本章提供了PostgreSQL SQL 命令的列表,以及每个命令的精确语法规则,这套命令取自psql命令行工具,现在您已经安装了Postgres,打开psql为-
Program Files→PostgreSQL 9.2→SQL Shell(psql)。
使用psql,可以使用\help命令生成命令的完整列表。对于特定命令的语法,请使用以下命令-
postgres-#\help <command_name>
中止当前事务。
ABORT [ WORK | TRANSACTION ]
更改聚合函数的定义。
ALERT AGGREGATE name ( type ) RENAME TO new_name ALERT AGGREGATE name ( type ) OWNER TO new_owner
更改转换的定义。
ALTER CONVERSION name RENAME TO new_name ALTER CONVERSION name OWNER TO new_owner
更改数据库特定的参数。
ALTER DATABASE name SET parameter { TO | = } { value | DEFAULT } ALTER DATABASE name RESET parameter ALTER DATABASE name RENAME TO new_name ALTER DATABASE name OWNER TO new_owner
更改域特定参数的定义。
ALTER DOMAIN name { SET DEFAULT expression | DROP DEFAULT } ALTER DOMAIN name { SET | DROP } NOT NULL ALTER DOMAIN name ADD domain_constraint ALTER DOMAIN name DROP CONSTRAINT constraint_name [ RESTRICT | CASCADE ] ALTER DOMAIN name OWNER TO new_owner
更改函数的定义。
ALTER FUNCTION
更改用户组。
ALTER GROUP groupname ADD USER username [, ... ] ALTER GROUP groupname DROP USER username [, ... ] ALTER GROUP groupname RENAME TO new_name
更改索引的定义。
ALTER INDEX name OWNER TO new_owner ALTER INDEX name SET TABLESPACE indexspace_name ALTER INDEX name RENAME TO new_name
更改过程语言的定义。
ALTER LANGUAGE
更改运算符的定义。
ALTER OPERATOR name ( { lefttype | NONE }, { righttype | NONE } ) OWNER TO new_owner
更改操作类别的定义。
ALTER OPERATOR CLASS name USING index_method RENAME TO new_name ALTER OPERATOR CLASS name USING index_method OWNER TO new_owner
更改架构的定义。
ALTER SCHEMA
更改序列生成器的定义。
ALTER SEQUENCE name [ INCREMENT [ BY ] increment ] [ MINVALUE minvalue | NO MINVALUE ] [ MAXVALUE maxvalue | NO MAXVALUE ] [ RESTART [ WITH ] start ] [ CACHE cache ] [ [ NO ] CYCLE ]
更改表的定义。
ALTER TABLE
其中动作是以下几行之一-
CLUSTER
更改表空间的定义。
ALTER TABLESPACE name RENAME TO new_name ALTER TABLESPACE name OWNER TO new_owner
更改触发器的定义。
ALTER TRIGGER
更改类型的定义。
ALTER TYPE
更改数据库用户帐户。
ALTER USER name [ [ WITH ] option [ ... ] ] ALTER USER name RENAME TO new_name ALTER USER name SET parameter { TO | = } { value | DEFAULT } ALTER USER name RESET parameter
其中选项可以是-
[ ENCRYPTED | UNENCRYPTED ] PASSWORD 'password' | CREATEDB | NOCREATEDB | CREATEUSER | NOCREATEUSER | VALID UNTIL 'abstime'
收集有关数据库的统计信息。
ANALYZE [ VERBOSE ] [ table [ (column [, ...] ) ] ]
启动事务块。
BEGIN [ WORK | TRANSACTION ] [ transaction_mode [, ...] ]
其中 transaction_mode 是以下之一:
COMMITTED
强制执行事务日志检查点。
CHECKPOINT
关闭游标。
CLOSE name
根据索引对表进行聚类。
CLUSTER
定义或更改对象的注释。
COMMENT
提交当前交易。
COMMIT
在文件和表之间复制数据。
COPY table_name [ ( column [, ...] ) ] FROM { 'filename' | STDIN } [ WITH ] [ BINARY ] [ OIDS ] [ DELIMITER [ AS ] 'delimiter' ] [ NULL [ AS ] 'null string' ] [ CSV [ QUOTE [ AS ] 'quote' ] [ ESCAPE [ AS ] 'escape' ] [ FORCE NOT NULL column [, ...] ] COPY table_name [ ( column [, ...] ) ] TO { 'filename' | STDOUT } [ [ WITH ] [ BINARY ] [ OIDS ] [ DELIMITER [ AS ] 'delimiter' ] [ NULL [ AS ] 'null string' ] [ CSV [ QUOTE [ AS ] 'quote' ] [ ESCAPE [ AS ] 'escape' ] [ FORCE QUOTE column [, ...] ]
定义一个新的聚合函数。
CREATE AGGREGATE name ( BASETYPE = input_data_type, SFUNC = sfunc, STYPE = state_data_type [, FINALFUNC = ffunc ] [, INITCOND = initial_condition ] )
定义一个新的CAST表。
CREATE CAST (source_type AS target_type) WITH FUNCTION func_name (arg_types) [ AS ASSIGNMENT | AS IMPLICIT ] CREATE CAST (source_type AS target_type) WITHOUT FUNCTION [ AS ASSIGNMENT | AS IMPLICIT ]
定义一个新的约束触发器。
EXECUTE
定义新的转化。
CREATE [DEFAULT] CONVERSION name FOR source_encoding TO dest_encoding FROM func_name
创建一个新的数据库。
CREATE DATABASE name [ [ WITH ] [ OWNER [=] db_owner ] [ TEMPLATE [=] template ] [ ENCODING [=] encoding ] [ TABLESPACE [=] tablespace ] ]
定义一个新域。
CREATE DOMAIN name [AS] data_type [ DEFAULT expression ] [ constraint [ ... ] ]
其中约束是-
[ CONSTRAINT constraint_name ] { NOT NULL | NULL | CHECK (expression) }
定义一个新功能。
CREATE [ OR REPLACE ] FUNCTION name ( [ [ arg_name ] arg_type [, ...] ] ) RETURNS ret_type { LANGUAGE lang_name | IMMUTABLE | STABLE | VOLATILE | CALLED ON NULL INPUT | RETURNS NULL ON NULL INPUT | STRICT | [ EXTERNAL ] SECURITY INVOKER | [ EXTERNAL ] SECURITY DEFINER | AS 'definition' | AS 'obj_file', 'link_symbol' } ... [ WITH ( attribute [, ...] ) ]
定义一个新的用户组。
CREATE GROUP name [ [ WITH ] option [ ... ] ] Where option can be: SYSID gid | USER username [, ...]
定义一个新索引。
CREATE [ UNIQUE ] INDEX name ON table [ USING method ] ( { column | ( expression ) } [ opclass ] [, ...] ) [ TABLESPACE tablespace ] [ WHERE predicate ]
定义一种新的程序语言。
CREATE [ TRUSTED ] [ PROCEDURAL ] LANGUAGE name HANDLER call_handler [ VALIDATOR val_function ]
定义一个新的运算符。
CREATE OPERATOR name ( PROCEDURE = func_name [, LEFTARG = left_type ] [, RIGHTARG = right_type ] [, COMMUTATOR = com_op ] [, NEGATOR = neg_op ] [, RESTRICT = res_proc ] [, JOIN = join_proc ] [, HASHES ] [, MERGES ] [, SORT1 = left_sort_op ] [, SORT2 = right_sort_op ] [, LTCMP = less_than_op ] [, GTCMP = greater_than_op ] )
定义一个新的运算符类。
CREATE OPERATOR CLASS name [ DEFAULT ] FOR TYPE data_type USING index_method AS { OPERATOR strategy_number operator_name [ ( op_type, op_type ) ] [ RECHECK ] | FUNCTION support_number func_name ( argument_type [, ...] ) | STORAGE storage_type } [, ... ]
定义一个新的重写规则。
CREATE [ OR REPLACE ] RULE name AS ON event TO table [ WHERE condition ] DO [ ALSO | INSTEAD ] { NOTHING | command | ( command ; command ... ) }
定义一个新的架构。
CREATE SCHEMA schema_name [ AUTHORIZATION username ] [ schema_element [ ... ] ] CREATE SCHEMA AUTHORIZATION username [ schema_element [ ... ] ]
定义一个新的序列生成器。
CREATE [ TEMPORARY | TEMP ] SEQUENCE name [ INCREMENT [ BY ] increment ] [ MINVALUE minvalue | NO MINVALUE ] [ MAXVALUE maxvalue | NO MAXVALUE ] [ START [ WITH ] start ] [ CACHE cache ] [ [ NO ] CYCLE ]
定义一个新表。
COMMIT
其中 column_constraint 是-
DELETE
并且 table_constraint 是-
DELETE
根据查询输出定义一个新表。
CREATE [ [ GLOBAL | LOCAL ] { TEMPORARY | TEMP } ] TABLE table_name [ (column_name [, ...] ) ] [ [ WITH | WITHOUT ] OIDS ] AS query
定义一个新的表空间。
CREATE TABLESPACE
定义一个新触发器。
CREATE TRIGGER name { BEFORE | AFTER } { event [ OR ... ] } ON table [ FOR [ EACH ] { ROW | STATEMENT } ] 执行 PROCEDURE func_name ( arguments )
定义一个新的数据类型。
ANALYZE
定义一个新的数据库用户帐户。
CREATE USER name [ [ WITH ] option [ ... ] ]
其中选项可以是-
SYSID uid | [ ENCRYPTED | UNENCRYPTED ] PASSWORD 'password' | CREATEDB | NOCREATEDB | CREATEUSER | NOCREATEUSER | IN GROUP group_name [, ...] | VALID UNTIL 'abs_time'
定义一个新视图。
CREATE [ OR REPLACE ] VIEW name [ ( column_name [, ...] ) ] AS query
取消分配准备好的语句。
DEALLOCATE [PREPARE ] plan_name
定义一个游标。
UPDATE
删除表中的行。
DELETE
删除聚合函数。
DROP AGGREGATE
删除别名。
DROP CAST (source_type AS target_type) [ CASCADE | RESTRICT ]
删除转换。
DROP CONVERSION name [ CASCADE | RESTRICT ]
删除数据库。
DROP DATABASE
删除域。
DROP DOMAIN name [, ...] [ CASCADE | RESTRICT ]
删除功能。
DROP FUNCTION name ( [ type [, ...] ] ) [ CASCADE | RESTRICT ]
删除用户组。
DROP GROUP name
删除索引。
DROP INDEX name [, ...] [ CASCADE | RESTRICT ]
删除程序语言。
DROP [ PROCEDURAL ] LANGUAGE name [ CASCADE | RESTRICT ]
删除运算符。
DROP OPERATOR name ( { left_type | NONE }, { right_type | NONE } ) [ CASCADE | RESTRICT ]
删除运算类。
DROP OPERATOR CLASS name USING index_method [ CASCADE | RESTRICT ]
删除重写规则。
DROP RULE name ON relation [ CASCADE | RESTRICT ]
删除架构。
DROP SCHEMA name [, ...] [ CASCADE | RESTRICT ]
删除序列。
DROP SEQUENCE name [, ...] [ CASCADE | RESTRICT ]
删除表。
DROP TABLE name [, ...] [ CASCADE | RESTRICT ]
删除表空间。
DROP TABLESPACE
删除触发器。
链接:https://www.learnfk.comhttps://www.learnfk.com/postgresql/postgresql-syntax.html
来源:LearnFk无涯教程网
DROP TRIGGER name ON table [ CASCADE | RESTRICT ]
删除数据类型。
DROP TYPE
删除数据库用户帐户。
DROP USER
删除视图。
DROP VIEW
提交当前交易。
END [ WORK | TRANSACTION ]
执行准备好的语句。
EXECUTE
显示语句的执行计划。
ANALYZE
使用游标从查询中检索行。
FETCH [ direction { FROM | IN } ] cursor_name
其中 direction 可以为空或-
NEXT
PRIOR
FIRST
LAST
ABSOLUTE count
RELATIVE count
count
ALL
FORWARD
FORWARD count
FORWARD ALL
BACKWARD
BACKWARD count
BACKWARD ALL
定义访问权限。
SELECT
在表中创建新行。
INSERT
收听通知。
LISTEN
加载或重新加载共享库文件。
LOAD 'filename'
锁定表。
LOCK [ TABLE ] name [, ...] [ IN lock_mode MODE ] [ NOWAIT ]
其中 lock_mode 是-之一
ACCESS SHARE | ROW SHARE | ROW EXCLUSIVE | SHARE UPDATE EXCLUSIVE | SHARE | SHARE ROW EXCLUSIVE | EXCLUSIVE | ACCESS EXCLUSIVE
定位光标。
MOVE [ direction { FROM | IN } ] cursor_name
生成通知。
NOTIFY name
准备要执行的语句。
PREPARE plan_name [ (data_type [, ...] ) ] AS statement
重建索引。
REINDEX { DATABASE | TABLE | INDEX } name [ FORCE ]
销毁先前定义的保存点。
SAVEPOINT
将运行时参数的值恢复为默认值。
RESET name
RESET ALL
删除访问权限。
REVOKE
中止当前交易。
ROLLBACK
回滚到保存点。
ROLLBACK
在当前事务中定义一个新的保存点。
SAVEPOINT
从表或视图中检索行。
SELECT其中from_item可以是以下之一:
[ ONLY ] table_name [ * ] [ [ AS ] alias [ ( column_alias [, ...] ) ] ] ( select ) [ AS ] alias [ ( column_alias [, ...] ) ] function_name ( [ argument [, ...] ] ) [ AS ] alias [ ( column_alias [, ...] | column_definition [, ...] ) ] function_name ( [ argument [, ...] ] ) AS ( column_definition [, ...] ) from_item [ NATURAL ] join_type from_item [ ON join_condition | USING ( join_column [, ...] ) ]
根据查询输出定义一个新表。
SELCT
更改运行时参数。
SET [ SESSION | LOCAL ] name { TO | = } { value | 'value' | DEFAULT } SET [ SESSION | LOCAL ] TIME ZONE { time_zone | LOCAL | DEFAULT }
设置当前事务的约束检查模式。
SET CONSTRAINTS { ALL | name [, ...] } { DEFERRED | IMMEDIATE }
设置会话用户标识符和当前会话的当前用户标识符。
SESSION AUTHORIZATION
设置当前交易的特征。
SET TRANSACTION transaction_mode [, ...] SET SESSION CHARACTERISTICS AS TRANSACTION transaction_mode [, ...]
其中 transaction_mode 是以下之一:
COMMIT
显示运行时参数的值。
SHOW name
SHOW ALL
启动事务块。
START TRANSACTION [ transaction_mode [, ...] ]
其中 transaction_mode 是以下之一:
COMMIT
清空表。
TRUNCATE[ TABLE ] name
停止收听通知。
UNLISTEN { name | * }
更新表的行。
UPDATE
垃圾收集并可选地分析数据库。
VACUUM
祝学习愉快!(内容编辑有误?请选中要编辑内容 -> 右键 -> 修改 -> 提交!)