Android关于数据库CRUD操作
首先需要使用SQLiteDataBase获取连接对象
其次需要SQLHelper对象进行database的连接和关闭
public class UserDBHelper extends SQLiteOpenHelper { private static final String TAG = "UserDBHelper"; private static final String DB_NAME = "user.db"; // 数据库的名称 private static final int DB_VERSION = 1; // 数据库的版本号 private static UserDBHelper mHelper = null; // 数据库帮助器的实例 private SQLiteDatabase mDB = null; // 数据库的实例 public static final String TABLE_NAME = "user_info"; // 表的名称 //dbhelper对象首先需要通过构造器传递数据库的名称以及版本号 private UserDBHelper(Context context) { super(context, DB_NAME, null, DB_VERSION); } private UserDBHelper(Context context, int version) { super(context, DB_NAME, null, version); } // 利用单例模式获取数据库帮助器的唯一实例,这里没有可说的 public static UserDBHelper getInstance(Context context, int version) { if (version > 0 && mHelper == null) { mHelper = new UserDBHelper(context, version); } else if (mHelper == null) { mHelper = new UserDBHelper(context); } return mHelper; } // 打开数据库的读连接 // 需要通过helper帮助器对象实例来得到sqlLiteDataBase对象,这个对象可以理解为preparestament代理执行sql对象,不过功能要多一些 public SQLiteDatabase openReadLink() { if (mDB == null || !mDB.isOpen()) { mDB = mHelper.getReadableDatabase(); } return mDB; } // 打开数据库的写连接 public SQLiteDatabase openWriteLink() { if (mDB == null || !mDB.isOpen()) { mDB = mHelper.getWritableDatabase(); } return mDB; } // 关闭数据库连接 public void closeLink() { if (mDB != null && mDB.isOpen()) { mDB.close(); mDB = null; } } // 创建数据库,执行建表语句 //首先通过help对象调用onCreate方法、注意要传入sqlLiteDB对象,用它来执行sql语句 public void onCreate(SQLiteDatabase db) { Log.d(TAG, "onCreate"); String drop_sql = "DROP TABLE IF EXISTS " + TABLE_NAME + ";"; Log.d(TAG, "drop_sql:" + drop_sql); db.execSQL(drop_sql); String create_sql = "CREATE TABLE IF NOT EXISTS " + TABLE_NAME + " (" + "name VARCHAR NOT NULL," + "age INTEGER NOT NULL," + "height INTEGER NOT NULL," + "weight FLOAT NOT NULL" + ");"; Log.d(TAG, "create_sql:" + create_sql); db.execSQL(create_sql); // 执行完整的SQL语句 } // 升级数据库,执行表结构变更语句 public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) { Log.d(TAG, "onUpgrade oldVersion=" + oldVersion + ", newVersion=" + newVersion); if (newVersion > 1) { //Android的ALTER命令不支持一次添加多列,只能分多次添加 String alter_sql = "ALTER TABLE " + TABLE_NAME + " ADD COLUMN " + "phone VARCHAR;"; Log.d(TAG, "alter_sql:" + alter_sql); db.execSQL(alter_sql); alter_sql = "ALTER TABLE " + TABLE_NAME + " ADD COLUMN " + "password VARCHAR;"; Log.d(TAG, "alter_sql:" + alter_sql); db.execSQL(alter_sql); // 执行完整的SQL语句 } } // 根据指定条件删除表记录 public int delete(String condition) { // 执行删除记录动作,该语句返回删除记录的数目 return mDB.delete(TABLE_NAME, condition, null); } // 删除该表的所有记录 public int deleteAll() { // 执行删除记录动作,该语句返回删除记录的数目 return mDB.delete(TABLE_NAME, "1=1", null); } // 往该表添加一条记录 public long insert(UserInfo info) { List<UserInfo> infoList = new ArrayList<UserInfo>(); infoList.add(info); return insert(infoList); } // 往该表添加多条记录 public long insert(List<UserInfo> infoList) { long result = -1; for (int i = 0; i < infoList.size(); i++) { UserInfo info = infoList.get(i); List<UserInfo> tempList = new ArrayList<UserInfo>(); // 如果存在同名记录,则更新记录 // 注意条件语句的等号后面要用单引号括起来 // if (info.name != null && info.name.length() > 0) { // String condition = String.format("name='%s'", info.name); // tempList = query(condition); // if (tempList.size() > 0) { // update(info, condition); // result = tempList.get(0).rowid; // continue; // } // } // // 如果存在同样的手机号码,则更新记录 // if (info.phone != null && info.phone.length() > 0) { // String condition = String.format("phone='%s'", info.phone); // tempList = query(condition); // if (tempList.size() > 0) { // update(info, condition); // result = tempList.get(0).rowid; // continue; // } // } // 不存在唯一性重复的记录,则插入新记录 ContentValues cv = new ContentValues(); cv.put("name", info.name); cv.put("age", info.age); cv.put("height", info.height); cv.put("weight", info.weight); // 执行插入记录动作,该语句返回插入记录的行号 result = mDB.insert(TABLE_NAME, "", cv); if (result == -1) { // 添加成功则返回行号,添加失败则返回-1 return result; } } return result; } // 根据条件更新指定的表记录 // public int update(UserInfo info, String condition) { // ContentValues cv = new ContentValues(); // cv.put("name", info.name); // cv.put("age", info.age); // cv.put("height", info.height); // cv.put("weight", info.weight); // cv.put("married", info.married); // cv.put("update_time", info.update_time); // cv.put("phone", info.phone); // cv.put("password", info.password); // // 执行更新记录动作,该语句返回更新的记录数量 // return mDB.update(TABLE_NAME, cv, condition, null); // } // public int update(UserInfo info) { // // 执行更新记录动作,该语句返回更新的记录数量 // return update(info, "rowid=" + info.rowid); // } // 根据指定条件查询记录,并返回结果数据列表 public List<UserInfo> query(String condition) { String sql = String.format("select name,age,height," + "weight " + "from %s where %s;", TABLE_NAME, condition); Log.d(TAG, "query sql: " + sql); List<UserInfo> infoList = new ArrayList<UserInfo>(); // 执行记录查询动作,该语句返回结果集的游标 Cursor cursor = mDB.rawQuery(sql, null); // 循环取出游标指向的每条记录 while (cursor.moveToNext()) { UserInfo info = new UserInfo(); info.name = cursor.getString(2); // 取出字符串 info.age = cursor.getInt(3); // 取出整型数 info.height = cursor.getInt(4); // 取出长整型数 info.weight = cursor.getInt(5); // 取出浮点数 //SQLite没有布尔型,用0表示false,用1表示true infoList.add(info); } cursor.close(); // 查询完毕,关闭数据库游标 return infoList; } // 根据手机号码查询指定记录 public UserInfo queryByPhone(String phone) { UserInfo info = null; List<UserInfo> infoList = query(String.format("phone='%s'", phone)); if (infoList.size() > 0) { // 存在该号码的登录信息 info = infoList.get(0); } return info; }