久久机这里只有精品,国产69精品一区二区亚洲孕妇,91精品国产综合久久婷婷香蕉,午夜久久久久久电影

最新活動:電腦PC端+手機端+微網(wǎng)站+自適應網(wǎng)頁多模板選擇-建站388元起價!!!
當前位置:主頁 > 網(wǎng)站建設(shè) > 解析SQLite中的常見問題與總結(jié)詳解建站知識

解析SQLite中的常見問題與總結(jié)詳解建站知識

時間:2023-05-23 22:05:23 閱讀: 文章分類: 網(wǎng)站建設(shè) 作者: 網(wǎng)站技術(shù)員

導讀:1建站知識1、 創(chuàng)建數(shù)據(jù) 如果不往數(shù)據(jù)庫里面添加任何的表,這個數(shù)據(jù)庫等于沒有建立,不會在硬盤上產(chǎn)生任何文件,如果數(shù)據(jù)庫已經(jīng)存在,則會打開這個數(shù)據(jù)庫。 2、 如何通過sql網(wǎng)站seo優(yōu)化培訓建設(shè)網(wǎng)站公司。

網(wǎng)站seo優(yōu)化培訓建設(shè)網(wǎng)站公司1、 創(chuàng)建數(shù)據(jù) 如果不往數(shù)據(jù)庫里面添加任何的表,這個數(shù)據(jù)庫等于沒有建立,不會在硬盤上產(chǎn)生任何文件,如果數(shù)據(jù)庫已經(jīng)存在,則會打開這個數(shù)據(jù)庫。    2、 如何通過sqlite3.dll與sqlite3.def生成sqlite3.lib文件 LIB /DEF:sqlite3.def /machine:IX86   3、 sqlite3_open打開一個數(shù)據(jù)庫時,如果數(shù)據(jù)庫不存在就會新生成一個數(shù)據(jù)庫文件。如果接著執(zhí)行其他查詢語句就會失敗,比如sqlite3_prepare,編程中出現(xiàn)明明指定了數(shù)據(jù)庫而且里面也有數(shù)據(jù),為什么查詢失敗了,主要是數(shù)據(jù)庫名路徑不對引起的。一般的做法是先檢查數(shù)據(jù)庫文件是否存在,如果存在就使用sqlite3_open打開數(shù)據(jù)庫;否則創(chuàng)建一個新的數(shù)據(jù)庫。   4、 如何建立自動增長字段 聲明為INTEGER PRIMARY KEY的列將會自動增長。   5、SQLite3支持何種數(shù)據(jù)類型? NULL INTEGER REAL TEXT BLOB 但實際上,sqlite3也接受如下的數(shù)據(jù)類型: smallint 16位元的整數(shù)。 interger 32位元的整數(shù)。 decimal(p,s) p精確值和s大小的十進位整數(shù),精確值p是指全部有幾個數(shù)(digits)大小值,s是指小數(shù)點後有幾位數(shù)。如果沒有特別指定,則系統(tǒng)會設(shè)為p=5; s=0。 float 32位元的實數(shù)。 double 64位元的實數(shù)。 char(n) n長度的字串,n不能超過254。 varchar(n)長度不固定且其最大長度為n的字串,n不能超過4000。 graphic(n)和char(n)一樣,不過其單位是兩個字元double-bytes,n不能超過127。這個形態(tài)是為了支援兩個字元長度的字體,例如中文字。 vargraphic(n)可變長度且其最大長度為n的雙字元字串,n不能超過2000。 date包含了年份、月份、日期。 time包含了小時、分鐘、秒。 timestamp包含了年、月、日、時、分、秒、千分之一秒。   6、SQLite允許向一個integer型字段中插入字符串 這是一個特性,而不是一個bug。SQLite不強制數(shù)據(jù)類型約束。任何數(shù)據(jù)都可以插入任何列。你可以向一個整型列中插入任意長度的字符串,向布爾型列中插入浮點數(shù),或者向字符型列中插入日期型值。在CREATE TABLE中所指定的數(shù)據(jù)類型不會限制在該列中插入任何數(shù)據(jù)。任何列均可接受任意長度的字符串(只有一種情況除外:標志為INTEGER PRIMARY KEY的列只能存儲64位整數(shù),當向這種列中插數(shù)據(jù)除整數(shù)以外的數(shù)據(jù)時,將會產(chǎn)生錯誤。   但SQLite確實使用聲明的列類型來指示你所期望的格式。所以,例如你向一個整型列中插入字符串時,SQLite會試圖將該字符串轉(zhuǎn)換成一個整數(shù)。如果可以轉(zhuǎn)換,它將插入該整數(shù);否則,將插入字符串。這種特性有時被稱為類型或列親和性(type or column affinity).   7、為什么SQLite不允許在同一個表不同的兩行上使用0和0.0作主鍵? 主鍵必須是數(shù)值類型,將主鍵改為TEXT型將不起作用。 每一行必須有一個唯一的主鍵。對于一個數(shù)值型列,SQLite認為'0'和'0.0'是相同的,因為他們在作為整數(shù)比較時是相等的(參見上一問題)。所以,這樣值就不唯一了。   8、多個應用程序或一個應用程序的多個實例可以同時訪問同一個數(shù)據(jù)庫文件嗎?   多個進程可同時打開同一個數(shù)據(jù)庫。多個進程可以同時進行SELECT操作,但在任一時刻,只能有一個進程對數(shù)據(jù)庫進行更改。   SQLite使用讀、寫鎖控制對數(shù)據(jù)庫的訪問。(在Win95/98/ME等不支持讀、寫鎖的系統(tǒng)下,使用一個概率性的模擬來代替。)但使用時要注意:如果數(shù)據(jù)庫文件存放于一個NFS文件系統(tǒng)上,這種鎖機制可能不能正常工作。這是因為fcntl()文件鎖在很多NFS上沒有正確的實現(xiàn)。在可能有多個進程同時訪問數(shù)據(jù)庫的時候,應該避免將數(shù)據(jù)庫文件放到NFS上。在Windows上,Mi網(wǎng)站建設(shè)哪家好crosoft的文檔中說:如果使用FAT文件系統(tǒng)seo網(wǎng)站關(guān)鍵詞優(yōu)化而沒有運行share.exe守護進程,那么鎖可能是不能正常使用的。那些在Windows上有很多經(jīng)驗的人告訴我:對于網(wǎng)絡(luò)文件,文件鎖的實現(xiàn)有好多Bug,是靠不住的。如果他們說的是對的,那么在兩臺或多臺Windows機器間共享數(shù)據(jù)庫可能會引起不期望的問題。   我們意識到,沒有其它嵌入式的SQL數(shù)據(jù)庫引擎能象SQLite這樣處理如此多的并發(fā)。SQLite允許多個進程同時打開一個數(shù)據(jù)庫,同時讀一個數(shù)據(jù)庫。當有任何進程想要寫時,它必須在更新過程中鎖住數(shù)據(jù)庫文件。但那通常只是幾毫秒的時間。其它進程只需等待寫進程干完活結(jié)束。典型地,其它嵌入式的SQL數(shù)據(jù)庫引擎同時只允許一個進程連接到數(shù)據(jù)庫。   但是,Client/Server數(shù)據(jù)庫引擎(如PostgreSQL, MySQL,或Oracle)通常支持更高級別的并發(fā),并且允許多個進程同時寫同一個數(shù)據(jù)庫。這種機制在Client/Server結(jié)構(gòu)的數(shù)據(jù)庫上是可能的,因為總是有一個單一的服務(wù)器進程很好地控制、協(xié)調(diào)對數(shù)據(jù)庫的訪問。如果你的應用程序需要很多的并發(fā),那么你應該考慮使用一個Client/Server結(jié)構(gòu)的數(shù)據(jù)庫。但經(jīng)驗表明,很多應用程序需要的并發(fā),往往比其設(shè)計者所想象的少得多。   當SQLite試圖訪問一個被其它進程鎖住的文件時,缺省的行為是返回SQLITE_BUSY。可以在C代碼中使用sqlite3_busy_handler()或sqlite3_busy_timeout() API函數(shù)調(diào)整這一行為。   9、SQLite線程安全嗎? 線程是魔鬼(Threads are evil)。避免使用它們。 SQLite是線程安全的。由于很多用戶會忽略我們在上一段中給出的建議,我們做出了這種讓步。但是,為了達到線程安全,SQLite在編譯時必須將SQLITE_THREADSAFE預處理宏置網(wǎng)seo優(yōu)化趨勢為1。在Windows和Linux上,已編譯的好的二進制發(fā)行版中都是這樣設(shè)置的。如果不確定你所使用的庫是否是線程安全的,可以調(diào)用sqlite3_threadsafe()接口找出。   10、在SQLite數(shù)據(jù)庫中如何列出所有的表和索引? 如果你運行sqlite3命令行來訪問你的數(shù)據(jù)庫,可以鍵入“.tables”來獲得所有表的列表。或者,你可以輸入“.schema”來看整個數(shù)據(jù)庫模式,包括所有的表的索引。輸入這些命令,后面跟一個LIKE模式匹配可以限制顯示的表。   11、SQLite數(shù)據(jù)庫有已知的大小限制嗎? 在Windows和Unix下,版本2.7.4的SQLite可以達到2的41次方字節(jié)(2T字節(jié))。老版本的為2的31次方字節(jié)(2G字節(jié))。 SQLite版本2.8限制一個記錄的容量為1M。SQLite版本3.0則對單個記錄容量沒有限制。 表名、索引表名、視圖名、觸發(fā)器名和字段名沒有長度限制。但SQL函數(shù)的名稱(由sqlite3_create_function() API函數(shù)創(chuàng)建)不得超過255個字符。   12、在SQLite中,VARCHAR字段最長是多少? SQLite不強制VARCHAR的長度。你可以在SQLITE中聲明一個VARCHAR(10),SQLite還是可以很高興地允許你放入500個字符。并且這500個字符是原封不動的,它永遠不會被截斷。   13、在SQLite中,如何在一個表上添加或刪除一列? SQLite有有限地ALTER TABLE支持。你可以使用它來在表的末尾增加一列,可更改表的名稱。如果需要對表結(jié)構(gòu)做更復雜的改變,則必須重新建表。重建時可以先將已存在的數(shù)據(jù)放到一個臨時表中,刪除原表,創(chuàng)建新表,然后將數(shù)據(jù)從臨時表中復制回來。   如,假設(shè)有一個t1表,其中有"a", "b", "c"三列,如果要刪除列c,以下過程描述如何做:   BEGIN TRANSACTION; CREATE TEMPORARY TABLE t1_backup(a,b); INSERT INTO t1_backup SELECT a,b FROM t1; DROP TABLE t1; CREATE TABLE t1(a,b); INSERT INTO t1 SELECT a,b FROM t1_backup; DROP TABLE t1_backup; COMMIT; 14、在SQLite中支持分頁嗎?   SQLite分頁是世界上最簡單的。如果我要去11-20的Account表的數(shù)據(jù)Select * From Account Limit 9 Offset 10; 以上語句表示從Account表獲取數(shù)據(jù),跳過10行,取9行。這個特性足夠讓很多的web中型網(wǎng)站使用這個了。也可以這樣寫 select * from account limit10,9和上面的的效果一樣。這種寫法MySQL也支持。  相關(guān)網(wǎng)站seo優(yōu)化培訓建設(shè)網(wǎng)站公司。

關(guān)鍵詞標簽: 詳解 SQL 常見問題

聲明: 本文由我的SEOUC技術(shù)文章主頁發(fā)布于:2023-05-23 ,文章解析SQLite中的常見問題與總結(jié)詳解建站知識主要講述常見問題,詳解,SQL網(wǎng)站建設(shè)源碼以及服務(wù)器配置搭建相關(guān)技術(shù)文章。轉(zhuǎn)載請保留鏈接: http://www.bifwcx.com/article/web_6109.html

我的IDC 網(wǎng)站建設(shè)技術(shù)SEOUC.COM
專注網(wǎng)站建設(shè),SEO優(yōu)化,小程序設(shè)計制作搭建開發(fā)定制網(wǎng)站等,數(shù)千家網(wǎng)站定制開發(fā)案例,網(wǎng)站推廣技術(shù)服務(wù)。
  • 5000+合作客服
  • 8年從業(yè)經(jīng)驗
  • 150+覆蓋行業(yè)
  • 最新熱門源碼技術(shù)文章

    主站蜘蛛池模板: 阳江市| 皮山县| 万源市| 苏尼特右旗| 中西区| 镇宁| 廊坊市| 九台市| 屏南县| 闵行区| 丰顺县| 临清市| 健康| 渝北区| 饶平县| 武强县| 武冈市| 和林格尔县| 长宁区| 普宁市| 广河县| 成都市| 鲜城| 化德县| 龙海市| 南澳县| 客服| 临漳县| 新干县| 泗水县| 阳信县| 民权县| 林甸县| 东山县| 无极县| 洪洞县| 曲松县| 百色市| 康平县| 永顺县| 丰县|