日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
Android SQLite3命令詳解教程

sqlite3可以讓我們手動的對SQLite數(shù)據(jù)庫進(jìn)行管理。一共有2個sqlite3,一個在電腦上,它位于 Android-sdk-windows\tools\sqlite3.exe,用于電腦上SQLite數(shù)據(jù)庫進(jìn)行管理;還有一個位于Android系統(tǒng)上(手機(jī)上),它用于位于Android系統(tǒng)上的SQLite數(shù)據(jù)庫進(jìn)行管理,對于后者你需要通過adb shell進(jìn)入shell。有時我們不想直接在Android系統(tǒng)上對SQLite數(shù)據(jù)庫進(jìn)行操作,這時可以把它拷貝到電腦上進(jìn)行操作。

創(chuàng)新互聯(lián)致力于網(wǎng)站建設(shè),網(wǎng)站制作設(shè)計,營銷網(wǎng)頁按需求定制設(shè)計,成都外貿(mào)網(wǎng)站制作,企業(yè)網(wǎng)站建設(shè),微信平臺小程序開發(fā),網(wǎng)站SEO優(yōu)化,網(wǎng)站設(shè)計制作案例豐富,是成都做網(wǎng)站公司和建站公司,歡迎咨詢。

但是需要注意前者是Windows系統(tǒng),后者是Linux系統(tǒng),他們表示路徑的方式不一樣。

在SQLite3命令后可跟一個參數(shù)指定要打開或創(chuàng)建的數(shù)據(jù)庫文件。如果指定的數(shù)據(jù)庫文件還不存在,就會新建一個數(shù)據(jù)庫,且以該參數(shù)作為文件名。對于Android系統(tǒng)上的SQLite3,必須通過其shell來運行,如果新建數(shù)據(jù)庫的話,需要root權(quán)限,可以在shell中鍵入"su"來獲得root權(quán)限。

如果是Android系統(tǒng)的sqlite3程序(通過shell運行),你可以Ctrl鍵+D ,然后回車退出該程序回到shell,也可以Ctrl鍵+C直接退出Shell,如果是電腦上的SQLite3,可以Ctrl鍵+C直接退出SQLite3程序。

下面就是一個創(chuàng)建包含一個名叫"tbl1"的表的名叫"ex1"的SQLite數(shù)據(jù)庫的示例。

示例1:

java代碼:

 
 
  1. $ sqlite3 ex1 
  2. SQLite version 3.3.10 
  3. Enter ".help" for instructions 
  4. sqlite> create table tbl1(one varchar(10), two smallint); 
  5. sqlite> insert into tbl1 values('hello!',10); 
  6. sqlite> insert into tbl1 values('goodbye', 20); 
  7. sqlite> select * from tbl1; 
  8. hello!|10 
  9. goodbye|20 
  10. sqlite> 

SQLite3支持兩種命令,一種是SQL命令,一種是非SQL命令,非SQL命令以"."作為前綴,比如".tables"命令。

可以通過".help"命令來查看它所有的非SQL命令.所有不以"."為前綴的語句,都將做SQL進(jìn)行解釋,當(dāng)時對于SQL語句你需要在末尾加上分號";"以表示SQL語句輸入完成,這時你輸入的命令才開始按照SQL語言進(jìn)行執(zhí)行。

示例2:

java代碼:

 
 
  1. sqlite> CREATE TABLE tbl2 ( 
  2. ...> f1 varchar(30) primary key, 
  3. ...> f2 text, 
  4. ...> f3 real 
  5. ...> ); 
  6. sqlite> 

關(guān)于數(shù)據(jù)庫的schema是存放在一個叫sqlite_master的表中,你雖然不能對它進(jìn)行DROP TABLE, UPDATE, INSERT or DELETE操作,但是可以像普通的表一樣對它進(jìn)行查詢。

示例3:

java代碼:

 
 
  1. sqlite3 /data/data/com.android.providers.settings/databases/settings.db 
  2. SQLite version 3.6.22 
  3. Enter ".help" for instructions 
  4. Enter SQL statements terminated with a ";" 
  5. sqlite> .tables 
  6. .tables 
  7. android_metadata bookmarks system 
  8. bluetooth_devices secure 
  9. sqlite> select * from sqlite_master; 
  10. select * from sqlite_master; 
  11. table|android_metadata|android_metadata|3|CREATE TABLE android_metadata (locale TEXT) 
  12. table|system|system|4|CREATE TABLE system (_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT UNIQUE ON CONFLICT REPLACE,value TEXT) 
  13. index|sqlite_autoindex_system_1|system|5| 
  14. table|sqlite_sequence|sqlite_sequence|6|CREATE TABLE sqlite_sequence(name,seq) 
  15. index|systemIndex1|system|7|CREATE INDEX systemIndex1 ON system (name) 
  16. table|secure|secure|8|CREATE TABLE secure (_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT UNIQUE ON CONFLICT REPLACE,value TEXT) 
  17. index|sqlite_autoindex_secure_1|secure|9| 
  18. index|secureIndex1|secure|10|CREATE INDEX secureIndex1 ON secure (name) 
  19. table|bluetooth_devices|bluetooth_devices|11|CREATE TABLE bluetooth_devices (_id INTEGER PRIMARY KEY,name TEXT,addr TEXT,channel INTEGER,type INTEGER) 
  20. table|bookmarks|bookmarks|12|CREATE TABLE bookmarks (_id INTEGER PRIMARY KEY,tit 
  21. le TEXT,folder TEXT,intent TEXT,shortcut INTEGER,ordering INTEGER) 
  22. index|bookmarksIndex1|bookmarks|13|CREATE INDEX bookmarksIndex1 ON bookmarks (folder) 
  23. index|bookmarksIndex2|bookmarks|14|CREATE INDEX bookmarksIndex2 ON bookmarks (shortcut) 
  24. sqlite> 

#p#

在sqlite3中我們可以通過".help"命令來查所有的非SQL命令。

sqlite3 8種不同的方式顯示查詢返回的結(jié)果:"csv", "column", "html", "insert", "line", "list","tabs", "tcl".

你可以通過.mode來設(shè)置顯示的方式。默認(rèn)的是"list"方式,這時返回結(jié)果的一條記錄顯示一行,每列的內(nèi)容之間用設(shè)定的分隔符隔開,

默認(rèn)的分隔符是"|".

示例5:

java代碼:

 
 
  1. sqlite> .mode list 
  2. sqlite> select * from tbl1; 
  3. hello|10 
  4. goodbye|20 
  5. sqlite> 

你可以通過".separator"來設(shè)置"list"模式下的分隔符。比如我們想把", "作為分隔符,可以這樣:

示例6:

java代碼:

 
 
  1. sqlite> .separator ", " 
  2. sqlite> select * from tbl1; 
  3. hello, 10 
  4. goodbye, 20 
  5. sqlite> 

"line"模式下, 每行只顯示數(shù)據(jù)庫的一行的一列。每行由列名,等號和列的值組成。每條記錄之間由一個空行隔開。

示例7

java代碼:

 
 
  1. sqlite> .mode line 
  2. sqlite> select * from tbl1; 
  3. one = hello 
  4. two = 10 
  5. one = goodbye 
  6. two = 20 
  7. sqlite> 

"column"模式下,每條記錄都在單獨一行顯示。***行顯示的是列名,第二行只是用于分割列名和記錄的數(shù)據(jù),第三行開始才是記錄的內(nèi)容。

示例8:

java代碼:

 
 
  1. sqlite> .mode columnsqlite> select * from tbl1; 
  2. one two 
  3. ---------- ---------- 
  4. hello 10 
  5. goodbye 20 
  6. sqlite> 

默認(rèn)情況下,每列的寬度最多只能顯示10個字符。所以如果數(shù)據(jù)包含的字符如果他太多,可能就顯示不完。

但是我們可以通過".width"設(shè)置每列的寬度。

示例9:

java代碼:

 
 
  1. sqlite> .width 12 6 
  2. sqlite> select * from tbl1; 
  3. one two 
  4. ------------ ------ 
  5. hello 10 
  6. goodbye 20 
  7. sqlite> 

示例9就把第1列和第二列的寬度分別設(shè)置為了12和6個字符,其他列的寬度并沒改變。

如果你把列寬設(shè)置為0,那么調(diào)整為以下三個的***值:10,該列的列名字符數(shù),***行記錄該列的字符數(shù)。這樣列的寬度就可以自動調(diào)整。

默認(rèn)的列寬就是0,以便它可以自動調(diào)整。

可以通過".header"命令可以設(shè)置是否顯示頭(頭包括***行,列名,第二行,分隔行)。

示例10:

java代碼:

 
 
  1. sqlite> .header off 
  2. sqlite> select * from tbl1; 
  3. hello 10 
  4. goodbye 20 
  5. sqlite> 

"insert"模式下,返回的查詢結(jié)果將以SQL的INSERT語句形式進(jìn)行顯示。

示例11:

java代碼:

 
 
  1. sqlite> .mode insert new_table 
  2. sqlite> select * from tbl1; 
  3. INSERT INTO 'new_table' VALUES('hello',10); 
  4. INSERT INTO 'new_table' VALUES('goodbye',20); 
  5. sqlite> 

"html"模式下,查詢返回結(jié)果將以XHTML table的形式進(jìn)行顯示,它并不以

作為開頭和
作為結(jié)尾。 但是每條記錄以作為開始,作為結(jié)束,記錄的數(shù)據(jù)以作為開始,以作為結(jié)束

示例12:

java代碼:

 
 
  1. sqlite> select * from system; 
  2. select * from system; 
  3. volume_music 
  4.  
  5. volume_voice 
  6.  
  7. sqlite> 

".output"命令可以把查詢返回結(jié)果的輸出定向到文件上。該命令的***個參數(shù)即是要定向的位置。在把輸出定向了文件后,可以通過".output stdout"把輸出重新定向到標(biāo)準(zhǔn)輸出上。

示例13:

java代碼:

 
 
  1. sqlite> .mode list 
  2. sqlite> .separator | 
  3. sqlite> .output test_file_1.txt 
  4. sqlite> select * from tbl1; 
  5. sqlite> .exit 
  6. $ cat test_file_1.txt 
  7. hello|10 
  8. goodbye|20 

#p#

sqlite3提供了多個命令來查看數(shù)據(jù)庫的schema".tables"命令可以查看當(dāng)前數(shù)據(jù)庫所有的表

示例14:

java代碼:

 
 
  1. sqlite> .tables 
  2. tbl1 
  3. tbl2 
  4. sqlite> 

".tables"和在list模式下執(zhí)行下面的語句相似:

 SELECT name FROM sqlite_master WHERE type IN ('table','view') AND name NOT LIKE 'sqlite_%' UNION ALL SELECT name FROM sqlite_temp_master WHERE type IN ('table','view') ORDER BY 1

實際上, 如果你查看sqlite3程序的源碼 (found in the source tree in the file src/shell.c), you'll find exactly the above query.

另外,".tables"命令后也可以跟一參數(shù),它是一個pattern,這樣命令就只列出表名和該參數(shù)匹配的表。

示例14-1:

java代碼:

 
 
  1. sqlite> .tables 
  2. .tables 
  3. android_metadata bookmarks system 
  4. bluetooth_devices secure 
  5. sqlite> .tables s% 
  6. .tables s% 
  7. secure sqlite_sequence system 
  8. sqlite> 

".indices"命令列出指定表的所有indices(索引)。***個參數(shù)為表的名字。

示例15:

java代碼:

 
 
  1. sqlite> .schema system 
  2. .schema system 
  3. CREATE TABLE system (_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT UNIQUE ON C 
  4. ONFLICT REPLACE,value TEXT); 
  5. CREATE INDEX systemIndex1 ON system (name); 
  6. sqlite> .tables 
  7. .tables 
  8. android_metadata bookmarks system 
  9. bluetooth_devices secure 
  10. sqlite> .indices system 
  11. .indices system 
  12. sqlite_autoindex_system_1 
  13. systemIndex1 
  14. sqlite> 

".schema"命令,在沒有參數(shù)的情況,它會顯示最初用于創(chuàng)建數(shù)據(jù)庫的CREATE TABLE和CREATE INDEX的SQL語句。比如,示例16

".schema"命令可以包含一個參數(shù),它是一個pattern,用于對表進(jìn)行過濾,這時只會顯示滿足條件的表和所有索引的SQL語句。

比如,示例15和示例17.

示例16:

java代碼:

 
 
  1. sqlite> .schema 
  2. .schema 
  3. CREATE TABLE android_metadata (locale TEXT); 
  4. CREATE TABLE bluetooth_devices (_id INTEGER PRIMARY KEY,name TEXT,addr TEXT,chan 
  5. nel INTEGER,type INTEGER); 
  6. CREATE TABLE bookmarks (_id INTEGER PRIMARY KEY,title TEXT,folder TEXT,intent TE 
  7. XT,shortcut INTEGER,ordering INTEGER); 
  8. CREATE TABLE secure (_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT UNIQUE ON C 
  9. ONFLICT REPLACE,value TEXT); 
  10. CREATE TABLE system (_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT UNIQUE ON C 
  11. ONFLICT REPLACE,value TEXT); 
  12. CREATE INDEX bookmarksIndex1 ON bookmarks (folder); 
  13. CREATE INDEX bookmarksIndex2 ON bookmarks (shortcut); 
  14. CREATE INDEX secureIndex1 ON secure (name); 
  15. CREATE INDEX systemIndex1 ON system (name); 
  16. sqlite> 

示例17:

java代碼:

 
 
  1. sqlite> .schema s% 
  2. .schema s% 
  3. CREATE TABLE secure (_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT UNIQUE ON C 
  4. ONFLICT REPLACE,value TEXT); 
  5. CREATE TABLE sqlite_sequence(name,seq); 
  6. CREATE TABLE system (_id INTEGER PRIMARY KEY AUTOINCREMENT,name TEXT UNIQUE ON C 
  7. ONFLICT REPLACE,value TEXT); 
  8. CREATE INDEX secureIndex1 ON secure (name); 
  9. CREATE INDEX systemIndex1 ON system (name); 
  10. sqlite> 

文章題目:Android SQLite3命令詳解教程
標(biāo)題網(wǎng)址:http://m.5511xx.com/article/dpechjd.html