sqlite 是android应用程序自带的一个数据库,很小,很快。
下面对他的使用简单的介绍一下。
最好可以使用adb shell去查看,有点要注意的是,如果用真机模拟的时候,需要开启root权限,不然是看不了databases的内容的。虚拟机的话可以直接查看。
布局文件xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" tools:context=".sqliteTestActivity" > <Button android:id="@+id/BTN_ID" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Create DataBase"/> <Button android:id="@+id/BTNINS_ID" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Insert DataBase"/> <Button android:id="@+id/BTNQUR_ID" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="Query DataBase"/> </LinearLayout>然后是一个继承了sqliteOpenHelper的自定义类
package com.example.sqlitetest; import android.content.Context; import android.database.sqlite.sqliteDatabase; import android.database.sqlite.sqliteDatabase.CursorFactory; import android.database.sqlite.sqliteOpenHelper; import android.widget.Toast; public class MyDatabaseHepler extends sqliteOpenHelper{ public static final String CreateStr = "create table Book(" +"id integer primary key autoincrement," +"author text," +"price real," +"pages integer," +"name text)" ; private Context mcontext ; public MyDatabaseHepler(Context context,String name,CursorFactory factory,int version) { super(context,name,factory,version); mcontext = context ; // TODO Auto-generated constructor stub } @Override public void onCreate(sqliteDatabase arg0) { // TODO Auto-generated method stub arg0.execsql(CreateStr) ; Toast.makeText(mcontext,"Create succsse",Toast.LENGTH_LONG).show() ; } @Override public void onUpgrade(sqliteDatabase arg0,int arg1,int arg2) { // TODO Auto-generated method stub } }
activty.java文件
package com.example.sqlitetest; import android.app.Activity; import android.content.ContentValues; import android.database.Cursor; import android.database.sqlite.sqliteDatabase; import android.os.Bundle; import android.util.Log; import android.view.Menu; import android.view.View; import android.view.View.OnClickListener; import android.widget.Button; import android.widget.Toast; public class sqliteTestActivity extends Activity { private MyDatabaseHepler myDatabaseHepler ; private Button btn ; private Button btnInset ; private Button btnQuery ; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_sqlite_test); myDatabaseHepler = new MyDatabaseHepler(this,"NewBookStore.db",null,1) ; /*在点击btn响应了对应的代码 MyDtabaseHelper构造的时候传入的第二个参数,是一个数据库 而不是一个表 *当myDatabaseHelper去调用getWriterDatabase的时候会发现当前数据库并没有这个数据库 *于是就会去响应 oncreat的方法于是 BookStore就创建了 并且在Oncreate里面 也实现了创建表book的方法 *下次在点击的时候 就知道数据库已经存在BookStroe了 那么oncreate就不会再去调用 */ btn = (Button) findViewById(R.id.BTN_ID) ; btn.setOnClickListener(new OnClickListener() { @Override public void onClick(View arg0) { // TODO Auto-generated method stub myDatabaseHepler.getWritableDatabase() ; } }) ; btnInset = (Button) findViewById(R.id.BTNINS_ID) ; btnInset.setOnClickListener(new OnClickListener() { @Override public void onClick(View arg0) { // TODO Auto-generated method stub sqliteDatabase db = myDatabaseHepler.getWritableDatabase() ; ContentValues values= new ContentValues() ; values.put("name","nihao") ; values.put("author","buhao") ; values.put("pages",12) ; values.put("price",1.2) ; db.insert("Book",values) ; Log.d("Insert11","1") ; } }) ; btnQuery = (Button) findViewById(R.id.BTNQUR_ID) ; btnQuery.setOnClickListener(new OnClickListener() { @Override public void onClick(View arg0) { // TODO Auto-generated method stub sqliteDatabase db = myDatabaseHepler.getWritableDatabase() ; Cursor cursor = db.query("Book",null) ; if(cursor.moveToFirst()){ do { String name = cursor.getString(cursor.getColumnIndex("name") ) ; Log.d("BookName",name) ; } while (cursor.moveToNext()); } cursor.close() ; } }) ; } @Override public boolean onCreateOptionsMenu(Menu menu) { // Inflate the menu; this adds items to the action bar if it is present. getMenuInflater().inflate(R.menu.sqlite_test,menu); return true; } }