SQLite存储方式 SQLiteDatabase SQL

package com.eoeAndroid.SQLite;

import android.app.Activity;
import android.content.Context;
import android.database.Cursor;
import android.database.SQLException;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteOpenHelper;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;

public class ActivityMain extends Activity {
OnClickListener listener1 = null;
OnClickListener listener2 = null;
OnClickListener listener3 = null;
OnClickListener listener4 = null;
OnClickListener listener5 = null;

Button button1;
Button button2;
Button button3;
Button button4;
Button button5;

DatabaseHelper mOpenHelper;

private static final String DATABASE_NAME = "dbForTest.db";
private static final int DATABASE_VERSION = 1;
private static final String TABLE_NAME = "diary";
private static final String TITLE = "title";
private static final String BODY = "body";

/**
* SQLiteOpenHelper这个类是一个辅助类。这个类主要生成一个数据库,并对数据库的版本进行管理。
* 当在程序中调用这个类的方法getWritableDatabase()或者getReadableDatabase()方法的时候,
* 如果当时没有数据,那么android系统就会自动生成一个数据库。SQLiteOpenHelper是一个抽象类,
* 我们通常需要继承它,并且实现3个函数。
*
* onCreate(SQLiteDatabase ):在数据库第一次生成的时候会调用这个方法,一般在这个方法里
* 边生存数据库表
*
* onUpgrade(SQLiteDatabase,int,int):在数据库需要升级的时候,Android系统会主动的调用
* 这个方法。一般我们在这个方法里边删除数据表,并建立新表,当然是否还需要做其他的操作,完全取决
* 于应用的需求。
*
* onOpen(SQLiteDatabase):这是当打开数据库时的回调函数,一般用不到
*/
private static class DatabaseHelper extends SQLiteOpenHelper {
DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}

@Override
/**
* 一个SQLiteDatabase的实例代表了一个SQLite的数据库,通过SQLiteDatabase实例的一些方法,
* 我们可以执行SQL语句,对数据进行增、删、改、查的操作。需要注意的是,数据库对于一个应用来说
* 是私有的,并且在一个应用中,数据库的名字也是唯一的。
*/
public void onCreate(SQLiteDatabase db) {

String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE
+ " text not null, " + BODY + " text not null " + ");";
Log.i("haiyang:createDB=", sql);
db.execSQL(sql);
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}

@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
prepareListener();
initLayout();
mOpenHelper = new DatabaseHelper(this);
}

private void initLayout() {
button1 = (Button) findViewById(R.id.button1);
button1.setOnClickListener(listener1);

button2 = (Button) findViewById(R.id.button2);
button2.setOnClickListener(listener2);

button3 = (Button) findViewById(R.id.button3);
button3.setOnClickListener(listener3);
button4 = (Button) findViewById(R.id.button4);
button4.setOnClickListener(listener4);

button5 = (Button) findViewById(R.id.button5);
button5.setOnClickListener(listener5);

}

private void prepareListener() {
listener1 = new OnClickListener() {
public void onClick(View v) {
CreateTable();
}
};
listener2 = new OnClickListener() {
public void onClick(View v) {
dropTable();
}
};
listener3 = new OnClickListener() {
public void onClick(View v) {
insertItem();
}
};
listener4 = new OnClickListener() {
public void onClick(View v) {
deleteItem();
}
};
listener5 = new OnClickListener() {
public void onClick(View v) {
showItems();
}
};
}

/*
* 重新创建数据库
*/
private void CreateTable() {
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
String sql = "CREATE TABLE " + TABLE_NAME + " (" + TITLE
+ " text not null, " + BODY + " text not null " + ");";
Log.i("haiyang:createDB=", sql);

try {
db.execSQL("DROP TABLE IF EXISTS diary");
db.execSQL(sql);
setTitle("数据表重建成功");
} catch (SQLException e) {
setTitle("数据表重建失败");
}
}

/*
* 删除数据库
*/
private void dropTable() {
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
String sql = "drop table " + TABLE_NAME;
try {
db.execSQL(sql);
setTitle("删除数据表成功" + sql);
} catch (SQLException e) {
setTitle("删除数据表失败");
}
}

/*
*插入2条记录
*/
private void insertItem() {
//mOpenHelper.getWritableDatabase()这条语句负责一个可写的SQLite数据库,如果这个
//数据库还没有建立,那么mOpenHelper辅助类负责建立这个数据库,如果数据库已经建立,那么直接返回一个可写的数据库
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
String sql1 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
+ ") values('haiyang', 'android的发展真是迅速阿');";
String sql2 = "insert into " + TABLE_NAME + " (" + TITLE + ", " + BODY
+ ") values('icesky', 'android的发真真是迅速啊');";
try {
Log.i("haiyang:sql1=", sql1);
Log.i("haiyang:sql2=", sql2);
db.execSQL(sql1);
db.execSQL(sql2);
setTitle("插入两条数据成功");
} catch (SQLException e) {
setTitle("插入两条数据失败");
}
}

/*
* 删除一个条数据
*/
private void deleteItem() {
try {
SQLiteDatabase db = mOpenHelper.getWritableDatabase();
db.delete(TABLE_NAME, " title = 'haiyang'", null);
setTitle("删除title为haiyang的一条记录");
} catch (SQLException e) {

}
}


private void showItems() {

SQLiteDatabase db = mOpenHelper.getReadableDatabase();
String col[] = { TITLE, BODY };
Cursor cur = db.query(TABLE_NAME, col, null, null, null, null, null);
Integer num = cur.getCount();
setTitle(Integer.toString(num) + " 条记录");
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值