android初学之Sqlite数据库基本操作(下)

删除和修改的方法与(上)提到的增加的方法相似,都可以执行sql语句或者直接用ContentValue

查询操作

/**
	 * 
	 * 查询:查询与其他不同的是:
	 * 1,查询只要获取可读的数据库就可以了
	 * 2,增删改执行sql语句后都没有返回值,而查询需要有返回值Cursor
	 * @return
	 */
	public User find(int id){
		SQLiteDatabase db = myhelper.getReadableDatabase(); // 获取可读的数据库,先尝试获取可写的,异常再获取可读的
		Cursor c = db.rawQuery("SELECT name, password FROM user WHERE id=?", new String[]{id+""});
		
		/*第二种查询操作
		
		/**
		 *	最后三个参数:groupBy分组, having分组条件, orderBy排序
		 * 	user表,查询name和password两列, 查询条件是id 
		 */
		Cursor c = db.query("user", new String[]{"name","password"}, "id=?", new String[]{id +""}, null, null, null);
		
		*/
		
		User user = null;
		if(c.moveToNext()){	//将游标向后移动,返回移动是否成功,判断是否包含下一条记录
			String name = c.getString(c.getColumnIndexOrThrow("name"));
//先查到name的索引,在通过索引拿到内容,效率没下面的高
		//String name = c.getString(0);
		int password = c.getInt(1);
		user = new User(id, name, password);
	}		
		
		return user;
}

在测试类中:(创建类继承AndroidTestCase,清单文件中配置test节点,方法名以test开头)

public void testCreateDB(){		
	/**
	* 第一次执行,指定环境下没有数据库文件:创建数据库,执行oncreate方法
	* 以后再执行,数据库存在,版本号没变:只打开数据库
	* 数据库存在,版本号改变:打开数据库,执行onUpgrade()方法
       */
	MyHelper myhelper = new MyHelper(getContext());	//activity中以getApplicationContext()获取当前程序环境,测试类中以getContext()获取环境
	myhelper.getWriteableDatabase();	//获取可写的数据库
}
	
	在这里执行代码
	
public void testInsert(){
	UserDao dao = new UserDao(getContext());	//不能定义成全局变量
	dao.insert(new User("xxx",123456));
}

其余的方法与上面的相似,都是通过dao对象来调用方法。

你可能感兴趣的:(android初学之Sqlite数据库基本操作(下))