Android SQLite (一) 數據庫簡介

大家好,今天來介紹一下SQLite的相關知識,并結合Java實現對SQLite數據庫的操作。

SQLite是D.Richard Hipp用C語言編寫的開源嵌入式數據庫引擎。它支持大多數的SQL92標準,并且可以在所有主要的操作系統上運行。

SQLite由以下幾個部分組成:SQL編譯器、內核、后端以及附件。SQLite通過利用虛擬機和虛擬數據庫引擎(VDBE),是調試、修改和擴 展SQLite的內核變得更加方便。所有SQL語句都被編譯成易讀的、可以在SQLite虛擬機中執行的程序集。SQLite的整體結構圖如下:


值得一提的是,袖珍型的SQLite竟然可以支持高達2TB大小的數據庫,每個數據庫都是以單個文件的形式存在,這些數據都是以B-Tree的數據結構形式存儲在磁盤上。

在事務處理方面,SQLite通過數據庫級上的獨占性和共享鎖來實現獨立事務處理。這意味著多個進程可以在同一時間從同一數據庫讀取數據,但只有一 個可以寫入數據。在某個進程或線程想數據庫執行寫操作之前,必須獲得獨占鎖。在獲得獨占鎖之后,其他的讀或寫操作將不會再發生。

SQLite采用動態數據類型,當某個值插入到數據庫時,SQLite將會檢查它的類型,如果該類型與關聯的列不匹配,SQLite則會嘗試將該值 轉換成該列的類型,如果不能轉換,則該值將作為本身的類型存儲,SQLite稱這為“弱類型”。但有一個特例,如果是INTEGER PRIMARY KEY,則其他類型不會被轉換,會報一個“datatype missmatch”的錯誤。

概括來講,SQLite支持NULL、INTEGER、REAL、TEXT和BLOB數據類型,分別代表空值、整型值、浮點值、字符串文本、二進制對象。

下面,我們就來親自操作一下SQLite數據庫。

在操作之前,朋友們要先下載SQLite數據庫,官方的下載頁面是http://sqlite.org/download.html, 我是在Windows下試驗,所以我選擇了Precompiled Binaries For Windows下面的sqlite-shell-win32-x86和sqlite-analyzer-win32-x86的zip包,前者是 SQLite數據庫引擎,后者是SQLite數據庫分析器,主要用于分析數據庫的狀態等信息,大家也可以根據自己的情況去下載。下載完成后分別解壓,得到 兩個可執行文件,如圖:


這兩個文件可以根據自己的喜好放置在指定的位置,我將其放在D盤根目錄下。下面我們就來一步一步操作SQLite:


創建數據庫:

[sql]?view plain?copy
  1. D:\>sqlite3?test.db??
  2. SQLite?version?3.7.7.1?2011-06-28?17:39:05??
  3. Enter?".help"?for?instructions??
  4. Enter?SQL?statements?terminated?with?a?";"??
  5. sqlite>?.databases??
  6. seq??name?????????????file??
  7. ??
  8. ---??---------------??----------------------------------------------------------??
  9. ??
  10. 0????main?????????????D:\test.db??
  11. ??
  12. sqlite>??

我 們執行了sqlite3命令,參數就是數據庫的名稱,如果該數據庫已存在,則使用,如果不存在,則新建一個,這里我們簡單的在當前位置創建了 test.db,你也可以在任何存在的并且可寫的目錄下創建自己的數據庫。(如果對于SQLite的命令不太熟悉,可以執行“.help”命令列出所有的 命令清單進行查看)。


創建表:

[sql]?view plain?copy
  1. sqlite>?CREATE?TABLE?person?(id?INTEGER?PRIMARY?KEY?AUTOINCREMENT,?name?VARCHAR(20),?age?SMALLINT);??
  2. sqlite>?.tables??
  3. person??
  4. sqlite>?.schema?person??
  5. CREATE?TABLE?person?(id?INTEGER?PRIMARY?KEY?AUTOINCREMENT,?name?VARCHAR(20),?age?SMALLINT);??
  6. sqlite>??

在我們創建表之后,可以用“.tables”命令去查看已有的表,用“.schema”命令去查看表的結構,如果后面沒有表名做參數,則將會輸出所有表的建表語句。


插入數據:

[sql]?view plain?copy
  1. sqlite>?INSERT?INTO?person?VALUES?(NULL,?'john',?30);??
  2. sqlite>?SELECT?*?FROM?person;??
  3. 1|john|30??


從.sql文件導入數據:

[sql]?view plain?copy
  1. sqlite>?.read?test.sql??
  2. sqlite>?SELECT?*?FROM?person;??
  3. 1|john|30??
  4. 2|david|35??
  5. 3|henry|40??
  6. sqlite>??


分析數據庫使用狀態:

[sql]?view plain?copy
  1. D:\>sqlite3_analyzer?test.db??
  2. /**?Disk-Space?Utilization?Report?For?test.db??
  3. ??
  4. Page?size?in?bytes....................?1024??
  5. Pages?in?the?whole?file?(measured)....?4??
  6. Pages?in?the?whole?file?(calculated)..?4??
  7. Pages?that?store?data.................?4??????????100.0%??
  8. Pages?on?the?freelist?(per?header)....?0????????????0.0%??
  9. Pages?on?the?freelist?(calculated)....?0????????????0.0%??
  10. Pages?of?auto-vacuum?overhead.........?0????????????0.0%??
  11. Number?of?tables?in?the?database......?4??
  12. Number?of?indices.....................?0??
  13. Number?of?named?indices...............?0??
  14. Automatically?generated?indices.......?0??
  15. Size?of?the?file?in?bytes.............?4096??
  16. Bytes?of?user?payload?stored..........?39???????????0.95%??
  17. ...??


備份數據庫:

備份 SQLite 數據庫有兩種方法。如果數據庫正在使用中,則應從命令行界面使用 .dump 命令。這樣可以創建一個包含必要命令和數據的文件,從而重新創建數據庫。.dump 命令也可以用于備份數據庫表。

[sql]?view plain?copy
  1. sqlite>?.dump??
  2. PRAGMA?foreign_keys=OFF;??
  3. BEGIN?TRANSACTION;??
  4. CREATE?TABLE?person?(id?INTEGER?PRIMARY?KEY?AUTOINCREMENT,?name?VARCHAR(20),?age?SMALLINT);??
  5. INSERT?INTO?"person"?VALUES(1,'john',30);??
  6. INSERT?INTO?"person"?VALUES(2,'david',35);??
  7. INSERT?INTO?"person"?VALUES(3,'henry',40);??
  8. DELETE?FROM?sqlite_sequence;??
  9. INSERT?INTO?"sqlite_sequence"?VALUES('person',3);??
  10. COMMIT;??
  11. sqlite>?.output?dump.sql??
  12. sqlite>?.dump??
  13. sqlite>??

我們可以指定輸出的目標為一個文件,然后再使用命令時,輸出信息就會寫入指定的文件,如果想恢復為標準輸出,可以這樣設定:

[sql]?view plain?copy
  1. sqlite>?.output?stdout??
  2. sqlite>?.dump??
  3. PRAGMA?foreign_keys=OFF;??
  4. BEGIN?TRANSACTION;??
  5. CREATE?TABLE?person?(id?INTEGER?PRIMARY?KEY?AUTOINCREMENT,?name?VARCHAR(20),?age?SMALLINT);??
  6. INSERT?INTO?"person"?VALUES(1,'john',30);??
  7. INSERT?INTO?"person"?VALUES(2,'david',35);??
  8. INSERT?INTO?"person"?VALUES(3,'henry',40);??
  9. DELETE?FROM?sqlite_sequence;??
  10. INSERT?INTO?"sqlite_sequence"?VALUES('person',3);??
  11. COMMIT;??
  12. sqlite>??

如果數據庫沒有處于使用狀態,則可以直接將數據庫文件復制到安全位置。

最后,我們可以使用“.quit”或“.exit”退出SQLite。


管理工具:

現在網絡上的SQLite管理工具很多,我向大家推薦一款好用的工具:SQLite Expert。



在Java中使用SQLite:

我們要想在Java中使用SQLite,需要下載SQLite相關驅動,推薦大家到http://www.xerial.org/trac/Xerial/wiki/SQLiteJDBC頁面去下載最新的驅動包,現在最新版本是sqlite-jdbc-3.7.2.jar,體積有點大,因為它包含了Linux、Mac、Windows的本地類庫,如圖:


下載了驅動之后,我們新建一個項目,名為sqlite:


在上圖中,我們引入sqlite驅動包到類路徑下,然后建立一個db的文件夾,用于放置數據庫文件。最后我們看一下Test.java代碼:

[java]?view plain?copy
  1. package?com.scott.sqlite;??
  2. import?java.sql.Connection;??
  3. import?java.sql.DriverManager;??
  4. import?java.sql.ResultSet;??
  5. import?java.sql.Statement;??
  6. ??
  7. public?class?Test?{??
  8. ????public?static?void?main(String[]?args)?throws?Exception?{??
  9. ????????Class.forName("org.sqlite.JDBC");??
  10. ????????Connection?conn?=?DriverManager.getConnection("jdbc:sqlite:db/test.db");??
  11. ????????Statement?stmt?=?conn.createStatement();??
  12. ??
  13. ????????stmt.executeUpdate("DROP?TABLE?IF?EXISTS?person");??
  14. ????????stmt.executeUpdate("CREATE?TABLE?person(id?INTEGER,?name?STRING)");??
  15. ????????stmt.executeUpdate("INSERT?INTO?person?VALUES(1,?'john')");??
  16. ????????stmt.executeUpdate("INSERT?INTO?person?VALUES(2,?'david')");??
  17. ????????stmt.executeUpdate("INSERT?INTO?person?VALUES(3,?'henry')");??
  18. ????????ResultSet?rs?=?stmt.executeQuery("SELECT?*?FROM?person");??
  19. ????????while?(rs.next())?{??
  20. ????????????System.out.println("id=>"?+?rs.getInt("id")?+?",?name=>"?+?rs.getString("name"));??
  21. ????????}??
  22. ????????stmt.close();??
  23. ????????conn.close();??
  24. ????}??
  25. }??

執行Test.java文件,結果如下:


這個時候,在我們的db目錄下,就生成了一個test.db的文件:



SQLite使用須知:

目前沒有可用于 SQLite 的網絡服務器。從應用程序運行位于其他計算機上的 SQLite 的惟一方法是從網絡共享運行。這樣會導致一些問題,像 UNIX? 和 Windows? 網絡共享都存在文件鎖定問題。還有由于與訪問網絡共享相關的延遲而帶來的性能下降問題。

SQLite 只提供數據庫級的鎖定。

SQLite 沒有用戶帳戶概念,而是根據文件系統確定所有數據庫的權限。


結束語:

由于資源占用少、性能良好和零管理成本,嵌入式數據庫有了它的用武之地,像Android、iPhone都有內置的SQLite數據庫供開發人員使用,它的易用性可以加快應用程序的開發,并使得復雜的數據存儲變得輕松了許多


? ? 本文轉自 一點點征服 ? 博客園博客,原文鏈接:http://www.cnblogs.com/ldq2016/p/5237684.html,如需轉載請自行聯系原作者




本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/286948.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/286948.shtml
英文地址,請注明出處:http://en.pswp.cn/news/286948.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

poj3685 二分套二分

F - 二分二分Crawling in process... Crawling failed Time Limit:6000MS Memory Limit:65536KB 64bit IO Format:%lld & %llu Submit StatusDescription Given a N N matrix A, whose element in the i-th row and j-th column Aij is an number that equals i2 …

租號顯示服務器爆滿怎么辦,租號器環境異常怎么解決

玩網絡游戲出現環境異常,怎么辦…網絡連接上但上不了網的原因以及相應的解決辦法。一、檢查是否密碼錯誤輸入連接密碼的時候,如果密碼比較長有可能會輸錯密碼,所以建議大家再輸入一次密碼。如果有可能,直接使用復制粘貼的方式輸入…

零基礎“復刻”經典飛機大戰小程序游戲【一篇文使用 IVX 輕松實戰5】

作者簡介 作者名:1_bit 簡介:CSDN博客專家,2020年博客之星TOP5,藍橋簽約作者。15-16年曾在網上直播,帶領一批程序小白走上程序員之路。歡迎各位小白加我咨詢我相關信息,迷茫的你會找到答案。 必看提示 項…

【無人機組裝與調試】第一章 概述

【無人機組裝與調試】系列課程全集: 第一章 概述 第二章 關于新西達30A電調說明書的問題 第三章 舵機安裝與調整 第四章 F450四軸裝機實例-選擇機型、需要的器材工具材料 第五章 無人機遙控器 第六章 電調、電池、電機 1.1 什么是無人機? 無人駕駛飛機是…

Flutter之Center

1、Center介紹 Center將子控件放在其內部中心,里面只能放一個child,但是child里面可以放Container Center繼承勒Align,然后Align默認是center. 2、測試代碼 測試1、 overrideWidget build(BuildContext context) {return MaterialApp(title…

【Cisco Packet Tracer】綜合實踐題-校園網仿真

本題的目的: 理論與實踐結合:Cisco Packet Tracer是一個網絡模擬軟件,通過模擬真實的網絡環境,可以讓學生在實際操作中加深對理論知識的理解和掌握。問題解決能力:綜合實驗題可以考察學生分析和解決問題的能力。在實驗…

C# =符號的使用

前言:-. 讀作 goes to,是C#3.0的新內容;-. 字段定義時設置{ get; set; }屬性的作用:主要是為了外部訪問的安全性封裝字段,get set你自己可以設置限制條件,尤其是wpf綁定時,沒有get set屬性&…

【無人機組裝與調試】第二章 關于新西達30A電調說明書的問題

【無人機組裝與調試】系列課程全集: 第一章 概述 第二章 關于新西達30A電調說明書的問題 第三章 舵機安裝與調整 第四章 F450四軸裝機實例-選擇機型、需要的器材工具材料 第五章 無人機遙控器 第六章 電調、電池、電機 極限使用:   持續電流30A,瞬間35A ,40A持續10秒。 外…

所有方向你要的資料干貨這都有,從入門到實戰!【CSDN寶藏資料圖鑒第一期】

前言 CSDN 是全球知名的開發者社區,創建于1999年,經過20來年的知識文檔積累已然成為中文開發者的知識寶庫;從基礎的法入門到蛻變實戰案例、從神秘前沿技術到清晰的實踐步驟,可以說CSDN是你找尋資料的最佳寶庫,只要你想…

Spark官方調優文檔翻譯(轉載)

Spark調優 由于大部分Spark計算都是在內存中完成的,所以Spark程序的瓶頸可能由集群中任意一種資源導致,如:CPU、網絡帶寬、或者內存等。最常見的情況是,數據能裝進內存,而瓶頸是網絡帶寬;當然,有…

《DOS命令全集(中英文對照)》CHM版.CHM

http://pan.baidu.com/s/1pLrhAzx轉載于:https://www.cnblogs.com/micro-chen/p/5692802.html

判斷一個字符串是否為另外一個字符串旋轉之后的字符串。

★判斷一個字符串是否為另外一個字符串旋轉之后的字符串。例如:給定s1 = AABCD和s2 BCDAA,返回1,給定s1abcd和s2ACBD,返回0.AABCD左旋一個字符得到ABCDA AABCD右旋一個字符得到DAABC AABCD左旋兩…

Flutter之Padding

1 、Padding介紹 Padding用來為子元素添加填充,也就是指定子元素與容器邊界的距離,作用基本上與Android中ViewGroup的padding屬性差不多 const Padding({Key key,required this.padding,Widget child,}) : assert(padding ! null),super(key: key, chil…

【無人機組裝與調試】第三章 舵機安裝與調整

【無人機組裝與調試】系列課程全集: 第一章 概述 第二章 關于新西達30A電調說明書的問題 第三章 舵機安裝與調整 第四章 F450四軸裝機實例-選擇機型、需要的器材工具材料 第五章 無人機遙控器 第六章 電調、電池、電機 舵機就是一種有輸出軸的小傳動裝置。這個輸出軸能夠通過向…

其實python面向對象3分鐘就可以入門(14)

本系列文章將會以通俗易懂的對話方式進行教學,對話中將涵蓋了新手在學習中的一般問題。此系列將會持續更新,包括別的語言以及實戰都將使用對話的方式進行教學,基礎編程語言教學適用于零基礎小白,之后實戰課程也將會逐步更新。 若…

定制ASP.NET 6.0的應用配置

大家好,我是張飛洪,感謝您的閱讀,我會不定期和你分享學習心得,希望我的文章能成為你成長路上的墊腳石,讓我們一起精進。本文的主題是應用程序配置。要介紹的是如何使用配置、如何自定義配置,以采用不同的方…

mysql optimization

EXPLAIN 命令詳解 http://www.cnblogs.com/gomysql/p/3720123.html http://www.cnblogs.com/Aiapple/p/5697229.html http://www.cnblogs.com/xuanzhi201111/p/4175635.html https://dev.mysql.com/doc/refman/5.7/en/optimization.html Mysql 執行計劃(Explain&…

云服務器cpu性能,云服務器cpu性能

云服務器cpu性能 內容精選換一換CPU積分是一種用來衡量云服務器計算、存儲以及網絡配置利用率的方式。云服務器利用CPU積分機制保證云服務器基準性能,解決超分云服務器長期占用CPU資源的問題。使用CPU積分機制的彈性云服務器適用于平時CPU負載不高、但突發時可接受因…

Flutter之Decoration

1、不廢話,先爆照看效果 2、Decoration介紹 Flutter的Decoration可以設置:背景色 背景圖 邊框 圓角 陰影 漸變色 的等屬性,有點像android里面的shape,Decoration 是基類,它的子類有下面這些 BoxDecoration:實現邊框、…

DRBD 部署

主備模式DRBD1:eth0:10.0.0.3eth1:172.16.1.3 用于心跳線和數據同步(在工作中,一般把心跳線分開)DRBD2:eth0:10.0.0.4eth1:172.16.1.4 用于心跳線和數據同步(在工作中,一…