SQLite中不支持的sql語法

今天很自然的在寫Sql語句的時候用了Top,一開始沒發現問題,因為我從數據庫讀出的值正好是0,而我習慣變量定義的時候也都賦值0,可是到我不要0的時候我就發現問題了。后來才知道,可愛的小sqlite竟然有不支持的sql語法。

  看到某個論壇有個新手也發現了這個問題并發帖了,下面一牛人的回復是“top是哪家的關鍵詞?sqlite家沒有這詞的”,哈,原來top這詞是mssql里才有的~

  最后還想說,數據庫絕對是很重要的一塊。我的基礎語法很垃圾,過幾天認真記錄下。

  Google之下的結果:

1 TOP
  這是一個大家經常問到的問題,例如在SQLSERVER中可以使用如下語句來取得記錄集中的前十條記錄:
  SELECT TOP 10 * from [index] ORDER BY indexid DESC;
  但是這條SQL語句在SQLite中是無法執行的,應該改為:
  SELECT * from [index] ORDER BY indexid DESC limit 0,10;
  其中limit 0,10表示從第0條記錄開始,往后一共讀取10條

2 創建視圖(Create View)
  SQLite在創建多表視圖的時候有一個BUG,問題如下:
  CREATE VIEW watch_single AS SELECT DISTINCTwatch_item.[watchid],watch_item.[itemid] from watch_item;
  上面這條SQL語句執行后會顯示成功,但是實際上除了
  SELECT COUNT(*) from [watch_single ] WHERE watch_ single.watchid = 1;
  能執行之外是無法執行其他任何語句的。其原因在于建立視圖的時候指定了字段所在的表名,而SQLite并不能正確地識別它。所以上面的創建語句要改為:
  CREATE VIEW watch_single AS SELECT DISTINCT [watchid],[itemid] from watch_item;
  但是隨之而來的問題是如果是多表的視圖,且表間有重名字段的時候該怎么辦?

3 COUNT(DISTINCT column)
  SQLite在執行如下語句的時候會報錯:
    SELECT COUNT(DISTINCT watchid) from [watch_item] WHERE watch_item.watchid = 1;
    其原因是SQLite的所有內置函數都不支持DISTINCT限定,所以如果要統計不重復的記錄數的時候會出現一些麻煩。比較可行的做法是先建立一個不重復的記錄表的視圖,然后再對該視圖進行計數。

4 外連接
  雖然SQLite官方已經聲稱LEFT OUTER JOIN 已經實現,但還沒有 RIGHT OUTER JOIN 和 FULL OUTER JOIN。但是實際測試表明似乎并不能夠正常的工作。以下三條語句在執行的時候均會報錯:
  SELECT tags.[tagid] from [tags],[tag_rss] WHERE tags.[tagid] = tag_rss.[tagid](*);
  SELECT tags.[tagid] from [tags],[tag_rss] WHERE LEFT OUTER JOIN tag_rss.[tagid] = tags.[tagid];
  SELECT tags.[tagid] from [tags],[tag_rss] WHERE LEFT JOIN tag_rss.[tagid] = tags.[tagid];
  此外經過測試用+號代替*號也是不可行的。


超越C++原創文章,轉載請注明來源并保留原文鏈接

本文鏈接:http://www.beyondc.cn/sqlite-does-not-support-sql-syntax.html

轉載于:https://www.cnblogs.com/dongweiq/p/4040941.html

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

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

相關文章

Analyzer普通用戶登錄不了[從網絡訪問此計算機]

問題: 最近客戶諾奇反映說Analyzer普通用戶登錄不了,但是發現管理員又可以登錄,幾經周折發現原來是系統的本地安全策略設置了不讓遠程使用本地賬戶密碼登錄系統導致。解決方案: 修改本地安全策略的“從遠程訪問此計算機”中的用戶…

金蝶系統服務器要求,金蝶服務器安裝及其相關要求.doc

K/3WISE創新管理平臺 V12.2標準部署環境說明目錄1. 多語言部署規則21.1 客戶端多語言部署規則21.2 中間層多語言部署規則31.3 數據庫多語言部署規則31.4 人力資源、管理門戶、CRM多語言部署規則41.5 Citrix遠程接入多語言部署規則42. 多語言部署架構圖52.1 簡體中間層52.2 繁體…

源碼 移植_FreeModbus移植總結

modbus是一項工業上經常用到的通訊協議,而freemodbus是一款開源的從機協議棧。關于它的移植網上已經有了很多的文章,但是大多都只是針對其中部分問題的表述。本文將會把自己在移植freemodbus過程中遇到的問題以及freemodbus的源碼分析盡量表述清楚。&…

expect腳本的簡單應用

expect是一個用來處理交互的命令。借助于expect我們可以把交互過程寫在一個腳本上,使之自動化完成。expect最核心的四個命令:send:用于向進程發送字符串 except:從進程接收字符串 spawn:打開一個新的進程 interact:保持交互的狀態首先一個簡單…

ajax中datatype是json,dataType:'json'vs data:$ .ajax中的JSON.stringify(obj)

我有這個數據結構:var formValues {TemporaryToken: a.userStatus.get("TemporaryToken"),MemorableWordPositionAndValues:[{Position: a.userStatus.get("MemorableWordPositions")[0],Value: this.$([name"login-memorable-character-…

sqlserver 查詢中使用Union或Union All

在 程序人生網站上 看到了 這篇文章 就收藏了 哈 http://www.ourcodelife.com/article-415-1.html 首先,在程序人生網站上,需要負責任的指出的是在SQL Server查詢中使用Union或Union All后Order by排序無效,我不確認是不是微軟的bug&#xf…

word標題大綱級別_快速按標題層級把Word轉Excel—附詳細操作步驟

如何快速把層級分明的word文檔轉換成橫向從屬結構的excel表格一、問題描述文檔如下圖所示。文檔一共三個層次,大綱級別分別是1、2、3級,左則是其文檔結構圖,可以看出文檔層級分明。最終要將文檔轉換成如下橫向從屬結構的表格。一個層次的內容…

生成GUID唯一值的方法匯總(dotnet/javascript/sqlserver)

一、在 .NET 中生成1、直接用.NET Framework 提供的 Guid() 函數,此種方法使用非常廣泛。GUID(全局統一標識符)是指在一臺機器上生成的數字,它保證對在同一時空中的任何兩臺計算機都不會生成重復的 GUID 值(即保證所有…

Thread.CurrentPrincipal HttpContext.Current.User

據說要這樣寫才穩妥 // This principal will flow throughout the request.VoyagerPrincipal principal new VoyagerPrincipal(yada, yada, yada); // Attach the new principal object to the current HttpContext objectHttpContext.Current.User principal; // Make sure …

江森系統設置服務器日期,江森自控METASYS操作手冊

? Alarm? Trend顯示窗口中的按鈕編號 A B按鈕說明允許您編輯所示項目的屬性。選擇Save按鈕可保存修改。 顯示這個窗口中以前顯示過的內容。每個窗口最多可顯示5個歷史項目。顯示已保存的下一個窗口中的內容。鎖定選中的顯示窗口(防止被其他拖拽來的項目覆蓋)。您可調整被鎖定…

servlet中getWriter和getOutputStream的區別

getWriter();getOutputStream();區別:1、getWriter()用于向客戶機回送字符數據2、getOutputStream()返回的對象,可以回送字符數據,也可以回送字節數據(二進制數據)如何選擇:若果我們回送字符數據&#xff0…

execve系統調用_張凱捷—系統調用分析(3) (基于最新Linux5.0版本系統調用日志收集系統)...

在上一篇文章《系統調用分析(2)》中介紹和分析了32位和64位的快速系統調用指令——sysenter/sysexit和syscall/sysret,以及內核對快速系統調用部分的相關代碼,并追蹤了一個用戶態下的系統調用程序運行過程。本篇中將基于最新的Linux-5.0內核,…

批量下載小說網站上的小說(python爬蟲)

隨便說點什么 因為在學python,所有自然而然的就掉進了爬蟲這個坑里,好吧,主要是因為我覺得爬蟲比較酷,才入坑的。 想想看,你可以批量自動的采集互聯網上海量的資料數據,是多么令人激動啊! 所以我…

Playground

題意 :求被兩點分割的凸包面積的較小值 題意已經給出順時針啦 就是求以某一個點 和其他所有相鄰點組成三角形的面積,然后sum存和求兩點的時候就求出那兩點的之間所有三角形的和再減掉0點和那兩點的面積一減就是其中一個三角形的面積。轉載于:https://…

華為歐拉系統服務器開接口,華為操作系統 euleros

華為操作系統 euleros 內容精選換一換Atlas 900 AI集群安裝上架、服務器基礎參數配置、安裝操作系統等操作,請根據集群配置參見對應的手冊:《Atlas 900 PoD 用戶指南 (型號9000, 直流)》《Atlas 900 PoD 用戶指南 (型號9000, 交流)》《Atlas 900 計算節點…

對勾函數_對勾函數?2020福建省中考壓軸題分析

訓練營機密視頻大公開歡迎轉發、分享傳播知識,傳播力量!福建也是全省統一考選擇題:這題考的是二次函數的性質,先求出對稱軸就好了填空題:這題看似有反比例,確實會用到反比例函數的對稱性。但其實重點是考察…

這個textview有問題嗎 為什么一使用就崩潰

問題描述<TextViewandroid:id"id/textview1"android:layout_columnSpan"4"android:layout_gravity"fill"android:gravity"right"android:text"0" />public class MainActivity extends Activity {Button one;TextView…

通過Ajax解析和jQuery寫了一個小小的導航條

最近在用ajax和jquery做開發&#xff0c;所以閑來無事寫了些小導航條&#xff0c;通過ajax解析XML文件動態的創建WEB網站的導航條。 <link href"css/style.css" rel"stylesheet" type"text/css" /><script src"js/jquery-1.8.2.mi…

一次生產事故的優化經歷

在一次正常的活動促銷之后&#xff0c;客服開始陸續反饋有用戶反應在搶標的時候打不開網頁或者APP&#xff0c;在打開的時候標的就已經被搶光了&#xff0c;剛開始沒有特別的上心&#xff0c;覺得搶標不就是這樣嗎&#xff0c;搶小米手機的時候也不就這樣嗎&#xff1f;隨著活動…

mysql over rank_SQL學習筆記 - 窗口函數OVER

Window Function 窗口函數Perform calculations on an already generated result set ( a window).&#xff08;在已生成的結果集上執行計算&#xff09;Aggregate calculation(without having to group your data)&#xff08;允許使用聚合函數時不用進行GROUP BY分組&#xf…