Heim Datenbank MySQL-Tutorial 【数据库】SQLite与SQL差异问题汇总

【数据库】SQLite与SQL差异问题汇总

Jun 07, 2016 pm 03:10 PM
sql sqlite 差异 数据库 汇总 问题

编者注:这些关于SQLite与SQL差异的问题,你是否遇到过呢?笔者在这里为大家总结出了使用SQLite时,与SQL之间经常会出现的一些差异性问题,希望对大家的使用有所帮助。 一、常见问题汇总 1 TOP 这是一个大家经常问到的问题,例如在SQLSERVER中可以使用如下语

编者注:这些关于SQLite与SQL差异的问题,你是否遇到过呢?笔者在这里为大家总结出了使用SQLite时,与SQL之间经常会出现的一些差异性问题,希望对大家的使用有所帮助。

一、常见问题汇总

1 TOP

这是一个大家经常问到的问题,例如在SQLSERVER中可以使用如下语句来取得记录集中的前十条记录:

<ol><li><span><span>SELECT</span><span> </span><span>TOP</span><span> 10 * </span><span>FROM</span><span> [</span><span>index</span><span>] </span><span>ORDER</span><span> </span><span>BY</span><span> indexid </span><span>DESC</span><span>; </span></span></li></ol>
Nach dem Login kopieren

但是这条SQL语句在SQLite中是无法执行的,应该改为:

<ol><li><span><span>SELECT</span><span> * </span><span>FROM</span><span> [</span><span>index</span><span>] </span><span>ORDER</span><span> </span><span>BY</span><span> indexid </span><span>DESC</span><span> limit 0,10; </span></span></li></ol>
Nach dem Login kopieren

其中limit 0,10表示从第0条记录开始,往后一共读取10条

2 创建视图(Create View)

SQLite在创建多表视图的时候有一个BUG,问题如下:

<ol><li><span><span>CREATE</span><span> </span><span>VIEW</span><span> watch_single </span><span>AS</span><span> </span><span>SELECT</span><span> DISTINCTwatch_item.[watchid],watch_item.[itemid] </span><span>FROM</span><span> watch_item; </span></span></li></ol>
Nach dem Login kopieren

上面这条SQL语句执行后会显示成功,但是实际上除了

<ol><li><span><span>SELECT</span><span> </span><span>COUNT</span><span>(*) </span><span>FROM</span><span> [watch_single ] </span><span>WHERE</span><span> watch_ single.watchid = 1; </span></span></li></ol>
Nach dem Login kopieren

能执行之外是无法执行其他任何语句的。其原因在于建立视图的时候指定了字段所在的表名,而SQLite并不能正确地识别它。所以上面的创建语句要改为:

<ol><li><span><span>CREATE</span><span> </span><span>VIEW</span><span> watch_single </span><span>AS</span><span> </span><span>SELECT</span><span> </span><span>DISTINCT</span><span> [watchid],[itemid] </span><span>FROM</span><span> watch_item; </span></span></li></ol>
Nach dem Login kopieren

但是随之而来的问题是如果是多表的视图,且表间有重名字段的时候该怎么办?

3 COUNT(DISTINCT column)

SQLite在执行如下语句的时候会报错:

<ol><li><span><span>SELECT</span><span> </span><span>COUNT</span><span>(</span><span>DISTINCT</span><span> watchid) </span><span>FROM</span><span> [watch_item] </span><span>WHERE</span><span> watch_item.watchid = 1; </span></span></li></ol>
Nach dem Login kopieren

其原因是SQLite的所有内置函数都不支持DISTINCT限定,所以如果要统计不重复的记录数的时候会出现一些麻烦。比较可行的做法是先建立一个不重复的记录表的视图,然后再对该视图进行计数。

4 外连接

虽然SQLite官方已经声称LEFT OUTER JOIN 已经实现,但还没有 RIGHT OUTER JOIN 和 FULL OUTER JOIN。但是实际测试表明似乎并不能够正常的工作。以下三条语句在执行的时候均会报错:

<ol>
<li><span><span>SELECT</span><span> tags.[tagid] </span><span>FROM</span><span> [tags],[tag_rss] </span><span>WHERE</span><span> tags.[tagid] = tag_rss.[tagid](*);  </span></span></li>
<li>
<span>SELECT</span><span> tags.[tagid] </span><span>FROM</span><span> [tags],[tag_rss] </span><span>WHERE</span><span> </span><span>LEFT</span><span> </span><span>OUTER</span><span> </span><span>JOIN</span><span> tag_rss.[tagid] = tags.[tagid];  </span>
</li>
<li>
<span>SELECT</span><span> tags.[tagid] </span><span>FROM</span><span> [tags],[tag_rss] </span><span>WHERE</span><span> </span><span>LEFT</span><span> </span><span>JOIN</span><span> tag_rss.[tagid] = tags.[tagid]; </span>
</li>
</ol>
Nach dem Login kopieren

此外经过测试用+号代替*号也是不可行的。

二、收集SQLite与Sql Server的语法差异

1.返回最后插入的标识值

返回最后插入的标识值sql server用@@IDENTITY

sqlite用标量函数LAST_INSERT_ROWID()

返回通过当前的 SQLConnection 插入到数据库的最后一行的行标识符(生成的主键)。此值与 SQLConnection.lastInsertRowID 属性返回的值相同。

2.top n

在sql server中返回前2行可以这样:

<ol>
<li><span><span>select</span><span> </span><span>top</span><span> 2 * </span><span>from</span><span> aa   </span></span></li>
<li>
<span>order</span><span> </span><span>by</span><span> ids </span><span>desc</span><span> </span>
</li>
</ol>
Nach dem Login kopieren

sqlite中用LIMIT,语句如下:

<ol>
<li><span><span>select</span><span> * </span><span>from</span><span> aa   </span></span></li>
<li>
<span>order</span><span> </span><span>by</span><span> ids </span><span>desc</span><span>   </span>
</li>
<li><span>LIMIT 2 </span></li>
</ol>
Nach dem Login kopieren

3.GETDATE ( )

在sql server中GETDATE ( )返回当前系统日期和时间

sqlite中没有

4.EXISTS语句

sql server中判断插入(不存在ids=5的就插入)

<ol>
<li><span><span>IF </span><span>NOT</span><span> EXISTS (</span><span>select</span><span> * </span><span>from</span><span> aa </span><span>where</span><span> ids=5)   </span></span></li>
<li>
<span>BEGIN</span><span>   </span>
</li>
<li>
<span>insert</span><span> </span><span>into</span><span> aa(nickname)   </span>
</li>
<li>
<span>select</span><span> </span><span>'t'</span><span>   </span>
</li>
<li>
<span>END</span><span>   </span>
</li>
</ol>
Nach dem Login kopieren

在sqlite中可以这样

<ol>
<li><span><span>insert</span><span> </span><span>into</span><span> aa(nickname)   </span></span></li>
<li>
<span>select</span><span> </span><span>'t'</span><span>   </span>
</li>
<li>
<span>where</span><span> </span><span>not</span><span> exists(</span><span>select</span><span> * </span><span>from</span><span> aa </span><span>where</span><span> ids=5) </span>
</li>
</ol>
Nach dem Login kopieren

5.嵌套事务

sqlite仅允许单个活动的事务

6.RIGHT 和 FULL OUTER JOIN

sqlite不支持 RIGHT OUTER JOIN 或 FULL OUTER JOIN

7.可更新的视图

sqlite视图是只读的。不能对视图执行 DELETE、INSERT 或 UPDATE 语句,sql server是可以对视图 DELETE、INSERT 或 UPDATE

三、新增内容

1.关于日期时间类型列的默认设置:

对"列"的设置包括三个字段:Name、Type、Default

Name:logTime(随意命名);

Type:

Date类型,得到的值形如"2011-04-23",

DATETIME类型,得到的值形如"2011-04-23 11:49:04.000";

Default:datetime('now','localtime')  我采用的是两个参数,后面的localtime不要丢弃,不然时间不准确。

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Java-Tutorial
1663
14
PHP-Tutorial
1263
29
C#-Tutorial
1236
24
iOS 18 fügt eine neue Albumfunktion „Wiederhergestellt' hinzu, um verlorene oder beschädigte Fotos wiederherzustellen iOS 18 fügt eine neue Albumfunktion „Wiederhergestellt' hinzu, um verlorene oder beschädigte Fotos wiederherzustellen Jul 18, 2024 am 05:48 AM

Apples neueste Versionen der iOS18-, iPadOS18- und macOS Sequoia-Systeme haben der Fotoanwendung eine wichtige Funktion hinzugefügt, die Benutzern dabei helfen soll, aus verschiedenen Gründen verlorene oder beschädigte Fotos und Videos einfach wiederherzustellen. Mit der neuen Funktion wird im Abschnitt „Extras“ der Fotos-App ein Album mit dem Namen „Wiederhergestellt“ eingeführt, das automatisch angezeigt wird, wenn ein Benutzer Bilder oder Videos auf seinem Gerät hat, die nicht Teil seiner Fotobibliothek sind. Das Aufkommen des Albums „Wiederhergestellt“ bietet eine Lösung für Fotos und Videos, die aufgrund einer Datenbankbeschädigung verloren gehen, die Kameraanwendung nicht korrekt in der Fotobibliothek speichert oder eine Drittanbieteranwendung die Fotobibliothek verwaltet. Benutzer benötigen nur wenige einfache Schritte

Ausführliches Tutorial zum Herstellen einer Datenbankverbindung mit MySQLi in PHP Ausführliches Tutorial zum Herstellen einer Datenbankverbindung mit MySQLi in PHP Jun 04, 2024 pm 01:42 PM

So verwenden Sie MySQLi zum Herstellen einer Datenbankverbindung in PHP: MySQLi-Erweiterung einbinden (require_once) Verbindungsfunktion erstellen (functionconnect_to_db) Verbindungsfunktion aufrufen ($conn=connect_to_db()) Abfrage ausführen ($result=$conn->query()) Schließen Verbindung ( $conn->close())

Umgang mit Datenbankverbindungsfehlern in PHP Umgang mit Datenbankverbindungsfehlern in PHP Jun 05, 2024 pm 02:16 PM

Um Datenbankverbindungsfehler in PHP zu behandeln, können Sie die folgenden Schritte ausführen: Verwenden Sie mysqli_connect_errno(), um den Fehlercode abzurufen. Verwenden Sie mysqli_connect_error(), um die Fehlermeldung abzurufen. Durch die Erfassung und Protokollierung dieser Fehlermeldungen können Datenbankverbindungsprobleme leicht identifiziert und behoben werden, wodurch der reibungslose Betrieb Ihrer Anwendung gewährleistet wird.

Wie verwende ich Datenbank-Callback-Funktionen in Golang? Wie verwende ich Datenbank-Callback-Funktionen in Golang? Jun 03, 2024 pm 02:20 PM

Durch die Verwendung der Datenbank-Rückruffunktion in Golang kann Folgendes erreicht werden: Ausführen von benutzerdefiniertem Code, nachdem der angegebene Datenbankvorgang abgeschlossen ist. Fügen Sie benutzerdefiniertes Verhalten durch separate Funktionen hinzu, ohne zusätzlichen Code zu schreiben. Rückruffunktionen stehen für Einfüge-, Aktualisierungs-, Lösch- und Abfragevorgänge zur Verfügung. Sie müssen die Funktion sql.Exec, sql.QueryRow oder sql.Query verwenden, um die Rückruffunktion verwenden zu können.

Wie speichere ich JSON-Daten in einer Datenbank in Golang? Wie speichere ich JSON-Daten in einer Datenbank in Golang? Jun 06, 2024 am 11:24 AM

JSON-Daten können mithilfe der gjson-Bibliothek oder der json.Unmarshal-Funktion in einer MySQL-Datenbank gespeichert werden. Die gjson-Bibliothek bietet praktische Methoden zum Parsen von JSON-Feldern, und die Funktion json.Unmarshal erfordert einen Zieltypzeiger zum Unmarshalieren von JSON-Daten. Bei beiden Methoden müssen SQL-Anweisungen vorbereitet und Einfügevorgänge ausgeführt werden, um die Daten in der Datenbank beizubehalten.

MySQL: Einfache Konzepte für einfaches Lernen MySQL: Einfache Konzepte für einfaches Lernen Apr 10, 2025 am 09:29 AM

MySQL ist ein Open Source Relational Database Management System. 1) Datenbank und Tabellen erstellen: Verwenden Sie die Befehle erstellte und creatEtable. 2) Grundlegende Vorgänge: Einfügen, aktualisieren, löschen und auswählen. 3) Fortgeschrittene Operationen: Join-, Unterabfrage- und Transaktionsverarbeitung. 4) Debugging -Fähigkeiten: Syntax, Datentyp und Berechtigungen überprüfen. 5) Optimierungsvorschläge: Verwenden Sie Indizes, vermeiden Sie ausgewählt* und verwenden Sie Transaktionen.

Fallstricke bei PHP-Datenbankverbindungen: Vermeiden Sie häufige Fehler und Missverständnisse Fallstricke bei PHP-Datenbankverbindungen: Vermeiden Sie häufige Fehler und Missverständnisse Jun 05, 2024 pm 10:21 PM

Um Fehler bei der PHP-Datenbankverbindung zu vermeiden, befolgen Sie Best Practices: Überprüfen Sie auf Verbindungsfehler und gleichen Sie Variablennamen mit Anmeldeinformationen ab. Verwenden Sie sichere Speicher- oder Umgebungsvariablen, um eine Hardcodierung von Anmeldeinformationen zu vermeiden. Schließen Sie die Verbindung nach der Verwendung, um eine SQL-Injection zu verhindern, und verwenden Sie vorbereitete Anweisungen oder gebundene Parameter.

MySQL: Eine Einführung in die beliebteste Datenbank der Welt MySQL: Eine Einführung in die beliebteste Datenbank der Welt Apr 12, 2025 am 12:18 AM

MySQL ist ein Open Source Relational Database Management -System, das hauptsächlich zum schnellen und zuverlässigen Speicher und Abrufen von Daten verwendet wird. Sein Arbeitsprinzip umfasst Kundenanfragen, Abfragebedingungen, Ausführung von Abfragen und Rückgabergebnissen. Beispiele für die Nutzung sind das Erstellen von Tabellen, das Einsetzen und Abfragen von Daten sowie erweiterte Funktionen wie Join -Operationen. Häufige Fehler umfassen SQL -Syntax, Datentypen und Berechtigungen sowie Optimierungsvorschläge umfassen die Verwendung von Indizes, optimierte Abfragen und die Partitionierung von Tabellen.

See all articles