亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > Android > 正文

條件數據庫Android:sqllite的簡單使用

2020-04-11 12:24:14
字體:
來源:轉載
供稿:網友

    SQLite分析

    SQLite是輕量級的、嵌入式的、關系型數據庫,現在已經在iPhone、Android等手機系統中應用,SQLite可移植性好,很輕易應用,很小,高效而且牢靠。SQLite嵌入到應用它的應用程序中,它們共用雷同的進程空間,而不是單獨的一個進程。從外部看,它并不像一個RDBMS,但在進程內部,它倒是完整的,自包括的數據庫引擎。

    在android中當須要操作SQLite數據庫的時候須要失掉一個SQLiteOpenHelper對象,而SQLiteOpenHelper是一個抽象類,用戶須要繼承這個類,并實現該類中的一些方法。

   

    1、繼承SQLiteOpenHelper之后就擁有了以下兩個方法:

    ◆getReadableDatabase() 創立或者打開一個查詢數據庫

    ◆getWritableDatabase()創立或者打開一個可寫數據庫

    ◆他們都市返回SQLiteDatabase對象,用戶通過失掉的SQLiteDatabase對象進行后續操作

    2、同時用戶還可以覆蓋以下回調函數,再對數據庫進行操作的時候回調以下方法:

    ◆onCreate(SQLiteDatabase):在數據庫第一次創立的時候會調用這個方法,一般我們在這個方法里邊創立數據庫表。

    ◆onUpgrade(SQLiteDatabase,int,int):當數據庫須要修改的時候,Android系統會主動的調用這個方法。一般我們在這個方法里邊刪除數據庫表,并建立新的數據庫表,當然是否還須要做其他的操作,完整取決于應用程序的需求。

    ◆onOpen(SQLiteDatabase):這是當打開數據庫時的回調函數,一般也不會用到。

    須要注意

    1、在SQLiteOepnHelper的子類當中,必須有以下該構造函數

復制代碼 代碼如下:

public DatabaseHelper(Context context, String name, CursorFactory factory, 
   int version) { 
  //必須通過super調用父類當中的構造函數 
  super(context, name, factory, version); 
}    為了便利,也可以創立其它的構造函數,含二個參數或者三個參數的。

    2、函數public void onCreate(SQLiteDatabase db)是在調用getReadableDatabase()或者是getWritableDatabase()第一次創立數據庫的時候執行,實際上是在第一次失掉SQLiteDatabse對象的時候,才會調用這個方法.

public void onCreate(SQLiteDatabase db) { 
  System.out.println("create a Database"); 
  //execSQL函數用于執行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) {
            //創立表結構
            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();
    }

    /**
     * 關閉數據源
     */
    public void closeConnection() {
        if (mDb != null && mDb.isOpen())
            mDb.close();
        if (mDbHelper != null)
            mDbHelper.close();
    }

    /**
     * 插入數據 參數
     * @param tableName 表名
     * @param initialValues 要插入的列對應值
     * @return
     */
    public long insert(String tableName, ContentValues initialValues) {

        return mDb.insert(tableName, null, initialValues);
    }

    /**
     * 刪除數據
     * @param tableName 表名
     * @param deleteCondition 條件
     * @param deleteArgs 條件對應的值(如果deleteCondition中有“?”號,將用此數組中的值替換,一一對應)
     * @return
     */
    public boolean delete(String tableName, String deleteCondition, String[] deleteArgs) {

        return mDb.delete(tableName, deleteCondition, deleteArgs) > 0;
    }

    /**
     * 更新數據
     * @param tableName 表名
     * @param initialValues 要更新的列
     * @param selection 更新的條件
     * @param selectArgs 更新條件中的“?”對應的值
     * @return
     */
    public boolean update(String tableName, ContentValues initialValues, String selection, String[] selectArgs) {
        return mDb.update(tableName, initialValues, selection, selectArgs) > 0;
    }

    /**
     * 取得一個列表
     * @param distinct 是否去重復
     * @param tableName 表名
     * @param columns 要返回的列
     * @param selection 條件
     * @param selectionArgs 條件中“?”的參數值
     * @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 獲取的列數組
     * @param selection 條件
     * @param selectionArgs 條件中“?”對應的值
     * @param groupBy 分組
     * @param having 分組條件
     * @param orderBy 排序
     * @param limit 數據區間
     * @param distinct 是否去重復
     * @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;

    }

    /**
     * 執行SQL(帶參數)
     * @param sql
     * @param args SQL中“?”參數值
     */
    public void execSQL(String sql, Object[] args) {
        mDb.execSQL(sql, args);

    }

    /**
     * 執行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;
    }

    /**
     * 判斷某張表中是否存在某字段(注,該方法無法判斷表是否存在,因此應與isTableExist一起應用)
     * @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;
    }

}
 

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲深夜福利在线| 久久中文字幕一区| 91伊人影院在线播放| 亚洲视频在线观看视频| 精品亚洲国产成av人片传媒| 日本老师69xxx| 亚洲午夜国产成人av电影男同| 日本精品久久电影| 日韩免费不卡av| 最近2019中文字幕一页二页| 精品国产乱码久久久久久婷婷| 成人福利在线观看| 欧美与欧洲交xxxx免费观看| 欧美激情视频在线免费观看 欧美视频免费一| 国产精品久久久久久久久久久久| 国产精品久久久久久久久久久久| 欧美裸体视频网站| 色老头一区二区三区在线观看| 日本午夜人人精品| 亚洲日本欧美日韩高观看| 欧美中文字幕精品| 亚洲午夜精品久久久久久久久久久久| 国产精品电影一区| 亚洲欧美日韩一区二区在线| 亚洲理论电影网| 欧日韩在线观看| 亚洲韩国欧洲国产日产av| 欧洲永久精品大片ww免费漫画| 伊人久久五月天| 欧美大码xxxx| 欧美激情中文字幕乱码免费| 免费99精品国产自在在线| 亚洲天堂成人在线视频| 美女黄色丝袜一区| 97视频在线看| 国产精品99久久久久久白浆小说| 久久99热这里只有精品国产| 福利二区91精品bt7086| 亚洲欧美999| 国产丝袜一区二区三区| 亚洲乱码av中文一区二区| 国产精品综合不卡av| 亚洲欧美日韩中文在线| 岛国av一区二区在线在线观看| 欧美激情精品久久久久久蜜臀| 亚洲一区二区少妇| 久久久亚洲国产| 亚洲女人天堂色在线7777| 日韩在线免费视频观看| 国产成人一区二区三区小说| www.久久色.com| 国内精品模特av私拍在线观看| 亚洲国产美女久久久久| 日韩av在线电影网| 亚洲天堂成人在线视频| 91夜夜揉人人捏人人添红杏| 少妇激情综合网| 一区二区三区四区在线观看视频| 国产精品久久久久久久7电影| 久久久国产一区| 亚洲老司机av| 午夜精品一区二区三区在线播放| 欧美精品videosex牲欧美| 国产丝袜一区二区三区| 成人有码在线视频| 97精品久久久中文字幕免费| 成人妇女免费播放久久久| 欧美成人精品在线| 91九色国产在线| 亚洲性夜色噜噜噜7777| 亚洲综合在线小说| 国产日韩欧美影视| 国产小视频国产精品| 国内精品久久久久| 精品国产一区久久久| 福利一区视频在线观看| 国产精品久久久一区| 777午夜精品福利在线观看| 亚洲精品日韩激情在线电影| 欧美日韩福利视频| 日韩精品在线观| 亚洲美女性生活视频| 91av在线精品| 在线成人激情黄色| 欧美性猛交xxxx免费看漫画| 国产亚洲激情视频在线| 国产精品视频在线播放| 国产日韩欧美日韩大片| 欧美激情在线有限公司| 欧美一级在线亚洲天堂| 国产欧美精品xxxx另类| 97精品伊人久久久大香线蕉| 国产成人高潮免费观看精品| 日韩中文在线中文网在线观看| 久久在线精品视频| 91免费国产视频| 欧美最近摘花xxxx摘花| 亚洲热线99精品视频| 亚洲 日韩 国产第一| 精品露脸国产偷人在视频| 欧美做受高潮电影o| 日本久久中文字幕| 久久免费少妇高潮久久精品99| 91精品国产综合久久香蕉922| 欧美综合第一页| 久99久在线视频| xxxxx成人.com| 亚洲嫩模很污视频| 欧美日韩国产中文字幕| 国产美女久久精品| 亚洲成人精品视频在线观看| 国产精品成人免费视频| 伊人一区二区三区久久精品| 亚洲欧洲在线视频| 久久精品视频一| 亚洲经典中文字幕| 日韩精品在线免费| 91色在线视频| 日韩av123| 成人午夜激情免费视频| 一本一本久久a久久精品牛牛影视| 有码中文亚洲精品| 亚洲天堂免费在线| 91色中文字幕| 成人欧美一区二区三区在线湿哒哒| 久久资源免费视频| 日韩美女毛茸茸| 国产精品大陆在线观看| 永久免费精品影视网站| 精品国产福利在线| 日韩色av导航| 91精品久久久久久久久久久久久久| 午夜精品国产精品大乳美女| 91麻豆国产语对白在线观看| 亚洲色图第一页| 久久天天躁狠狠躁老女人| 国内自拍欧美激情| 91成品人片a无限观看| 日韩欧美一区二区三区| 亚洲天堂免费在线| 亚洲专区在线视频| 欧美夜福利tv在线| 日韩欧美成人网| 日韩av在线网址| 亚洲性视频网站| 亚洲国产精品成人一区二区| 亚洲国产另类 国产精品国产免费| 亚洲天堂成人在线| 欧美国产在线电影| 欧美日韩在线视频首页| 狠狠色狠色综合曰曰| 久久久久久国产精品三级玉女聊斋| 亚洲电影免费观看高清完整版在线| 久久网福利资源网站| 国产精品私拍pans大尺度在线| 欧美性高潮在线| 欧美在线视频观看免费网站| 一区二区三区视频免费在线观看| 国产精品成人v| 亚洲丁香久久久| 久久激情视频免费观看| 一本一本久久a久久精品牛牛影视| 秋霞av国产精品一区| 国产精品免费一区豆花|