android数据库sqlite
android的数据库操作一般都在SQLiteOpenHelper类中,而SQLiteOpenHelper是一个抽象类,所以需要一个类来实现这个抽象类。这个类为DateBaseHelper。
DateBaseHelper作为一个访问SQLite的助手类,提供一下两个方面的功能
(1)getReadableDatabase(),getWriteableDatabase()可以获得SQLiteDatabase对象,通过该对象对数据库进行操作
(2)提供onCreate()和onUpgrade()两个回调函数,允许我们在创建数据库时,进行自己的操作
package com.yx.db;
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
public class DateBaseHelper extends SQLiteOpenHelper {
private static final int VERSION=2;//数据库的版本号
//在SQLiteOpenHelper的子类中必须有该构造函数,
//context为一个activity对象,name为表名,version为当前数据库的版本
public DateBaseHelper(Context context, String name, CursorFactory factory,
int version) {
super(context, name, factory, version);
}
public DateBaseHelper(Context context, String name) {
this(context,name,VERSION);
}
public DateBaseHelper(Context context, String name,int version) {
this(context,name,null,version);
}
//该函数是在第一次创建数据库时执行,实际上是第一次得到SQLiteDatabase时,才会掉用的方法
@Override
public void onCreate(SQLiteDatabase db) {
System.out.println("create a database");
db.execSQL("create table user(id int,name varchar(20))");
}
@Override
public void onUpgrade(SQLiteDatabase arg0, int arg1, int arg2) {
System.out.println("upgrade a db");
}
}
为了方便先贴出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:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity"
android:orientation="vertical"
>
<Button
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/creatDB"
android:text="创建数据库"
/>
<Button
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/updateDB"
android:text="更新数据库"
/>
<Button
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/insert"
android:text="增加"
/>
<Button
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/update"
android:text="更新"
/>
<Button
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:id="@+id/query"
android:text="查询"
/>
</LinearLayout>
下面是调用sqlite是方法的类。
package com.yx.sqlite;
import com.yx.db.DateBaseHelper;
import android.os.Bundle;
import android.app.Activity;
import android.content.ContentValues;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
import android.view.Menu;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
public class MainActivity extends Activity {
//获取Button
private Button creatDB;
private Button updateDB;
private Button insert;
private Button update;
private Button query;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
creatDB = (Button) findViewById(R.id.creatDB);
updateDB = (Button) findViewById(R.id.updateDB);
insert = (Button) findViewById(R.id.insert);
update = (Button) findViewById(R.id.update);
query = (Button) findViewById(R.id.query);
//给Button注册监听事件
creatDB.setOnClickListener(new creatDBButtonListener());
updateDB.setOnClickListener(new updateDBButtonListener());
insert.setOnClickListener(new insertButtonListener());
update.setOnClickListener(new updateButtonListener());
query.setOnClickListener(new queryButtonListener());
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.main, menu);
return true;
}
//创建数据库
class creatDBButtonListener implements OnClickListener{
@Override
public void onClick(View v) {
//下面两句是为了获得数据库
DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2");
//只有调用SQLiteDatabase的getReadableDatabase或getWriteableDatabase中的一个才可以创建数据库
SQLiteDatabase db = helper.getReadableDatabase();
}
}
//更新数据库
class updateDBButtonListener implements OnClickListener{
@Override
public void onClick(View v) {
DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2",2);
//只有调用SQLiteDatabase的getReadableDatabase或getWriteableDatabase中的一个才可以创建数据库
SQLiteDatabase db = helper.getReadableDatabase();
}
}
//给数据库添加数据
class insertButtonListener implements OnClickListener{
@Override
public void onClick(View v) {
ContentValues values = new ContentValues();
//向ContentValues对象插入键值对
values.put("id", 1);
values.put("name", "张三");
DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2",2);
SQLiteDatabase db = helper.getWritableDatabase();
db.insert("user", null, values);
}
}
//修改数据库的数据
class updateButtonListener implements OnClickListener{
@Override
public void onClick(View v) {
DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2",2);
SQLiteDatabase db = helper.getWritableDatabase();
ContentValues values = new ContentValues();
values.put("name", "zhangsan");
db.update("user", values, "id=?", new String[]{"1"});
}
}
//查询数据库的数据
class queryButtonListener implements OnClickListener{
@Override
public void onClick(View v) {
System.out.println("queryButtonListener");
DateBaseHelper helper = new DateBaseHelper(MainActivity.this, "textDB2",2);
SQLiteDatabase db = helper.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("quary-->"+name);
}
}
}
}
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。