Android中SQLite应用详解,企业级项目实战讲解

本文详细介绍了如何在Android中使用SQLite进行数据库操作,包括创建数据库、创建表、插入、更新、删除数据,以及查询操作。通过示例代码展示了如何使用SQL语句和ContentValues进行数据管理,并讲解了SQLiteOpenHelper的作用和使用。此外,文章还提到了事务处理的重要性,以及在实际项目中封装数据库操作类的方法。
摘要由CSDN通过智能技术生成

@Override

protected void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);

//打开或创建test.db数据库

SQLiteDatabase db = openOrCreateDatabase(“test.db”, Context.MODE_PRIVATE, null);

db.execSQL(“DROP TABLE IF EXISTS person”);

//创建person表

db.execSQL(“CREATE TABLE person (_id INTEGER PRIMARY KEY AUTOINCREMENT, name VARCHAR, age SMALLINT)”);

Person person = new Person();

person.name = “john”;

person.age = 30;

//插入数据

db.execSQL(“INSERT INTO person VALUES (NULL, ?, ?)”, new Object[]{person.name, person.age});

person.name = “david”;

person.age = 33;

//ContentValues以键值对的形式存放数据

ContentValues cv = new ContentValues();

cv.put(“name”, person.name);

cv.put(“age”, person.age);

//插入ContentValues中的数据

db.insert(“person”, null, cv);

cv = new ContentValues();

cv.put(“age”, 35);

//更新数据

db.update(“person”, cv, “name = ?”, new String[]{“john”});

Cursor c = db.rawQuery(“SELECT * FROM person WHERE age >= ?”, new String[]{“33”});

while (c.moveToNext()) {

int _id = c.getInt(c.getColumnIndex(“_id”));

String name = c.getString(c.getColumnIndex(“name”));

int age = c.getInt(c.getColumnIndex(“age”));

Log.i(“db”, “_id=>” + _id + “, name=>” + name + “, age=>” + age);

}

c.close();

//删除数据

db.delete(“person”, “age < ?”, new String[]{“35”});

//关闭当前数据库

db.close();

//删除test.db数据库

// deleteDatabase(“test.db”);

}

在执行完上面的代码后,系统就会在/data/data/[PACKAGE_NAME]/databases目录下生成一个“test.db”的数据库文件,如图:

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

上面的代码中基本上囊括了大部分的数据库操作;对于添加、更新和删除来说,我们都可以使用

[java] view plain copy print ?

  1. db.executeSQL(String sql);

  2. db.executeSQL(String sql, Object[] bindArgs);//sql语句中使用占位符,然后第二个参数是实际的参数集

db.executeSQL(String sql);

db.executeSQL(String sql, Object[] bindArgs);//sql语句中使用占位符,然后第二个参数是实际的参数集

除了统一的形式之外,他们还有各自的操作方法:

[java] view plain copy print ?

  1. db.insert(String table, String nullColumnHack, ContentValues values);

  2. db.update(String table, Contentvalues values, String whereClause, String whereArgs);

  3. db.delete(String table, String whereClause, String whereArgs);

db.insert(String table, String nullColumnHack, ContentValues values);

db.update(String table, Contentvalues values, String whereClause, String whereArgs);

db.delete(String table, String whereClause, String whereArgs);

以上三个方法的第一个参数都是表示要操作的表名;insert中的第二个参数表示如果插入的数据每一列都为空的话,需要指定此行中某一列的名称,系统将此列设置为NULL,不至于出现错误;insert中的第三个参数是ContentValues类型的变量,是键值对组成的Map,key代表列名,value代表该列要插入的值;update的第二个参数也很类似,只不过它是更新该字段key为最新的value值,第三个参数whereClause表示WHERE表达式,比如“age > ? and age < ?”等,最后的whereArgs参数是占位符的实际参数值;delete方法的参数也是一样。

下面来说说查询操作。查询操作相对于上面的几种操作要复杂些,因为我们经常要面对着各种各样的查询条件,所以系统也考虑到这种复杂性,为我们提供了较为丰富的查询形式:

[java] view plain copy print ?

  1. db.rawQuery(String sql, String[] selectionArgs);

  2. db.query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy);

  3. db.query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit);

  4. db.query(String distinct, String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit);

db.rawQuery(String sql, String[] selectionArgs);

db.query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy);

db.query(String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit);

db.query(String distinct, String table, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit);

上面几种都是常用的查询方法,第一种最为简单,将所有的SQL语句都组织到一个字符串中,使用占位符代替实际参数,selectionArgs就是占位符实际参数集;下面的几种参数都很类似,columns表示要查询的列所有名称集,selection表示WHERE之后的条件语句,可以使用占位符,groupBy指定分组的列名,having指定分组条件,配合groupBy使用,orderBy指定排序的列名,limit指定分页参数,distinct可以指定“true”或“false”表示要不要过滤重复值。需要注意的是,selection、groupBy、having、orderBy、

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值