SQLiteOpenHelper 

根据开发应用程序的需要,内部封装了创建和更新数据库使用的逻辑

使用SQLiteOpenHelper首先要创建一个类,该类继承自android.database.sqlite.SQLiteOpenHelper

而SQLiteDatabase.java中,构造函数是私有的,需要指定构造方法,接收参数为:

通过构造函数选择父类 SQLiteOpenHelper 的构造函数:

public myOpenHelper(Context context,String name,CursorFactory factory,int version) {
//context 上下文
//name 数据库的名称,"person.db"(文件数据库),如果是空则创建内存数据库
//factory 数据库查询结果的游标工厂,一般为null
//version 数据库的版本 >=1
super(context, "person.db", null, 4);

由于这个是抽象类, 因此你需要实现该类的两个方法

一个是

onCreate(SQLiteDatabase db),(数据库第一次创建的时候调用的方法,适合做数据库表结构的初始化)

db.execSQL("create table person (id integer primary key autoincrement , name varchar(20), phone varchar(20))");//用传进来的db例创建一个数据库

一个是

onUpgrage();

创建数据库

在测试类中使用上下文,getContext()  获取的是一个模拟的方便测试的上下文,用于提供数据库的路径等信息

1,在activity中创建myOpenHelper实例: myOpenHelper helper = new myOpenHelper(this);

在调用helper.getWriteableDatabase();时如果数据库中没有表,则会创建一个数据库表结构。

getWriteableDatabase();该方法会调用SQLiteOpenHelper类中的

<span style="font-size:14px;">getWritableDatabase()<span style="font-family: 'Microsoft YaHei', 'Segoe UI', Tahoma, Arial, Helvetica, sans-serif;">方法</span></span>
<span style="font-size:14px;"> public SQLiteDatabase getWritableDatabase() {
        synchronized (this) {
            return getDatabaseLocked(true);
        }
    }</span>


在getDatabaseLocked(true);方法中会判断数据库是否已经创建过,执行创建或是返回等操作

关于数据库中存放的类型

SQLite,SQLite3支持 NULL、INTEGER、REAL(浮点数字)、TEXT(字符串文本)和BLOB(二进制对象)数据类型,虽然它支持的类型只有五种,但实际上sqlite3也接受varchar(n)、char(n)、decimal(p,s) 等数据类型,只不过在运算或保存时会转成对应的五种数据类型。 SQLite最大的特点是你可以把各种类型的数据保存到任何字段中,而不用关心字段声明的数据类型是什么。

数据库的操作

语句:

查询语句:   select * from person where name = 'zhangsan'

插入语句:insertinto 表名(字段列表)values(值列表)。如:insert into person(name, age) values(‘lisi’,3)

更新语句:update表名set字段名=值where条件子句。如:update person set name='zhangsan' where id=10

删除语句:deletefrom 表名where条件子句。如:delete from person  where id=10


代码包装数据库语句

创建一个类 persondao.java

数据库增删改查方法1:

<span style="font-size:14px;">public class PersonDao {
	private PersonDBOpenHelper helper;
	public PersonDao(Context context) { 创建对象,传递上下文,得到PersonDBOpenHelper对象</span>
		helper = new PersonDBOpenHelper(context);在构造函数中创建对象
	}
	 * 添加一条记录
public void add(String name,String phone){
		SQLiteDatabase  db = helper.getWritableDatabase();
		db.execSQL("insert into person (name,phone) values (?,?)", new Object[]{name,phone});
		db.close();//最好记得关闭数据库, 避免如果有过的打开的连接 导致数据库以后无法访问.
	}
	 * 查询一条记录
	public boolean find(String name){
		SQLiteDatabase db = helper.getReadableDatabase(); 
		Cursor cursor = db.rawQuery("select * from  person where name=?", new String[]{name});
		boolean result = cursor.moveToFirst();//如果可以移动则返回ture
		cursor.close();
		db.close();
		return result;
	}
	 * @param 姓名根据姓名修改
	 * @param newphone  新的电话号码
	public void update(String name,String newphone){
		SQLiteDatabase  db = helper.getWritableDatabase();
		db.execSQL("update person set phone=? where name=?", new Object[]{newphone , name});
		db.close();
	}
	 * 删除记录
	public void delete(String name){
		SQLiteDatabase  db = helper.getWritableDatabase();
		db.execSQL("delete from person where name=?", new Object[]{ name});
		db.close();
	}
}</span>



方法处理完毕,则可以在activity中创建对象,调用方法

personDao dao = new personDao(this);
dao.add("zhangsan","123456");
dao.update("zhangsan","110");




数据库增删改查2(API):注释的为第一种方法

此方法能显示增删改查的结果

<span style="font-size:14px;">public class PersonDao2 {
	private PersonDBOpenHelper helper;
	public PersonDao2(Context context) {
		helper = new PersonDBOpenHelper(context);
	}
	public boolean add(String name, String phone) {
		SQLiteDatabase db = helper.getWritableDatabase();
		// db.execSQL("insert into person (name,phone) values (?,?)", new
		// Object[]{name,phone});
		ContentValues values = new ContentValues();//内部是一个map集合
		values.put("name", name);
		values.put("phone", phone);
		long id = db.insert("person", null, values);//返回一个被影响的行的id,如果失败则返回-1
		db.close();
		return id != -1;
	}

	public boolean find(String name) {
		SQLiteDatabase db = helper.getReadableDatabase();
		/*
		 * Cursor cursor = db.rawQuery("select * from peron where name =?", new
		 * String[]{name});
		 */
		Cursor cursor = db.query("person", null(返回哪几列), "name=?",
				new String[] { name }, null, null, null);
		boolean result = cursor.moveToFirst();
		cursor.close();
		db.close();
		return result;
	}
	/**
	 * 获取全部的person信息
	 * @return
	 */
	public List<Person> findAll(){//返回list集合,集合中装person对象,需要创建
		SQLiteDatabase db = helper.getReadableDatabase();
		Cursor cursor = db.query("person", null(返回全部), null, null, null, null, null);
		List<Person> persons = new ArrayList<Person>();
		while(cursor.moveToNext()){//遍历结果集
			int id = cursor.getInt(cursor.getColumnIndex("id")<span style="font-family: 'Microsoft YaHei', 'Segoe UI', Tahoma, Arial, Helvetica, sans-serif;">(根据id得到例)</span>);
			String name = cursor.getString(cursor.getColumnIndex("name")(根据name得例));
			String phone = cursor.getString(cursor.getColumnIndex("phone"));
			long account = cursor.getLong(cursor.getColumnIndex("account"));
			Person person = new Person(name, phone, id);
			person.setAccount(account);
			persons.add(person);
		}
		cursor.close();
		db.close();
		return persons;
	}
		public boolean update(String name, String newphone) {
		SQLiteDatabase db = helper.getReadableDatabase();
		// db.execSQL("update person set phone=? where name=?", new
		// Object[]{newphone,name});
		ContentValues values = new ContentValues();
		values.put("phone", newphone);
		int result = db.update("person", values, "name=?",//返回的int为影响了多少行
				new String[] { name });
		db.close();
		return result>0;
	}
	public boolean delete(String name) {
		SQLiteDatabase  db = helper.getWritableDatabase();
	//	db.execSQL("delete from person where name=?", new Object[]{ name});
		int result = db.delete("person", "name=?", new String[]{name});//int值为影响了多少行
		db.close();
		return result>0;
	}
}
</span>


推荐使用第二种方法,稳定性高

往数据库中添加一列:名为account的列,将版本更新就能调用onupgrade方法


public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
//程序的2.0的版本也要发布了. 2.0的版本 增加一个新的表  
db.execSQL("alter table person add account varchar(20)");
}

数据库的事物:如转账,需要金额减少的一方和金额增加的一方都执行,增加数据库的事物

db.beginTransaction();// 开始数据库的事务
try {
db.execSQL("update person set account = account-100 where name='zhangsan'");
// s.equals("haha");
db.execSQL("update person set account = account+100 where name='zhangsan0'");
db.setTransactionSuccessful(); // 如果没有标记数据库事务成功 //数据会回滚
} finally {
db.endTransaction(); // 检查是否设置了事务成功的flag
}
db.close();