SQLite 语法
大小写敏感性
有个重要的点值得注意,SQLite 是不区分大小写的,但也有一些命令是大小写敏感的,比如 GLOB 和 glob 在 SQLite 的语句中有不同的含义。
注释
SQLite 注释是附加的注释,可以在 SQLite 代码中添加注释以增加其可读性,他们可以出现在任何空白处,包括在表达式内和其他 SQL 语句的中间,但它们不能嵌套。
SQL 注释以两个连续的 “-” 字符(ASCII 0x2d)开始,并扩展至下一个换行符(ASCII 0x0a)或直到输入结束,以先到者为准。
您也可以使用 C 风格的注释,以 “/" 开始,并扩展至下一个 "/” 字符对或直到输入结束,以先到者为准。SQLite的注释可以跨越多行。
sqlite>.help -- 这是一个简单的注释
SQLite 语句
所有的 SQLite 语句可以以任何关键字开始,如 SELECT、INSERT、UPDATE、DELETE、ALTER、DROP 等,所有的语句以分号 ; 结束。
ANALYZE 语句
ANALYZE;
or
ANALYZE database_name;
or
ANALYZE database_name.table_name;
AND/OR 子句
SELECT column1, column2....columnN
FROM table_name
WHERE CONDITION-1 {AND|OR} CONDITION-2;
ALTER TABLE 语句
ALTER TABLE table_name ADD COLUMN column_def...;
ALTER TABLE 语句(Rename)
ALTER TABLE table_name RENAME TO new_table_name;
ATTACH DATABASE 语句
ATTACH DATABASE 'DatabaseName' As 'Alias-Name';
BEGIN TRANSACTION 语句
BEGIN;
or
BEGIN EXCLUSIVE TRANSACTION;
BETWEEN 子句
SELECT column1, column2....columnN
FROM table_name
WHERE column_name BETWEEN val-1 AND val-2;
COMMIT 语句
COMMIT;
CREATE INDEX 语句
CREATE INDEX index_name
ON table_name ( column_name COLLATE NOCASE );
CREATE UNIQUE INDEX 语句
CREATE UNIQUE INDEX index_name
ON table_name ( column1, column2,...columnN);
CREATE TABLE 语句
CREATE TABLE table_name(
column1 datatype,
column2 datatype,
column3 datatype,
.....
columnN datatype,
PRIMARY KEY( one or more columns )
);
CREATE TRIGGER 语句
CREATE TRIGGER database_name.trigger_name
BEFORE INSERT ON table_name FOR EACH ROW
BEGIN
stmt1;
stmt2;
....
END;
CREATE VIEW 语句
CREATE VIEW database_name.view_name AS
SELECT statement....;
CREATE VIRTUAL TABLE 语句
CREATE VIRTUAL TABLE database_name.table_name USING weblog( access.log );
or
CREATE VIRTUAL TABLE database_name.table_name USING fts3( );
COMMIT TRANSACTION 语句
COMMIT;
COUNT 子句
SELECT COUNT(column_name)
FROM table_name
WHERE CONDITION;
DELETE 语句
DELETE FROM table_name
WHERE {CONDITION};
DETACH DATABASE 语句
DETACH DATABASE 'Alias-Name';
DISTINCT 子句
SELECT DISTINCT column1, column2....columnN
FROM table_name;
DROP INDEX 语句
DROP INDEX database_name.index_name;
DROP TABLE 语句
DROP TABLE database_name.table_name;
DROP VIEW 语句
DROP VIEW view_name;
DROP TRIGGER 语句
DROP TRIGGER trigger_name
EXISTS 子句
SELECT column1, column2....columnN
FROM table_name
WHERE column_name EXISTS (SELECT * FROM table_name );
EXPLAIN 语句
EXPLAIN INSERT statement...;
or
EXPLAIN QUERY PLAN SELECT statement...;
GLOB 子句
SELECT column1, column2....columnN
FROM table_name
WHERE column_name GLOB { PATTERN };
GROUP BY 子句
SELECT SUM(column_name)
FROM table_name
WHERE CONDITION
GROUP BY column_name;
HAVING 子句
SELECT SUM(column_name)
FROM table_name
WHERE CONDITION
GROUP BY column_name
HAVING (arithematic function condition);
INSERT INTO 语句
INSERT INTO table_name( column1, column2....columnN)
VALUES ( value1, value2....valueN);
IN 子句
SELECT column1, column2....columnN
FROM table_name
WHERE column_name IN (val-1, val-2,...val-N);
Like 子句
SELECT column1, column2....columnN
FROM table_name
WHERE column_name LIKE { PATTERN };
NOT IN 子句
SELECT column1, column2....columnN
FROM table_name
WHERE column_name NOT IN (val-1, val-2,...val-N);
ORDER BY 子句
SELECT column1, column2....columnN
FROM table_name
WHERE CONDITION
ORDER BY column_name {ASC|DESC};
PRAGMA 语句
PRAGMA pragma_name;
For example:
PRAGMA page_size;
PRAGMA cache_size = 1024;
PRAGMA table_info(table_name);
RELEASE SAVEPOINT 语句
RELEASE savepoint_name;
REINDEX 语句
REINDEX collation_name; REINDEX database_name.index_name; REINDEX database_name.table_name;
ROLLBACK 语句
ROLLBACK;
or
ROLLBACK TO SAVEPOINT savepoint_name;
SAVEPOINT 语句
SAVEPOINT savepoint_name;
SELECT 语句
SELECT column1, column2....columnN
FROM table_name;
UPDATE 语句
UPDATE table_name
SET column1 = value1, column2 = value2....columnN=valueN
[ WHERE CONDITION ];
VACUUM 语句
VACUUM;
WHERE 子句
SELECT column1, column2....columnN
FROM table_name
WHERE CONDITION;
「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。




