84366992 发表于 2016-11-29 07:49:25

SQLite语法2

  SQLite内建语法表
结构定义CREATE TABLE  创建新表。
  语法:

sql-command::=CREATE[TEMP|TEMPORARY]TABLEtable-name(
column-def[,column-def]*
[,constraint]*
)sql-command::=CREATE[TEMP|TEMPORARY]TABLE[database-name.]table-nameASselect-statementcolumn-def::=name[type][[CONSTRAINTname]column-constraint]*type::=typename|
typename(number)|
typename(number,number)column-constraint::=NOT NULL[conflict-clause]|
PRIMARY KEY[sort-order][conflict-clause]|
UNIQUE[conflict-clause]|
CHECK(expr)[conflict-clause]|
DEFAULTvalue|
COLLATEcollation-nameconstraint::=PRIMARY KEY(column-list)[conflict-clause]|
UNIQUE(column-list)[conflict-clause]|
CHECK(expr)[conflict-clause]conflict-clause::=ON CONFLICTconflict-algorithmCREATE VIEW  创建一个视图(虚拟表),该表以另一种方式表示一个或多个表中的数据。
  语法:

sql-command::=CREATE[TEMP|TEMPORARY]VIEW[database-name.]view-nameASselect-statement
例子:
CREATE VIEWmaster_viewAS
SELECT*FROMsqlite_masterWHEREtype='view';
说明:
创建一个名为master_view的视图,其中包括sqlite_master这个表中的所有视图表。CREATE TRIGGER  创建触发器,触发器是一种特殊的存储过程,在用户试图对指定的表执行指定的数据修改语句时自动执行。
  语法:

sql-statement::=CREATE[TEMP|TEMPORARY]TRIGGERtrigger-name[BEFORE|AFTER]
database-eventON[database-name.]table-name
trigger-actionsql-statement::=CREATE[TEMP|TEMPORARY]TRIGGERtrigger-nameINSTEADOF
database-eventON[database-name.]view-name
trigger-actiondatabase-event::=DELETE|
INSERT|
UPDATE|
UPDATE OFcolumn-listtrigger-action::=[FOR EACH ROW|FOR EACH STATEMENT][WHENexpression]
BEGIN
trigger-step;[trigger-step;]*
ENDtrigger-step::=update-statement|insert-statement|
delete-statement|select-statement  例子:
CREATE TRIGGER update_customer_address UPDATE OF address ON customers
BEGIN
UPDATE orders SET address = new.address WHERE customer_name = old.name;
END;
说明:
创建了一个名为update_customer_address的触发器,当用户更新customers表中的address字段时,将触发并更新orders表中的address字段为新的值。
比如执行如下一条语句:
UPDATE customers SET address = '1 Main St.' WHERE name = 'Jack Jones';
数据库将自动执行如下语句:
UPDATE orders SET address = '1 Main St.' WHERE customer_name = 'Jack Jones';
CREATE INDEX  为给定表或视图创建索引。
  语法:

sql-statement::=CREATE[UNIQUE]INDEXindex-name
ON[database-name.]table-name(column-name[,column-name]*)
[ON CONFLICTconflict-algorithm]column-name::=name[COLLATEcollation-name][ASC|DESC]  例子:
CREATE INDEXidx_emailONcustomers (email);
说明:
为customers表中的email创建一个名为idx_email的字段。
结构删除DROP TABLE  删除表定义及该表的所有索引。
  语法:

sql-command::=DROP TABLE[database-name.]table-name例子:
DROP TABLE customers;DROP VIEW  删除一个视图。
  语法:

sql-command::=DROP VIEWview-name  例子:
DROP VIEW master_view;
DROP TRIGGER  删除一个触发器。
  语法:

sql-statement::=DROP TRIGGER[database-name.]trigger-name  例子:
DROP TRIGGERupdate_customer_address;
DROP INDEX  删除一个索引。
  语法:

sql-command::=DROP INDEX[database-name.]index-name  例子:
DROP INDEX idx_email;
数据操作INSERT  将新行插入到表。
  语法:

sql-statement::=INSERT[ORconflict-algorithm]INTO[database-name.]table-name[(column-list)]VALUES(value-list)|
INSERT[ORconflict-algorithm]INTO[database-name.]table-name[(column-list)]select-statementUPDATE  更新表中的现有数据。
  语法:

sql-statement::=UPDATE[ORconflict-algorithm][database-name.]table-name
SETassignment[,assignment]*
[WHEREexpr]assignment::=column-name=exprDELETE  从表中删除行。
  语法:

sql-statement::=DELETE FROM[database-name.]table-name[WHEREexpr]SELECT  从表中检索数据。
  语法:

sql-statement::=SELECT[ALL|DISTINCT]result[FROMtable-list]
[WHEREexpr]
[GROUP BYexpr-list]
[HAVINGexpr]
[compound-opselect]*
[ORDER BYsort-expr-list]
[LIMITinteger[(OFFSET|,)integer]]result::=result-column[,result-column]*result-column::=*|table-name.*|expr[[AS]string]table-list::=table[join-optablejoin-args]*table::=table-name[ASalias]|
(select)[ASalias]join-op::=,|[NATURAL][LEFT|RIGHT|FULL][OUTER|INNER|CROSS]JOINjoin-args::=[ONexpr][USING(id-list)]sort-expr-list::=expr[sort-order][,expr[sort-order]]*sort-order::=[COLLATEcollation-name][ASC|DESC]compound_op::=UNION|UNION ALL|INTERSECT|EXCEPTREPLACE  类似INSERT
  语法:

sql-statement::=REPLACE INTO[database-name.]table-name[(column-list)]VALUES(value-list)|
REPLACE INTO[database-name.]table-name[(column-list)]select-statement事务处理BEGIN TRANSACTION  标记一个事务的起始点。
  语法:

sql-statement::=BEGIN[TRANSACTION[name]]END TRANSACTION  标记一个事务的终止。
  语法:

sql-statement::=END[TRANSACTION[name]]COMMIT TRANSACTION  标志一个事务的结束。
  语法:

sql-statement::=COMMIT[TRANSACTION[name]]ROLLBACK TRANSACTION  将事务回滚到事务的起点。
  语法:

sql-statement::=ROLLBACK[TRANSACTION[name]]其他操作COPY  主要用于导入大量的数据。
  语法:

sql-statement::=COPY[ORconflict-algorithm][database-name.]table-nameFROMfilename
[USING DELIMITERSdelim]例子:
COPYcustomersFROMcustomers.csv;EXPLAIN  语法:

sql-statement::=EXPLAINsql-statementPRAGMA  语法:

sql-statement::=PRAGMAname[=value]|
PRAGMAfunction(arg)VACUUM  语法:

sql-statement::=VACUUM[index-or-table-name]ATTACH DATABASE  附加一个数据库到当前的数据库连接。
  语法:

sql-statement::=ATTACH[DATABASE]database-filenameASdatabase-nameDETTACH DATABASE  从当前的数据库分离一个使用ATTACH DATABASE附加的数据库。
  语法:

sql-command::=DETACH[DATABASE]database-name  SQLite内建函数表
算术函数abs(X)返回给定数字表达式的绝对值。max(X,Y[,...])返回表达式的最大值。min(X,Y[,...])返回表达式的最小值。random(*)返回随机数。round(X[,Y])返回数字表达式并四舍五入为指定的长度或精度。字符处理函数length(X)返回给定字符串表达式的字符个数。lower(X)将大写字符数据转换为小写字符数据后返回字符表达式。upper(X)返回将小写字符数据转换为大写的字符表达式。substr(X,Y,Z)返回表达式的一部分。randstr()quote(A)like(A,B)确定给定的字符串是否与指定的模式匹配。glob(A,B)条件判断函数coalesce(X,Y[,...])ifnull(X,Y)nullif(X,Y)集合函数avg(X)返回组中值的平均值。count(X)返回组中项目的数量。max(X)返回组中值的最大值。min(X)返回组中值的最小值。sum(X)返回表达式中所有值的和。其他函数typeof(X)返回数据的类型。last_insert_rowid()返回最后插入的数据的ID。sqlite_version(*)返回SQLite的版本。change_count()返回受上一语句影响的行数。last_statement_change_count()
页: [1]
查看完整版本: SQLite语法2