android 本地数据库sqlite的封装
admin
2023-05-24 01:42:38
0

 单机android   sqlite数据库的实现,这个数据库可与程序一起生成在安装包中

一、下载sqlite3.exe文件

二、运行 cmd 转到sqlite3.exe 所在目录  运行 sqlite3.exe 数据库名.db

    然后会出现sqlite>的命令提示符

    输入创建表的语句, create table 表名(‘列’,‘列’。。。);(注意: 要在结束部分加  分号 )

    此时会在sqlite3.exe 所在目录,出现所建数据库的文件

三、如果想在Android中运行的话,需要在数据库中增添

 CREATE TABLE "android_metadata" ("locale" TEXT DEFAULT 'zh_CN')
INSERT INTO "android_metadata" VALUES ('zh_CN')

四、将数据库 复制到 Android项目中res/raw中

五、下面是代码:
123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123public class TestSqlDatabase{         private static final String DATABASE_PATH = "/data/data/your.package.name/databases";     //此处不要改动,这个为数据库在手机上的物理地址    private static final int DATABASE_VERSION = 0;    private static final String DATABASE_NAME = "test.db";  //此处为数据库名称         private static String outFileName = DATABASE_PATH + "/" + DATABASE_NAME;         private Context context;     private SQLiteDatabase database;         public TestSqlDatabase(Context context) {        this.context = context;                 File file = new File(outFileName);        if (file.exists()) {            database = SQLiteDatabase.openOrCreateDatabase(outFileName, null);            if (database.getVersion() != DATABASE_VERSION) {                database.close();                file.delete();             }        }        try {            buildDatabase();        } catch (Exception e) {            e.printStackTrace();        }             }    private void buildDatabase() throws Exception{        InputStream myInput = context.getResources().openRawResource(R.raw.test);        File file = new File(outFileName);                 File dir = new File(DATABASE_PATH);        if (!dir.exists()) {            if (!dir.mkdir()) {                throw new Exception("创建失败");            }        }                 if (!file.exists()) {                      try {                OutputStream myOutput = new FileOutputStream(outFileName);                                 byte[] buffer = new byte[1024];                int length;                while ((length = myInput.read(buffer))>0){                    myOutput.write(buffer, 0, length);                }                myOutput.close();                myInput.close();            } catch (Exception e) {                e.printStackTrace();            }                 }    } /** * 查找 * @return */public Cursor select() {     database = SQLiteDatabase.openOrCreateDatabase(outFileName, null);     String sql = "select * from note_table";              Cursor cursor = database.rawQuery(sql, null);     return cursor;}/** * 插入 * @param word * @param note * @return */public long insert(String word, String note) {      database = SQLiteDatabase.openOrCreateDatabase(outFileName, null);      ContentValues cv = new ContentValues();      cv.put("word", word);      cv.put("note", note);                   long result = database.insert("note_table", null, cv);         return result;}     /** * 更新 * @param word * @param note * @return     */    private int update(String word, String note) {                            //参数 word 为修改条件   note为修改内容        database = SQLiteDatabase.openOrCreateDatabase(outFileName, null);                 ContentValues cv = new ContentValues();        cv.put("note", note);                 int result = database.update("note_table", cv, "word=?", new String[]{word});                     return result;    }   /** * 删除 * @param word */public int deleteNote(String word) {      database = SQLiteDatabase.openOrCreateDatabase(outFileName, null);      int result = database.delete("note_table", "word=?", new String[]{word});      return result;}       public void close() {      database.close();}  }


相关内容

热门资讯

霍尔木兹海峡危机给叙利亚带来机... 澎湃新闻记者 南博一自2月28日美以伊战争爆发以来,霍尔木兹海峡的航运已中断近80天。然而,这却为正...
刚川金属取得紧固垫圈成型模具专... 国家知识产权局信息显示,重庆市刚川金属制品有限公司取得一项名为“一种紧固垫圈成型模具”的专利,授权公...
可孚医疗AI呼吸机C11第1万... 本报讯 (记者何文英)5月19日,可孚医疗科技股份有限公司(以下简称“可孚医疗”)在长沙智能制造基地...
第四届小程序全球创新挑战赛总决... 中新网广东新闻5月17日电 (记者 索有为)第四届小程序全球创新挑战赛总决赛暨大湾区AI科技节5月1...
村民讲述湖北宣恩洪灾:下了一天... 据央视新闻报道,5月17日至18日,湖北省恩施州宣恩县沙道沟镇白水河村上游普降大到暴雨,截至5月18...
中欧联合研制!“微笑”卫星,发... 今天(19日),中欧联合研制的太阳风-磁层相互作用全景成像卫星(简称“微笑”卫星,SMILE)在法属...
男子意外发现千问App可生成淫... 在千问AI软件输入相关词汇,居然能够生成不堪入目的淫秽小说,这让河北沧州的许先生感到匪夷所思,难道千...
泰国内阁决定取消60天免签政策 新华社曼谷5月19日电(记者常天童 林淑婷) 据泰国媒体19日报道,泰国内阁当天批准取消对90多个国...
从技术突破到价值落地 业界热议... 人民网北京5月19日电 (记者杜燕飞)当前,人工智能(AI)作为推动新一轮科技革命和产业变革的力量,...
消息称英特尔推动消费PC制造商... IT之家 5 月 19 日消息,《日经亚洲》今日报道称,Intel(英特尔)正要求其主要 PC 合作...