SQLite是一种轻量级的,嵌入式的数据库系统,它占用的资源非常低。SQLite通过文件来保存数据库与,一个文件就是一个数据库。
Android平台下数据库相关类
◆SQLiteOpenHelper 抽象类:通过从此类继承实现用户类,来提供数据库打开、关闭等操作函数。
◆SQLiteDatabase 数据库访问类:执行对数据库的插入记录、查询记录等操作。
◆SQLiteCursor 查询结构操作类:用来访问查询结果中的记录。
- SQLiteOpenHelper抽象类
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){}
这个方法在更新数据库的时候调用,进行的是一些更新的操作。
- SQLiteDatabase 数据库的使用:
要获取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);
- Cursor的使用:
通过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;
}
}