sqlite作为轻量型数据库,也就是一个.db文件,使用起来非常方便。下面简单介绍下数据库常用的增删改查操作。
首先布局文件:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/createdatabase" android:text="创建数据库" /> <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/insert" android:text="插入数据" /> <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/query" android:text="查询并显示数据" /> <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/update" android:text="更新数据" /> <Button android:layout_width="match_parent" android:layout_height="wrap_content" android:id="@+id/delete" android:text="删除数据" /> <TextView android:id="@+id/text" android:layout_width="wrap_content" android:layout_height="30dp" android:text="显示数据" /> </LinearLayout>效果:
借助sqliteOpenHelper创建数据库,创建了一张表worker(id,name,adress),可以指定id为主键:id integer primary key,还可以指定自动增长,再加上autoincrement就行了。简单的说明下sqlite中常用数据类型,integer表示整型,text表示文本类型,real表示浮点型,blob表示二进制类型。
public class myDatabaseAdapter extends sqliteOpenHelper{ private final String CREATE_TABLE_A = "create table worker(" + "id integer," + "name text," + "adress text)"; public myDatabaseAdapter(Context context,String name,CursorFactory factory,int version) { super(context,factory,version); // TODO 自动生成的构造函数存根 } @Override public void onCreate(sqliteDatabase db) { // TODO 自动生成的方法存根 db.execsql(CREATE_TABLE_A); } @Override public void onUpgrade(sqliteDatabase db,int oldVersion,int newVersion) { // TODO 自动生成的方法存根 } }MainActivity.java:
public class MainActivity extends Activity implements OnClickListener{ private String DB_NAME = "lios"; private Button buttoncreate; private Button insert; private Button query; private Button update; private Button delete; private TextView text; private sqliteDatabase db; private myDatabaseAdapter dbHelper; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); buttoncreate = (Button)findViewById(R.id.createdatabase); insert = (Button)findViewById(R.id.insert); query = (Button)findViewById(R.id.query); update = (Button)findViewById(R.id.update); delete = (Button)findViewById(R.id.delete); text = (TextView)findViewById(R.id.text); dbHelper= new myDatabaseAdapter(this,DB_NAME,null,1); buttoncreate.setOnClickListener(this); insert.setOnClickListener(this); query.setOnClickListener(this); update.setOnClickListener(this); delete.setOnClickListener(this); } public void onClick(View v) { // TODO 自动生成的方法存根 switch (v.getId()) { case R.id.createdatabase: db = dbHelper.getWritableDatabase(); break; case R.id.insert: sqliteDatabase db1 = dbHelper.getWritableDatabase(); db1.execsql("insert into worker (id,adress) values (?,?,?)",new String[]{"1","w","shanghai"}); /* ContentValues values = new ContentValues(); values.put("id",1); values.put("name","w"); values.put("adress","shanghai"); db1.insert("worker",values); values.clear(); values.put("id",3); values.put("name","d"); values.put("adress",values);*/ break; case R.id.query: sqliteDatabase db2 = dbHelper.getWritableDatabase(); Cursor cursor = db2.rawQuery("select * from worker",null); if(cursor.moveToFirst()){ int id = cursor.getInt(cursor.getColumnIndex("id")); String name = cursor.getString(cursor.getColumnIndex("name")); Log.d("name",name); String adress = cursor.getString(cursor.getColumnIndex("adress")); text.setText(id+name+adress); } cursor.close(); //关闭游标 break; case R.id.update: sqliteDatabase db3 = dbHelper.getWritableDatabase(); db3.execsql("update worker set id =? where name =?",new String[]{"5","w"}); Toast.makeText(this,"数据已更改",Toast.LENGTH_SHORT).show();; break; case R.id.delete: sqliteDatabase db4 = dbHelper.getWritableDatabase(); db4.execsql("delete from worker where adress = ?",new String[]{"beijing"}); break; default: break; } } public void onDestory(){ db.close(); } }
简单的分析上面代码,由于自己喜欢写sql语句,所以上面就直接写sql语句了,也可以用sqlite提供的方法进行操作。注意我们进行CRUD操作,都是借助 sqliteDatabase对象来进行操作,而sqliteOpenHelper抽象类中有方法getWritableDatabase()可以获得sqliteDatabase对象:
public sqliteDatabase getWritableDatabase() { synchronized (this) { return getDatabaseLocked(true); } }
或者用
sqliteOpenHelper抽象类中getReadableDatabase()方法来获取:
public sqliteDatabase getReadableDatabase() { synchronized (this) { return getDatabaseLocked(false); } }为了看的更清楚,给出getDatabaseLocked()函数部分,详细请阅读源码。
private sqliteDatabase getDatabaseLocked(boolean writable) { if (mDatabase != null) { if (!mDatabase.isOpen()) { // Darn! The user closed the database by calling mDatabase.close(). mDatabase = null; } else if (!writable || !mDatabase.isReadOnly()) { // The database is already open for business. return mDatabase; } } ..... .....
其中getWritableDatabase() 方法以读写方式打开数据库,一旦数据库的磁盘空间满了,数据库就只能读而不能写,倘若使用的是getWritableDatabase() 方法就会出错。 而getReadableDatabase()方法则是先以读写方式打开数据库,如果数据库的磁盘空间满了,就会打开失败,当打开失败后会继续尝试以只读方式打开数据库。如果该问题成功解决,则只读数据库对象就会关闭,然后返回一个可读写的数据库对象。