SQLite是一种轻量级的,嵌入式的数据库系统,它占用的资源非常低。SQLite通过文件来保存数据库与,一个文件就是一个数据库。
◆SQLiteOpenHelper 抽象类:通过从此类继承实现用户类,来提供数据库打开、关闭等操作函数。
◆SQLiteDatabase 数据库访问类:执行对数据库的插入记录、查询记录等操作。
◆SQLiteCursor 查询结构操作类:用来访问查询结果中的记录。
package com.test.sqlitedemo; import android.R.integer; import android.content.Context; import android.database.sqlite.SQLiteDatabase; import android.database.sqlite.SQLiteDatabase.CursorFactory; import android.database.sqlite.SQLiteOpenHelper; import android.os.DropBoxManager; import android.provider.Contacts.Intents.Insert; import android.text.style.SuperscriptSpan; import android.widget.TableLayout; public class dbHelper extends SQLiteOpenHelper { private static String dbname = "data.db"; private static int version = 1; //构造方法1(一般用方法1比较好,应为数据库名字和版本不会改变) public dbHelper(Context context) { super(context, dbname, null, version); } //构造方法2 public dbHelper(Context context,String name,CursorFactory cursorFactory,int version) { //调用父类的构造方法 super(context, name, cursorFactory, version); } @Override public void onCreate(SQLiteDatabase db) { // 创建数据库后,对数据库的操作(比如建表) db.execSQL("CREATE TABLE IF NOT EXISTS person (id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR(20), age INTEGER)"); } @Override public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { // 更新数据库版本的操作 db.execSQL("DROP TABLE IF EXISTS person"); onCreate(db); } }
SQLiteOpenHelper主要的三个方法是:
①构造方法:
public dbHelper(Context context){}
或
public dbHelper(Context context,String name,CursorFactory cursorFactory,int version){}
其中,context是上下文环境,一般是Activity;name是数据库名字;cursorFactory是游标工程,一般为null;version是指现在数据库版本,由自己指定。
②onCreate(){}方法
public void onCreate(SQLiteDatabase db){}
这个方法在数据库第一次创建的时候调用,一般是做一些数据库的初始化工作,比如建表。
这个方法的参数是一个SQLiteDatabase数据库,建表之类的工作,就是通过调用db.execSQL()完成。
③onUpgrade(){}
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion){}
这个方法在更新数据库的时候调用,进行的是一些更新的操作。
要获取SQLiteDatebase对象,可以使用
SQLiteDatabase db = databaseHelper.getWritableDatabase();
或者
SQLiteDatabase db = databaseHelper.getReaderableDatabase();
二者的区别是:在数据库是可读写时,无异;当数据库是只读时,前者会抛出异常。
获取了db对象后,利用execSQL()方法,就可以对数据库进行增删改查操作了。
例如:
db.execSQL("DROP TABLE IF EXISTS person"); db.execSQL("CREATE TABLE person(id INTEGER PRIMARY KEY AUTOINCREMENT,name VARCHAR(20), age INTEGER)");
可以使用DDL语言。
对于不熟悉SQL语言的程序员,也可以使用SQLiteDatebase提供的方法:
db.query(),db.insert(),db.update(),db.delete()
这些方法会和哈希键--值对ContentValues一起用到,例如:
ContentValues contentValues = new ContentValues(); contentValues.put("name", person.getName()); contentValues.put("age", person.getAge()); database.insert("person", null, contentValues);
通过db.rawQuery()返回的查询结果,可以用Cursor来指向他们。
Cursor指向的是返回结果的第1个记录的前面一个节点,所以要获取操作第一个记录,需要 Cursor.moveToNext()。
例如:
String args[]={et_id.getText().toString()}; Cursor cursor=db.rawQuery("select name,age from student where id=?",args); if(cursor.moveToNext()) { et_name.setText(cursor.getString(cursor.getColumnIndex("name"))); et_age.setText(cursor.getString(cursor.getColumnIndex("age"))); Toast.makeText(MainActivity.this, "查詢成功", Toast.LENGTH_LONG).show(); }
下面的代码示出Acitivity里面,如何使用这些SQLite
package com.test.sqlitedemo; import android.R.integer; import android.R.string; import android.os.Bundle; import android.app.Activity; import android.content.ContentValues; import android.content.DialogInterface.OnClickListener; import android.database.Cursor; import android.database.sqlite.SQLiteDatabase; import android.view.Menu; import android.view.MenuItem; import android.view.View; import android.widget.Button; import android.widget.EditText; import android.widget.Toast; import android.support.v4.app.NavUtils; public class MainActivity extends Activity { private Button btn_selcet,btn_insert,btn_update,btn_delete; private EditText et_id,et_name,et_age; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); btn_selcet=(Button)findViewById(R.id.btn_select); btn_insert=(Button)findViewById(R.id.btn_insert); btn_update=(Button)findViewById(R.id.btn_update); btn_delete=(Button)findViewById(R.id.btn_delete); et_id=(EditText)findViewById(R.id.et_id); et_name=(EditText)findViewById(R.id.et_name); et_age=(EditText)findViewById(R.id.et_age); btn_selcet.setOnClickListener(listener); btn_insert.setOnClickListener(listener); btn_update.setOnClickListener(listener); btn_delete.setOnClickListener(listener); } View.OnClickListener listener=new View.OnClickListener() { @Override public void onClick(View v) { // 獲取SQLiteDatabase實例db,然後對各個事件調用db的不同操作 DBHelper dbHelper=new DBHelper(MainActivity.this); SQLiteDatabase db=dbHelper.getWritableDatabase(); switch (v.getId()) { case R.id.btn_select://查詢 if(et_id.getText().toString()!=null) { String args[]={et_id.getText().toString()}; Cursor cursor=db.rawQuery("select name,age from student where id=?",args); if(cursor.moveToNext()) { et_name.setText(cursor.getString(cursor.getColumnIndex("name"))); et_age.setText(cursor.getString(cursor.getColumnIndex("age"))); Toast.makeText(MainActivity.this, "查詢成功", Toast.LENGTH_LONG).show(); } } else { Toast.makeText(MainActivity.this, "查詢ID不能為空", Toast.LENGTH_LONG).show(); } break; case R.id.btn_insert://添加 if (et_id.getText().toString()!=null) { db.execSQL("insert into student(id,name,age) values(?,?,?)",new String[]{et_id.getText().toString(),et_name.getText().toString(),et_age.getText().toString()}); Toast.makeText(MainActivity.this, "添加"+et_id.getText().toString()+"成功", Toast.LENGTH_LONG).show(); } else { Toast.makeText(MainActivity.this, "插入ID不能為空", Toast.LENGTH_LONG).show(); } break; case R.id.btn_update://更新 db.execSQL("update student set name=?,age=? where id=?",new String[]{et_name.getText().toString(),et_age.getText().toString(),et_id.getText().toString()}); Toast.makeText(MainActivity.this, "更新成功", Toast.LENGTH_LONG).show(); break; case R.id.btn_delete://刪除 db.execSQL("delete from student where id=?",new String[]{et_id.getText().toString()}); et_id.setText(""); et_name.setText(""); et_age.setText(""); Toast.makeText(MainActivity.this, "刪除成功", Toast.LENGTH_LONG).show(); break; default: break; } } }; @Override public boolean onCreateOptionsMenu(Menu menu) { getMenuInflater().inflate(R.menu.activity_main, menu); return true; } }