條件數(shù)據(jù)庫Android:sqllite的簡單使用
SQLite分析
SQLite是輕量級的、嵌入式的、關(guān)系型數(shù)據(jù)庫,現(xiàn)在已經(jīng)在iPhone、Android等手機(jī)系統(tǒng)中應(yīng)用,SQLite可移植性好,很輕易應(yīng)用,很小,高效而且牢靠。SQLite嵌入到應(yīng)用它的應(yīng)用程序中,它們共用雷同的進(jìn)程空間,而不是單獨(dú)的一個(gè)進(jìn)程。從外部看,它并不像一個(gè)RDBMS,但在進(jìn)程內(nèi)部,它倒是完整的,自包括的數(shù)據(jù)庫引擎。
在android中當(dāng)須要操作SQLite數(shù)據(jù)庫的時(shí)候須要失掉一個(gè)SQLiteOpenHelper對象,而SQLiteOpenHelper是一個(gè)抽象類,用戶須要繼承這個(gè)類,并實(shí)現(xiàn)該類中的一些方法。
1、繼承SQLiteOpenHelper之后就擁有了以下兩個(gè)方法:
◆getReadableDatabase() 創(chuàng)立或者打開一個(gè)查詢數(shù)據(jù)庫
◆getWritableDatabase()創(chuàng)立或者打開一個(gè)可寫數(shù)據(jù)庫
◆他們都市返回SQLiteDatabase對象,用戶通過失掉的SQLiteDatabase對象進(jìn)行后續(xù)操作
2、同時(shí)用戶還可以覆蓋以下回調(diào)函數(shù),再對數(shù)據(jù)庫進(jìn)行操作的時(shí)候回調(diào)以下方法:
◆onCreate(SQLiteDatabase):在數(shù)據(jù)庫第一次創(chuàng)立的時(shí)候會(huì)調(diào)用這個(gè)方法,一般我們在這個(gè)方法里邊創(chuàng)立數(shù)據(jù)庫表。
◆onUpgrade(SQLiteDatabase,int,int):當(dāng)數(shù)據(jù)庫須要修改的時(shí)候,Android系統(tǒng)會(huì)主動(dòng)的調(diào)用這個(gè)方法。一般我們在這個(gè)方法里邊刪除數(shù)據(jù)庫表,并建立新的數(shù)據(jù)庫表,當(dāng)然是否還須要做其他的操作,完整取決于應(yīng)用程序的需求。
◆onOpen(SQLiteDatabase):這是當(dāng)打開數(shù)據(jù)庫時(shí)的回調(diào)函數(shù),一般也不會(huì)用到。
須要注意
1、在SQLiteOepnHelper的子類當(dāng)中,必須有以下該構(gòu)造函數(shù)
public DatabaseHelper(Context context, String name, CursorFactory factory,
int version) {
//必須通過super調(diào)用父類當(dāng)中的構(gòu)造函數(shù)
super(context, name, factory, version);
} 為了便利,也可以創(chuàng)立其它的構(gòu)造函數(shù),含二個(gè)參數(shù)或者三個(gè)參數(shù)的。
2、函數(shù)public void onCreate(SQLiteDatabase db)是在調(diào)用getReadableDatabase()或者是getWritableDatabase()第一次創(chuàng)立數(shù)據(jù)庫的時(shí)候執(zhí)行,實(shí)際上是在第一次失掉SQLiteDatabse對象的時(shí)候,才會(huì)調(diào)用這個(gè)方法.
public void onCreate(SQLiteDatabase db) {
System.out.println("create a Database");
//execSQL函數(shù)用于執(zhí)行SQL語句
db.execSQL("create table user(id int,name varchar(20))");
}
上面是寫好的例子,可以參考下
public class DBHelper {
private static DatabaseHelper mDbHelper;
private static SQLiteDatabase mDb;
private static final String DATABASE_NAME = "life";
private static final int DATABASE_VERSION = 1;
private Context mCtx;
private static class DatabaseHelper extends SQLiteOpenHelper {
DatabaseHelper(Context context) {
super(context, DATABASE_NAME, null, DATABASE_VERSION);
}
@Override
public void onCreate(SQLiteDatabase db) {
//創(chuàng)立表結(jié)構(gòu)
db.execSQL("CREATE TABLE life_history (id INTEGER PRIMARY KEY AUTOINCREMENT,type TEXT, city TEXT, company TEXT, pucNum TEXT, pucName TEXT);");
}
@Override
public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
}
}
public DBHelper(Context ctx) throws SQLException {
this.mCtx = ctx;
mDbHelper = new DatabaseHelper(mCtx);
mDb = mDbHelper.getWritableDatabase();
}
/**
* 關(guān)閉數(shù)據(jù)源
*/
public void closeConnection() {
if (mDb != null && mDb.isOpen())
mDb.close();
if (mDbHelper != null)
mDbHelper.close();
}
/**
* 插入數(shù)據(jù) 參數(shù)
* @param tableName 表名
* @param initialValues 要插入的列對應(yīng)值
* @return
*/
public long insert(String tableName, ContentValues initialValues) {
return mDb.insert(tableName, null, initialValues);
}
/**
* 刪除數(shù)據(jù)
* @param tableName 表名
* @param deleteCondition 條件
* @param deleteArgs 條件對應(yīng)的值(如果deleteCondition中有“?”號,將用此數(shù)組中的值替換,一一對應(yīng))
* @return
*/
public boolean delete(String tableName, String deleteCondition, String[] deleteArgs) {
return mDb.delete(tableName, deleteCondition, deleteArgs) > 0;
}
/**
* 更新數(shù)據(jù)
* @param tableName 表名
* @param initialValues 要更新的列
* @param selection 更新的條件
* @param selectArgs 更新條件中的“?”對應(yīng)的值
* @return
*/
public boolean update(String tableName, ContentValues initialValues, String selection, String[] selectArgs) {
return mDb.update(tableName, initialValues, selection, selectArgs) > 0;
}
/**
* 取得一個(gè)列表
* @param distinct 是否去重復(fù)
* @param tableName 表名
* @param columns 要返回的列
* @param selection 條件
* @param selectionArgs 條件中“?”的參數(shù)值
* @param groupBy 分組
* @param having 分組過濾條件
* @param orderBy 排序
* @return
*/
public Cursor findList(boolean distinct, String tableName, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit) {
return mDb.query(distinct, tableName, columns, selection, selectionArgs, groupBy, having, orderBy, limit);
}
/**
* 取得單行記錄
* @param tableName 表名
* @param columns 獲取的列數(shù)組
* @param selection 條件
* @param selectionArgs 條件中“?”對應(yīng)的值
* @param groupBy 分組
* @param having 分組條件
* @param orderBy 排序
* @param limit 數(shù)據(jù)區(qū)間
* @param distinct 是否去重復(fù)
* @return
* @throws SQLException
*/
public Cursor findOne(boolean distinct, String tableName, String[] columns, String selection, String[] selectionArgs, String groupBy, String having, String orderBy, String limit) throws SQLException {
Cursor mCursor = findList(distinct, tableName, columns, selection, selectionArgs, groupBy, having, orderBy, limit);
if (mCursor != null) {
mCursor.moveToFirst();
}
return mCursor;
}
/**
* 執(zhí)行SQL(帶參數(shù))
* @param sql
* @param args SQL中“?”參數(shù)值
*/
public void execSQL(String sql, Object[] args) {
mDb.execSQL(sql, args);
}
/**
* 執(zhí)行SQL
* @param sql
*/
public void execSQL(String sql) {
mDb.execSQL(sql);
}
/**
* 判斷某張表是否存在
* @param tabName 表名
* @return
*/
public boolean isTableExist(String tableName) {
boolean result = false;
if (tableName == null) {
return false;
}
try {
Cursor cursor = null;
String sql = "select count(1) as c from sqlite_master where type ='table' and name ='" + tableName.trim() + "'";
cursor = mDb.rawQuery(sql, null);
if (cursor.moveToNext()) {
int count = cursor.getInt(0);
if (count > 0) {
result = true;
}
}
cursor.close();
}
catch (Exception e) {
}
return result;
}
/**
* 判斷某張表中是否存在某字段(注,該方法無法判斷表是否存在,因此應(yīng)與isTableExist一起應(yīng)用)
* @param tabName 表名
* @param columnName 列名
* @return
*/
public boolean isColumnExist(String tableName, String columnName) {
boolean result = false;
if (tableName == null) {
return false;
}
try {
Cursor cursor = null;
String sql = "select count(1) as c from sqlite_master where type ='table' and name ='" + tableName.trim() + "' and sql like '%" + columnName.trim() + "%'";
cursor = mDb.rawQuery(sql, null);
if (cursor.moveToNext()) {
int count = cursor.getInt(0);
if (count > 0) {
result = true;
}
}
cursor.close();
}
catch (Exception e) {
}
return result;
}
}
- Android SQLite數(shù)據(jù)庫增刪改查操作的使用詳解
- Android使用SQLite數(shù)據(jù)庫的簡單實(shí)例
- android將圖片轉(zhuǎn)換存到數(shù)據(jù)庫再從數(shù)據(jù)庫讀取轉(zhuǎn)換成圖片實(shí)現(xiàn)代碼
- android創(chuàng)建數(shù)據(jù)庫(SQLite)保存圖片示例
- Android 用adb pull或push 拷貝手機(jī)文件到到電腦上,拷貝手機(jī)數(shù)據(jù)庫到電腦上,拷貝電腦數(shù)據(jù)庫到手機(jī)上
- Android中的SQL查詢語句LIKE綁定參數(shù)問題解決辦法(sqlite數(shù)據(jù)庫)
- Android學(xué)習(xí)筆記-保存數(shù)據(jù)到SQL數(shù)據(jù)庫中(Saving Data in SQL Databases)
- android實(shí)現(xiàn)raw文件夾導(dǎo)入數(shù)據(jù)庫代碼
- Android中操作SQLite數(shù)據(jù)庫快速入門教程
- Android數(shù)據(jù)庫操作工具類分享
相關(guān)文章
Android實(shí)現(xiàn)多段顏色進(jìn)度條效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)多段顏色進(jìn)度條效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01Android Flutter實(shí)現(xiàn)興趣標(biāo)簽選擇功能
我們在首次使用內(nèi)容類 App 的時(shí)候,不少都會(huì)讓我們選擇個(gè)人偏好,通過這些標(biāo)簽選擇可以預(yù)先知道用戶的偏好信息。我們本篇就來看看 Flutter 如何實(shí)現(xiàn)興趣標(biāo)簽的選擇,需要的可以參考一下2022-11-11Android實(shí)現(xiàn)圖片設(shè)置圓角形式
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)圖片設(shè)置圓角形式,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-11-11Android自定義View實(shí)現(xiàn)加載進(jìn)度條效果
這篇文章主要為大家詳細(xì)介紹了Android自定義View實(shí)現(xiàn)加載進(jìn)度條效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-05-05Android實(shí)現(xiàn)百分比下載進(jìn)度條效果
這篇文章主要為大家詳細(xì)介紹了Android實(shí)現(xiàn)百分比下載進(jìn)度條效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-12-12