導航:首頁 > 網路數據 > androidsqlite查詢大數據

androidsqlite查詢大數據

發布時間:2023-09-06 04:31:41

Ⅰ android 怎麼讀取sqlite資料庫

SQLite介紹
SQLite是輕量級的、嵌入式的、關系型資料庫,目前已經在iPhone、Android等手機系統中使用,SQLite可移植性好,很容易使用,很小,高效而且可靠。SQLite嵌入到使用它的應用程序中,它們共用相同的進程空間,而不是單獨的一個進程。從外部看,它並不像一個RDBMS,但在進程內部,它卻是完整的,自包含的資料庫引擎。
在android中當需要操作SQLite資料庫的時候需要得到一個SQLiteOpenHelper對象,而SQLiteOpenHelper是一個抽象類,用戶需要繼承這個類,並實現該類中的一些方法。
1、繼承SQLiteOpenHelper之後就擁有了以下兩個方法:
◆getReadableDatabase() 創建或者打開一個查詢資料庫
◆getWritableDatabase()創建或者打開一個可寫資料庫
◆他們都會返回SQLiteDatabase對象,用戶通過得到的SQLiteDatabase對象進行後續操作
2、同時用戶還可以覆蓋以下回調函數,再對資料庫進行操作的時候回調以下方法:
◆onCreate(SQLiteDatabase):在資料庫第一次創建的時候會調用這個方法,一般我們在這個方法里邊創建資料庫表。
◆onUpgrade(SQLiteDatabase,int,int):當資料庫需要修改的時候,Android系統會主動的調用這個方法。一般我們在這個方法里邊刪除資料庫表,並建立新的資料庫表,當然是否還需要做其他的操作,完全取決於應用程序的需求。
◆onOpen(SQLiteDatabase):這是當打開資料庫時的回調函數,一般也不會用到。
需要注意
1、在SQLiteOepnHelper的子類當中,必須有以下該構造函數
public DatabaseHelper(Context context, String name, CursorFactory factory, int version) { //必須通過super調用父類當中的構造函數 super(context, name, factory, version); }為了方便,也可以創建其它的構造函數,含二個參數或者三個參數的。
2、函數public void onCreate(SQLiteDatabase db)是在調用getReadableDatabase()或者是getWritableDatabase()第一次創建資料庫的時候執行,實際上是在第一次得到SQLiteDatabse對象的時候,才會調用這個方法.
public void onCreate(SQLiteDatabase db) { System.out.println("create a Database"); //execSQL函數用於執行SQL語句 db.execSQL("create table user(id int,name varchar(20))"); }在向資料庫的表中插入記錄時,需要先將數據包含在一個ContentValues中,向該對象當中插入鍵值對,其中鍵是列名,值是希望插入到這一列的值,值必須和資料庫當中的數據類型一致。接著調用Databasehelper的getWritableDatabase方法來獲得可以寫入的Databasehelper對象,再向其中insert記錄。注意調用DatabaseHelper對象的insert,update或者query方法的參數的傳遞。
另外執行query方法後,返回的是一個Cursor游標,游標最開始指向的是記錄集合中第一行的上一行,因此首先需要先調用cursor.next()將游標移動到記錄集合的第一行,接著再獲取數據即可。
java代碼

public class SQLiteActivity extends Activity { /** Called when the activity is first created. */ private Button createButton; private Button insertButton; private Button updateButton; private Button updateRecordButton; private Button queryButton; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); createButton = (Button)findViewById(R.id.createDatabase); updateButton = (Button)findViewById(R.id.updateDatabase); insertButton = (Button)findViewById(R.id.insert); updateRecordButton = (Button)findViewById(R.id.update); queryButton = (Button)findViewById(R.id.query); createButton.setOnClickListener(new CreateListener()); updateButton.setOnClickListener(new UpdateListener()); insertButton.setOnClickListener(new InsertListener()); updateRecordButton.setOnClickListener(new UpdateRecordListener()); queryButton.setOnClickListener(new QueryListener()); } class CreateListener implements OnClickListener{ @Override public void onClick(View v) { //創建一個DatabaseHelper對象 DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db"); //只有調用了DatabaseHelper對象的getReadableDatabase()方法,或者是getWritableDatabase()方法之後,才會創建,或打開一個資料庫 SQLiteDatabase db = dbHelper.getReadableDatabase(); } } class UpdateListener implements OnClickListener{ @Override public void onClick(View v) { DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db",2); SQLiteDatabase db = dbHelper.getReadableDatabase(); } } class InsertListener implements OnClickListener{ @Override public void onClick(View v) { //生成ContentValues對象 ContentValues values = new ContentValues(); //想該對象當中插入鍵值對,其中鍵是列名,值是希望插入到這一列的值,值必須和資料庫當中的數據類型一致 values.put("id", 1); values.put("name","zhangsan"); DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db",2); SQLiteDatabase db = dbHelper.getWritableDatabase(); //調用insert方法,就可以將數據插入到資料庫當中 db.insert("user", null, values); } } //更新操作就相當於執行SQL語句當中的update語句 //UPDATE table_name SET XXCOL=XXX WHERE XXXXCOL=XX... class UpdateRecordListener implements OnClickListener{ @Override public void onClick(View arg0) { // TODO Auto-generated method stub //得到一個可寫的SQLiteDatabase對象 DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db"); SQLiteDatabase db = dbHelper.getWritableDatabase(); ContentValues values = new ContentValues(); values.put("name", "zhangsanfeng"); //第一個參數是要更新的表名 //第二個參數是一個ContentValeus對象 //第三個參數是where子句 db.update("user", values, "id=?", new String[]{"1"}); } } class QueryListener implements OnClickListener{ @Override public void onClick(View v) { System.out.println("aaa------------------"); Log.d("myDebug", "myFirstDebugMsg"); DatabaseHelper dbHelper = new DatabaseHelper(SQLiteActivity.this,"test_mars_db"); SQLiteDatabase db = dbHelper.getReadableDatabase(); Cursor cursor = db.query("user", new String[]{"id","name"}, "id=?", new String[]{"1"}, null, null, null); while(cursor.moveToNext()){ String name = cursor.getString(cursor.getColumnIndex("name")); System.out.println("query--->" + name); } } } }

Ⅱ 如何查看android應用的sqlit資料庫文件

要在Android系統中操作SQLite資料庫,是通過Android的核心類SQLiteDatabase類來實現的,通常情況下為了資料庫升級的需要以及使用方便,我們會選擇繼承SQLiteOpenHelper抽像類,但是SQLiteOpenHelper會將資料庫文件創建在一個固定的目錄(內存的/data/data/<package name/databases>目錄中),如果你想使用已經存在的資料庫文件也就是說資料庫會和程序一起發布,就得通過使用SQLiteDabase的靜態方法OpenOrCreateDatabase()方法來得到SQLiteDabase對象,下面是一個具體操作類:
package net.my.;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import net.my.jokebook.R;
import android.app.Activity;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
public class DBHelper {
//得到SD卡路徑
private final String DATABASE_PATH = android.os.Environment
.getExternalStorageDirectory().getAbsolutePath()
+ "/joke";
private final Activity activity;
//資料庫名
private final String DATABASE_FILENAME;
public DBHelper(Context context) {
// TODO Auto-generated constructor stub
//這里直接給資料庫名
DATABASE_FILENAME = "jokebook.db3";
activity = (Activity)context;
}
//得到操作資料庫的對象
public SQLiteDatabase openDatabase()
{
try
{
boolean b = false;
//得到資料庫的完整路徑名
String databaseFilename = DATABASE_PATH + "/" + DATABASE_FILENAME;
//將資料庫文件從資源文件放到合適地方(資源文件也就是資料庫文件放在項目的res下的raw目錄中)
//將資料庫文件復制到SD卡中 File dir = new File(DATABASE_PATH);
if (!dir.exists())
b = dir.mkdir();
//判斷是否存在該文件
if (!(new File(databaseFilename)).exists())
{
//不存在得到資料庫輸入流對象
InputStream is = activity.getResources().openRawResource(
R.raw.jokebook);
//創建輸出流
FileOutputStream fos = new FileOutputStream(databaseFilename);
//將數據輸出
byte[] buffer = new byte[8192];
int count = 0;
while ((count = is.read(buffer)) > 0)
{
fos.write(buffer, 0, count);
}
//關閉資源
fos.close();
is.close();
}
//得到SQLDatabase對象
SQLiteDatabase database = SQLiteDatabase.openOrCreateDatabase(
databaseFilename, null);
return database;
}
catch (Exception e)
{
System.out.println(e.getMessage());
}
return null;
}
}
寫完這個類之後,就能得到SQLiteDatabase對象,就能對資料庫操作了

Ⅲ android上如何使用sqlite資料庫

SQLite 一個非常流行的嵌入式資料庫,它支持 SQL 語言,並且只利用很少的內存就有很好的性能。此外它還是開源的,任何人都可以使用它。許多開源項目((Mozilla, PHP, Python)都使用了 SQLite.

Android 開發中使用 SQLite 資料庫
Activites 可以通過 Content Provider 或者 Service 訪問一個資料庫。下面會詳細講解如果創建資料庫,添加數據和查詢資料庫。
創建資料庫
Android 不自動提供資料庫。在 Android 應用程序中使用 SQLite,必須自己創建資料庫,然後創建表、索引,填充數據。Android 提供了 SQLiteOpenHelper 幫助你創建一個資料庫,你只要繼承 SQLiteOpenHelper 類,就可以輕松的創建資料庫。SQLiteOpenHelper 類根據開發應用程序的需要,封裝了創建和更新資料庫使用的邏輯。SQLiteOpenHelper 的子類,至少需要實現三個方法:
構造函數,調用父類 SQLiteOpenHelper 的構造函數。這個方法需要四個參數:上下文環境(例如,一個 Activity),資料庫名字,一個可選的游標工廠(通常是 Null),一個代表你正在使用的資料庫模型版本的整數。
onCreate()方法,它需要一個 SQLiteDatabase 對象作為參數,根據需要對這個對象填充表和初始化數據。
onUpgrage() 方法,它需要三個參數,一個 SQLiteDatabase 對象,一個舊的版本號和一個新的版本號,這樣你就可以清楚如何把一個資料庫從舊的模型轉變到新的模型。

Ⅳ 怎樣查看 android sqlite資料庫

1、看 sqlite資料庫來 可以使用eclipse的源插件DDMS,或者Android工具包中的adb工具來查看。sqlite資料庫在安卓項目中的位置是/data/data/項目包/databases中。

2、在這里呢 演示使用eclipse插件來看。在Eclipse安裝好插件,找到 DDMS

5、使用sqlite界面管理工具如sqlite administrator、sqlite man打開就可以了

閱讀全文

與androidsqlite查詢大數據相關的資料

熱點內容
javaweb面試 瀏覽:4
qq空間說說點不進去 瀏覽:772
nodejscms系統 瀏覽:822
追星數據組是什麼東西 瀏覽:3
文件的格式怎麼建立 瀏覽:529
免費yoosee蘋果下載 瀏覽:447
網路大國與大數據 瀏覽:770
怎麼學plc的編程 瀏覽:643
javadnf輔助源碼 瀏覽:973
什麼app可以畫二維圖像 瀏覽:125
手機如何設置副路由器設置密碼 瀏覽:592
如何讓已經壓縮的文件恢復 瀏覽:344
網路atm取款支出是什麼意思 瀏覽:942
ios查看wifi密碼插件 瀏覽:742
win10因藍屏 瀏覽:322
app病毒是如何植入的 瀏覽:384
hadoop文件系統查看 瀏覽:317
熱門app免流都有哪些 瀏覽:619
cad怎麼轉換mpgis文件 瀏覽:631
win10照片不能用了 瀏覽:878

友情鏈接