Android数据库高手秘籍(一)——SQLite命令
要想熟練地操作任何一個數據庫,最最基本的要求就是要懂SQL語言,這也是每個程序員都應該掌握的技能。雖說SQL博大精深,要想精通確實很難,但最基本的一些建表命令,增刪改查,大家還是必須要學會的。
SQL(Structured Query Language)是一種標準的數據庫查詢語言,即所有的關系型數據庫都會支持它,只不過每種數據庫對SQL語言的支持與標準存在著細微的不同。我們無須關心其它數據庫對SQL語言的支持情況,這里我們只要把重點放在SQLite上就可以了。 下面我將使用模擬器來對SQLite支持的各種命令進行演示,如果你想用手機的話也可以,但要確保你的手機已經Root,并且包含sqlite3這個命令文件。
首先確保模擬器已經連接上了電腦,然后在命令行輸入adb shell進入控制臺,如下圖所示:
 
注意#符號表示我們當前已經是超級用戶了,如果顯示的是$符號,表示當前只是普通用戶而已,這時還需要輸入su命令切換一下用戶身份才行。
有了超級用戶權限之后,我們能做的事情就很多了,這里我們先查看一下系統自帶的聯系人表吧。進入到/data/data目錄下,如下圖所示:
 
 
 
OK,確實有很多,畢竟手機上所有的應用程序都在這里。其中,com.android.providers.contacts中存放的就是聯系人的相關數據,我們進入到這個目錄再ls一下:
 
 
可以看到,目前有databases、files、lib和shared_prefs這幾個子目錄。其中databases肯定是用于存放數據庫文件的,files是用于存放普通文本文件的,lib是用于存放so庫的,shared_prefs則是用于存放shared文件的。這是Android數據持久化的幾種可選方式,對這部分內容不太了解的朋友可以參考《第一行代碼——Android》的第六章。
接著進入到databases目錄中,再ls:
其中后綴名為journal的文件是日志文件,我們不用管,contacts2.db和profile.db才是真正的數據庫文件,可以使用sqlite3命令來打開數據庫,如下圖所示:
 
 
好的,數據庫已經打開了,那么我們怎么才能知道當前數據庫中有哪些表呢?很簡單,.table命令就可以做到了:
 
 
哇,竟然有這么多張表!是的,聯系人的數據結構非常復雜,很多的數據都是分表存儲的。這里我們隨便挑一張表,比如說accounts表,如果我想知道這張表中有哪些列應該怎么辦呢?在MySQL中可以使用desc?accounts這個命令,但SQLite卻不認識這個命令,畢竟它們是有差異化的。SQLite中可以使用pragma table_info(TABLE_NAME)這個命令來查看表的數據結構,如下圖所示:
 
 
可以看到,一共顯示了三條結果,表示accounts表中共有三列。但是,所有的字段都縮在了一行里面,并用“|”符號分隔,這樣我們很難看出每個字段的含義。很簡單,只需要換一種顯示模式就行了,比如說line模式就挺不錯的。輸入.mode line命令切換顯示模式,然后重新運行pragma命令,結果如下圖所示:
 
怎么樣,這樣就清晰多了吧?這三列的列名分別是account_name、account_type和data_set,數據類型都是TEXT(字符串),允許為空,并且都不是主鍵。好,那我現在想查一查accounts表中的數據呢?這就太簡單了,使用select語句就可以了,如下所示:
 
 
恩?怎么只有一條空數據啊。貌似模擬器上默認就是這樣的,如果你用的是手機的話,這里應該就可以查到真正的數據了。不過沒關系,我們可以在設置里面手動添加一個郵箱賬戶,如下圖所示:
 
 
現在再來重新查詢一遍accounts表,如下所示:
 
 
OK,添加的新賬戶已經成功查出來了。
除了查詢命令之外,還有其它的增刪改命令都和標準的SQL語法是相同的,即insert、delete和update,由于比較簡單,我就不再贅述了。比較值得一提的是,每個SQLite數據庫中都還有一個隱藏的sqlite_master表,這里記載了當前數據庫中所有表的建表語句,可以使用select * from sqlite_master命令進行查看:
結果太多了是不是?一屏根本就顯示不下嘛。不要著急,別忘了我們使用的是select命令,可以使用where語句來過濾出我們想要查詢的那部分內容,如下圖所示:
 
 
OK,CREATE TABLE accounts (account_name TEXT, account_type TEXT, data_set TEXT) 這就是accounts表的建表語句了,通過這種方式我們可以查詢到任意一張表的建表語句,從而對我們學習和分析數據庫表結構有所幫助。
有些朋友可能會覺得,每次都要輸入select命令來查詢表中的數據太麻煩了。沒錯,而且還要保證手機是連接在電腦上的時候才能查詢,確實太不方便。幸運的是,有些手機軟件已經提供了數據庫表查詢的功能,使得我們隨時隨地都可以方便地查看數據庫中的數據,比如Root Explorer這款軟件就不錯。
仍然是確保你的手機已經Root,然后安裝Root Explorer,打開軟件之后按照我們前面介紹的路徑,進入/data/data/com.android.providers.contacts/databases,點擊contacts2.db數據庫,選擇內置數據庫查看器,然后隨便點擊一張表就可以查看到里面的數據了,如下圖所示:
使用這種方法,我們可以隨時查看數據庫表中的最新數據,直觀又方便,在程序開發的時候可以起到非常大的幫助。
好了,今天的講解就到這里,下篇文章當中我將帶領大家探究Android數據庫中更多的奧秘。
總結
以上是生活随笔為你收集整理的Android数据库高手秘籍(一)——SQLite命令的全部內容,希望文章能夠幫你解決所遇到的問題。
 
                            
                        - 上一篇: 关于Android SDK工具Lint的
- 下一篇: JFreeChart 使用介绍
