한국어

네트워킹

온누리070 플레이스토어 다운로드
    acrobits softphone
     온누리 070 카카오 프러스 친구추가온누리 070 카카오 프러스 친구추가친추
     카카오톡 채팅 상담 카카오톡 채팅 상담카톡
    
     라인상담
     라인으로 공유

     페북공유

   ◎위챗 : speedseoul


  
     PAYPAL
     
     PRICE
     

pixel.gif

    before pay call 0088 from app


http://v4all123.blogspot.jp/2013/03/sqlite-databases-with-external-db.html


http://mobile-development-tutorial.blogspot.jp/2012/12/android-external-sqlite-database.html



SQLite Databases using External DB


This is tutorial for accessing external DB from assets folder. In android We can create sqlite database by using SQLite Database Browser. Now the question is how to access this database in source code. The answer is very simple. Store the database in assets folder that is placed in project folder.


Then we can access this database in dbhelper class using

  1. context.getAssets().open(DB_NAME);  

After this we should copy this database to our root directory. Why because our SQLiteOpenHelper reads data from root directory only. for this we have to open new empty file in root directory by using. 
  1. private String DB_PATH = "/data/data/" + context.getPackageName() + "/" + "databases/";  
  2. String DB_NAME = "database";  
  3. String outFileName = DB_PATH + DB_NAME;  
  4. OutputStream myOutput = new FileOutputStream(outFileName);  
then we have to copy our data to this empty file by using. 
  1. byte[] buffer = new byte[1024];  
  2. int length;  
  3. while ((length = myInput.read(buffer)) > 0) {  
  4. myOutput.write(buffer, 0, length);  
  5. }  

Now we can access our data from root directory db to our project easily. Sample project to implement external sqlite database access in android. 

DBHelper.java
  1. package com.android.sqlite;  
  2.   
  3. import java.io.File;  
  4. import java.io.FileOutputStream;  
  5. import java.io.IOException;  
  6. import java.io.InputStream;  
  7. import java.io.OutputStream;  
  8. import android.content.Context;  
  9. import android.database.Cursor;  
  10. import android.database.sqlite.SQLiteDatabase;  
  11. import android.database.sqlite.SQLiteOpenHelper;  
  12.   
  13. public class DBHelper extends SQLiteOpenHelper {  
  14.   
  15.  private static String DB_NAME = "database";  
  16.  private SQLiteDatabase db;  
  17.  private final Context context;  
  18.  private String DB_PATH;  
  19.   
  20.  public DBHelper(Context context) {  
  21.   super(context, DB_NAME, null1);  
  22.   this.context = context;  
  23.   DB_PATH = "/data/data/" + context.getPackageName() + "/" + "databases/";  
  24.  }  
  25.   
  26.  public void createDataBase() throws IOException {  
  27.   
  28.   boolean dbExist = checkDataBase();  
  29.   if (dbExist) {  
  30.   
  31.   } else {  
  32.    this.getReadableDatabase();  
  33.    try {  
  34.     copyDataBase();  
  35.    } catch (IOException e) {  
  36.     throw new Error("Error copying database");  
  37.    }  
  38.   }  
  39.  }  
  40.   
  41.  private boolean checkDataBase() {  
  42.   File dbFile = new File(DB_PATH + DB_NAME);  
  43.   return dbFile.exists();  
  44.  }  
  45.   
  46.  private void copyDataBase() throws IOException {  
  47.   
  48.   InputStream myInput = context.getAssets().open(DB_NAME);  
  49.   String outFileName = DB_PATH + DB_NAME;  
  50.   OutputStream myOutput = new FileOutputStream(outFileName);  
  51.   byte[] buffer = new byte[1024];  
  52.   int length;  
  53.   while ((length = myInput.read(buffer)) > 0) {  
  54.    myOutput.write(buffer, 0, length);  
  55.   }  
  56.   
  57.   // Close the streams  
  58.   myOutput.flush();  
  59.   myOutput.close();  
  60.   myInput.close();  
  61.   
  62.  }  
  63.   
  64.  public Cursor getData() {  
  65.   String myPath = DB_PATH + DB_NAME;  
  66.   db = SQLiteDatabase.openDatabase(myPath, null,  
  67.     SQLiteDatabase.OPEN_READONLY);  
  68.   Cursor c = db.rawQuery("SELECT * FROM master"null);  
  69.    // Note: Master is the one table in External db. Here we trying to access the records of table from external db.  
  70.   return c;  
  71.  }  
  72.   
  73.  @Override  
  74.  public void onCreate(SQLiteDatabase arg0) {  
  75.   // TODO Auto-generated method stub  
  76.  }  
  77.   
  78.  @Override  
  79.  public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {  
  80.   // TODO Auto-generated method stub  
  81.  }  
  82. }  

And 
ExternalDBActivity.java 
  1. package com.android.sqlite;  
  2.   
  3. import java.io.IOException;  
  4.   
  5. import android.app.Activity;  
  6. import android.database.Cursor;  
  7. import android.os.Bundle;  
  8. import android.widget.ListView;  
  9. import android.widget.SimpleCursorAdapter;  
  10.   
  11. public class ExternalDBActivity extends Activity {  
  12.  /** Called when the activity is first created. */  
  13.  DBHelper dbhelper;  
  14.   
  15.  @Override  
  16.  public void onCreate(Bundle savedInstanceState) {  
  17.   super.onCreate(savedInstanceState);  
  18.   setContentView(R.layout.main);  
  19.     
  20.   // if you use siplecursoradapter then you should have _id as one of column name and its values should be integer in your db.  
  21.   // so "_id", "columnName1", "columnName2" are column names from your db.  
  22.   String[] from = new String[] { "_id""columnName1""columnName2" };  
  23.   int[] to = new int[] { R.id.TextView1, R.id.TextView2, R.id.TextView3 };  
  24.   
  25.   dbhelper = new DBHelper(this);  
  26.   try {  
  27.    dbhelper.createDataBase();  
  28.   } catch (IOException e) {  
  29.    // TODO Auto-generated catch block  
  30.    e.printStackTrace();  
  31.   }  
  32.   
  33.   Cursor c = dbhelper.getData();  
  34.     
  35.   SimpleCursorAdapter adapter = new SimpleCursorAdapter(  
  36.     getApplicationContext(), R.layout.list, c, from, to);  
  37.     
  38.    ListView list = (ListView) findViewById(R.id.ListView1);  
  39.     
  40.    list.setAdapter(adapter);  
  41.  }  
  42. }  

main.xml 
  1. <?xml version="1.0" encoding="utf-8"?<  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="fill_parent"  
  4.     android:layout_height="fill_parent"  
  5.     android:orientation="vertical" <  
  6.   
  7.     <ListView  
  8.         android:id="@+id/ListView1"  
  9.         android:layout_width="fill_parent"  
  10.         android:layout_height="wrap_content" <  
  11.     </ListView<  
  12.   
  13. </LinearLayout<  
list.xml 
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     android:layout_width="match_parent"  
  4.     android:layout_height="match_parent"  
  5.     android:gravity="center" >  
  6.   
  7.     <TextView  
  8.         android:id="@+id/TextView1"  
  9.         android:layout_width="wrap_content"  
  10.         android:layout_height="wrap_content"  
  11.         android:layout_margin="10dp" />  
  12.   
  13.     <TextView  
  14.         android:id="@+id/TextView2"  
  15.         android:layout_width="wrap_content"  
  16.         android:layout_height="wrap_content"  
  17.         android:layout_margin="10dp" />  
  18.   
  19.     <TextView  
  20.         android:id="@+id/TextView3"  
  21.         android:layout_width="wrap_content"  
  22.         android:layout_height="wrap_content"  
  23.         android:layout_margin="10dp" />  
  24.   
  25. </LinearLayout>  
Related article How to create and use SQLite database dynamically 

Reduce your work by using SQLiteHelper.jar 

Thank You


조회 수 :
36293
등록일 :
2014.02.14
22:14:25 (*.251.139.148)
엮인글 :
http://webs.co.kr/index.php?document_srl=38764&act=trackback&key=0d9
게시글 주소 :
http://webs.co.kr/index.php?document_srl=38764
List of Articles
번호 제목 글쓴이 조회 수 추천 수sort 날짜
67 Oracle 10G installation admin 37288   2011-12-13
 
66 Oracle 의 ASM 구조 알아보기.. admin 39892   2011-12-13
 
65 오라클 아키텍쳐 admin 36258   2011-12-13
 
64 Oracle ACE 로부터 배우기 admin 39341   2011-12-16
 
63 Oracle Preinstallation Tasks admin 33550   2011-12-16
 
62 Oracle 의 ASM 구조 알아보기.. admin 40528   2011-12-16
 
61 Oracle 설치 Centos ,openSUSE,엔터프라이즈등 퍼온글 admin 36678   2011-12-16
 
60 xhost and display admin 34915   2011-12-16
 
59 (C#) ASP.NET MySQL Check Already Exists Add/Insert Record 프로그래밍 코드 admin 34667   2011-12-19
 
58 Java && Excel 연동 JAVA 자바로 엑셀을 핸들링 할 수 있는 방법 admin 193046   2011-12-19
 
57 http://www.hoons.kr/ admin 34821   2011-12-19
 
56 Oracle Backup & Restore admin 87885   2012-02-07
 
55 오라클 ACE가 해설하는 Oracle Backup & Recovery admin 41315   2012-02-07
 
54 Oracle Backup & restore with RMAN 기본 admin 42005   2012-02-12
 
53 Oracle RHEL4+10G 10.2.0.1 설치 10.2.0.5 패치 admin 95182   2012-03-03
 
52 Upgrade Oracle 10g Release 2 from 10201 to 10204 admin 110825   2012-03-05
 
51 centos 6.2 oracle 10g 설치 admin 108671   2012-03-05
 
50 Upgrade Oracle from 10.2.0.1 To 10.2.0.4 (Windows) admin 164551   2012-03-06
 
49 SUSE Linux Enterprise Server 10 (Oracle 10g R2 (10.2.0.1)) file admin 37495   2012-03-09
 
48 Oracle 10g Articles admin 32053   2012-06-24
 
47 기본 10g 설치의 리눅스 세팅에서 추가 해줘야하는 사항(윈도우) admin 39493   2012-06-24
 
46 Connect Excel VBA to a MySQL database file admin 45541   2013-09-05
 
45 MySQL Java tutorial admin 48521   2012-09-30
 
44 Configuring Oracle ASM disks in Oracle Enterprise Linux admin 38303   2013-04-20
 
43 PreparedStatement mysql java 깔끔한설명 admin 105655   2013-10-26
 
42 Oracle Linux 에 Oracle DB 설치하기 admin 104608   2013-12-03
 
41 OLE5 + 11G 설치 _silent mode admin 84241   2013-04-08
 
40 RHEL4 + 10g 설치 _silent mode admin 81080   2013-04-08
 
39 OS에따른 Oracle 설치버전 admin 32063   2013-04-08
 
38 SUPER OCM 1.8club admin 31089   2012-12-18