九、序列操作函数:
序列对象(也叫序列生成器)都是用CREATE SEQUENCE创建的特殊的单行表。一个序列对象通常用于为行或者表生成唯一的标识符。下面序列函数,为我们从序列对象中获取最新的序列值提供了简单和并发读取安全的方法。
函数 返回类型 描述 nextval(regclass) bigint 递增序列对象到它的下一个数值并且返回该值。这个动作是自动完成的。即使多个会话并发运行nextval,每个进程也会安全地收到一个唯一的序列值。 currval(regclass) bigint 在当前会话中返回最近一次nextval抓到的该序列的数值。(如果在本会话中从未在该序列上调用过 nextval,那么会报告一个错误。)请注意因为此函数返回一个会话范围的数值,而且也能给出一个可预计的结果,因此可以用于判断其它会话是否执行过nextval。 lastval() bigint 返回当前会话里最近一次nextval返回的数值。这个函数等效于currval,只是它不用序列名为参数,它抓取当前会话里面最近一次nextval使用的序列。如果当前会话还没有调用过nextval,那么调用lastval将会报错。 setval(regclass, bigint) bigint 重置序列对象的计数器数值。设置序列的last_value字段为指定数值并且将其is_called字段设置为true,表示下一次nextval将在返回数值之前递增该序列。 setval(regclass, bigint, boolean) bigint 重置序列对象的计数器数值。功能等同于上面的setval函数,只是is_called可以设置为true或false。如果将其设置为false,那么下一次nextval将返回该数值,随后的nextval才开始递增该序列。
对于regclass参数,仅需用单引号括住序列名即可,因此它看上去就像文本常量。为了达到和处理普通SQL对象一样的兼容性,这个字串将被转换成小写,除非该序列名是用双引号括起,如:
复制代码 代码如下:
nextval('foo') --操作序列号foo
nextval('FOO') --操作序列号foo
nextval('"Foo"') --操作序列号Foo
SELECT setval('foo', 42); --下次nextval将返回43
SELECT setval('foo', 42, true);
SELECT setval('foo', 42, false); --下次nextval将返回42
十、条件表达式:
1. CASE:
SQL CASE表达式是一种通用的条件表达式,类似于其它语言中的if/else语句。
复制代码 代码如下:
CASE WHEN condition THEN result
[WHEN ...]
[ELSE result]
END
condition是一个返回boolean的表达式。如果为真,那么CASE表达式的结果就是符合条件的result。如果结果为假,那么以相同方式搜寻随后的WHEN子句。如果没有WHEN condition为真,那么case表达式的结果就是在ELSE子句里的值。如果省略了ELSE子句而且没有匹配的条件,结果为NULL,如:
复制代码 代码如下:
MyTest=> SELECT * FROM testtable;
i
---
1
2
3
(3 rows)
MyTest=> SELECT i, CASE WHEN i=1 THEN 'one'
MyTest-> WHEN i=2 THEN 'two'
MyTest-> ELSE 'other'
MyTest-> END
MyTest-> FROM testtable;
i | case
---+-------
1 | one
2 | two
3 | other
(3 rows)
注:CASE表达式并不计算任何对于判断结果并不需要的子表达式。
2. COALESCE:
COALESCE返回它的第一个非NULL的参数的值。它常用于在为显示目的检索数据时用缺省值替换NULL值。
复制代码 代码如下:
COALESCE(value[, ...])
和CASE表达式一样,COALESCE将不会计算不需要用来判断结果的参数。也就是说,在第一个非空参数右边的参数不会被计算。
3. NULLIF:
当且仅当value1和value2相等时,NULLIF才返回NULL。否则它返回value1。
复制代码 代码如下:
NULLIF(value1, value2)
MyTest=> SELECT NULLIF('abc','abc');
nullif
--------
(1 row)
MyTest=> SELECT NULLIF('abcd','abc');
nullif
--------
abcd
(1 row)
4. GREATEST和LEAST:
GREATEST和LEAST函数从一个任意的数字表达式列表里选取最大或者最小的数值。列表中的NULL数值将被忽略。只有所有表达式的结果都是NULL的时候,结果才会是NULL。
复制代码 代码如下:
GREATEST(value [, ...])
LEAST(value [, ...])
MyTest=> SELECT GREATEST(1,3,5);
greatest
----------
5
(1 row)
MyTest=> SELECT LEAST(1,3,5,NULL);
least
-------
1
(1 row)
十一、数组函数和操作符:
1. PostgreSQL中提供的用于数组的操作符列表:
操作符
描述
例子
结果
=
等于
ARRAY[1.1,2.1,3.1]::int[] = ARRAY[1,2,3]
t
<>
不等于
ARRAY[1,2,3] <> ARRAY[1,2,4]
t
<
小于
ARRAY[1,2,3] < ARRAY[1,2,4]
t
>
大于
ARRAY[1,4,3] > ARRAY[1,2,4]
t
<=
小于或等于
ARRAY[1,2,3] <= ARRAY[1,2,3]
t
>=
大于或等于
ARRAY[1,4,3] >= ARRAY[1,4,3]
t
||
数组与数组连接
ARRAY[1,2,3] || ARRAY[4,5,6]
{1,2,3,4,5,6}
||
数组与数组连接
ARRAY[1,2,3] || ARRAY[[4,5,6],[7,8,9]]
{{1,2,3},{4,5,6},{7,8,9}}
||
元素与数组连接
3 || ARRAY[4,5,6]
{3,4,5,6}
||
元素与数组连接
ARRAY[4,5,6] || 7
{4,5,6,7}
2. PostgreSQL中提供的用于数组的函数列表:
函数 返回类型 描述 例子 结果 array_cat(anyarray, anyarray) anyarray 连接两个数组 array_cat(ARRAY[1,2,3], ARRAY[4,5]) {1,2,3,4,5} array_append(anyarray, anyelement) anyarray 向一个数组末尾附加一个元素 array_append(ARRAY[1,2], 3) {1,2,3} array_prepend(anyelement, anyarray) anyarray 向一个数组开头附加一个元素 array_prepend(1, ARRAY[2,3]) {1,2,3} array_dims(anyarray) text 返回一个数组维数的文本表示 array_dims(ARRAY[[1,2,3], [4,5,6]]) [1:2][1:3] array_lower(anyarray, int) int 返回指定的数组维数的下界 array_lower(array_prepend(0, ARRAY[1,2,3]), 1) 0 array_upper(anyarray, int) int 返回指定数组维数的上界 array_upper(ARRAY[1,2,3,4], 1) 4 array_to_string(anyarray, text) text 使用提供的分隔符连接数组元素 array_to_string(ARRAY[1, 2, 3], '~^~') 1~^~2~^~3 string_to_array(text, text) text[] 使用指定的分隔符把字串拆分成数组元素 string_to_array('xx~^~yy~^~zz', '~^~') {xx,yy,zz}
十二、系统信息函数:
1. PostgreSQL中提供的和数据库相关的函数列表:
名字
返回类型
描述
current_database()
name
当前数据库的名字
current_schema()
name
当前模式的名字
current_schemas(boolean)
name[]
在搜索路径中的模式名字
current_user
name
目前执行环境下的用户名
inet_client_addr()
inet
连接的远端地址
inet_client_port()
int
连接的远端端口
inet_server_addr()
inet
连接的本地地址
inet_server_port()
int
连接的本地端口
session_user
name
会话用户名
pg_postmaster_start_time()
timestamp
postmaster启动的时间
user
name
current_user
version()
text
PostgreSQL版本信息
2. 允许用户在程序里查询对象访问权限的函数:
名字 描述 可用权限 has_table_privilege(user,table,privilege) 用户是否有访问表的权限 SELECT/INSERT/UPDATE/DELETE/RULE/REFERENCES/TRIGGER has_table_privilege(table,privilege) 当前用户是否有访问表的权限 SELECT/INSERT/UPDATE/DELETE/RULE/REFERENCES/TRIGGER has_database_privilege(user,database,privilege) 用户是否有访问数据库的权限 CREATE/TEMPORARY has_database_privilege(database,privilege) 当前用户是否有访问数据库的权限 CREATE/TEMPORARY has_function_privilege(user,function,privilege) 用户是否有访问函数的权限 EXECUTE has_function_privilege(function,privilege) 当前用户是否有访问函数的权限 EXECUTE has_language_privilege(user,language,privilege) 用户是否有访问语言的权限 USAGE has_language_privilege(language,privilege) 当前用户是否有访问语言的权限 USAGE has_schema_privilege(user,schema,privilege) 用户是否有访问模式的权限 CREAT/USAGE has_schema_privilege(schema,privilege) 当前用户是否有访问模式的权限 CREAT/USAGE has_tablespace_privilege(user,tablespace,privilege) 用户是否有访问表空间的权限 CREATE has_tablespace_privilege(tablespace,privilege) 当前用户是否有访问表空间的权限 CREATE
注:以上函数均返回boolean类型。要评估一个用户是否在权限上持有赋权选项,给权限键字附加 WITH GRANT OPTION;比如 'UPDATE WITH GRANT OPTION'。
3. 模式可视性查询函数:
那些判断一个对象是否在当前模式搜索路径中可见的函数。 如果一个表所在的模式在搜索路径中,并且没有同名的表出现在搜索路径的更早的地方,那么就说这个表视可见的。 它等效于表可以不带明确模式修饰进行引用。
名字 描述 应用类型 pg_table_is_visible(table_oid) 该表/视图是否在搜索路径中可见 regclass pg_type_is_visible(type_oid) 该类/视图型是否在搜索路径中可见 regtype pg_function_is_visible(function_oid) 该函数是否在搜索路径中可见 regprocedure pg_operator_is_visible(operator_oid) 该操作符是否在搜索路径中可见 regoperator pg_opclass_is_visible(opclass_oid) 该操作符表是否在搜索路径中可见 regclass pg_conversion_is_visible(conversion_oid) 转换是否在搜索路径中可见 regoperator
注:以上函数均返回boolean类型,所有这些函数都需要对象 OID 标识作为检查的对象。
复制代码 代码如下:
postgres=# SELECT pg_table_is_visible('testtable'::regclass);
pg_table_is_visible
---------------------
t
(1 row)
4. 系统表信息函数:
名字 返回类型 描述 format_type(type_oid,typemod) text 获取一个数据类型的SQL名称 pg_get_viewdef(view_oid) text 为视图获取CREATE VIEW命令 pg_get_viewdef(view_oid,pretty_bool) text 为视图获取CREATE VIEW命令 pg_get_ruledef(rule_oid) text 为规则获取CREATE RULE命令 pg_get_ruledef(rule_oid,pretty_bool) text 为规则获取CREATE RULE命令 pg_get_indexdef(index_oid) text 为索引获取CREATE INDEX命令 pg_get_indexdef(index_oid,column_no,pretty_bool) text 为索引获取CREATE INDEX命令, 如果column_no不为零,则是只获取一个索引字段的定义 pg_get_triggerdef(trigger_oid) text 为触发器获取CREATE [CONSTRAINT] TRIGGER pg_get_constraintdef(constraint_oid) text 获取一个约束的定义 pg_get_constraintdef(constraint_oid,pretty_bool) text 获取一个约束的定义 pg_get_expr(expr_text,relation_oid) text 反编译一个表达式的内部形式,假设其中的任何Vars都引用第二个参数指出的关系 pg_get_expr(expr_text,relation_oid, pretty_bool) text 反编译一个表达式的内部形式,假设其中的任何Vars都引用第二个参数指出的关系 pg_get_userbyid(roleid) name 获取给出的ID的角色名 pg_get_serial_sequence(table_name,column_name) text 获取一个serial或者bigserial字段使用的序列名字 pg_tablespace_databases(tablespace_oid) setof oid 获取在指定表空间(OID表示)中拥有对象的一套数据库的OID的集合
这些函数大多数都有两个变种,其中一个可以选择对结果的"漂亮的打印"。 漂亮打印的格式更容易读,但是缺省的格式更有可能被将来的PostgreSQL版本用同样的方法解释;如果是用于转储,那么尽可能避免使用漂亮打印。 给漂亮打印参数传递false生成的结果和那个没有这个参数的变种生成的结果完全一样。
十三、系统管理函数:
1. 查询以及修改运行时配置参数的函数:
名字 返回类型 描述 current_setting(setting_name) text 当前设置的值 set_config(setting_name,new_value,is_local) text 设置参数并返回新值
current_setting用于以查询形式获取setting_name设置的当前数值。它和SQL命令SHOW是等效的。 比如:
复制代码 代码如下:
MyTest=# SELECT current_setting('datestyle');
current_setting
-----------------
ISO, YMD
(1 row)
set_config将参数setting_name设置为new_value。如果is_local设置为true,那么新数值将只应用于当前事务。如果你希望新的数值应用于当前会话,那么应该使用false。它等效于SQL命令SET。比如:
复制代码 代码如下:
MyTest=# SELECT set_config('log_statement_stats','off', false);
set_config
------------
off
(1 row)
2. 数据库对象尺寸函数:
名字 返回类型 描述 pg_tablespace_size(oid) bigint 指定OID代表的表空间使用的磁盘空间 pg_tablespace_size(name) bigint 指定名字的表空间使用的磁盘空间 pg_database_size(oid) bigint 指定OID代表的数据库使用的磁盘空间 pg_database_size(name) bigint 指定名称的数据库使用的磁盘空间 pg_relation_size(oid) bigint 指定OID代表的表或者索引所使用的磁盘空间 pg_relation_size(text) bigint 指定名称的表或者索引使用的磁盘空间。这个名字可以用模式名修饰 pg_total_relation_size(oid) bigint 指定OID代表的表使用的磁盘空间,包括索引和压缩数据 pg_total_relation_size(text) bigint 指定名字的表所使用的全部磁盘空间,包括索引和压缩数据。表名字可以用模式名修饰。 pg_size_pretty(bigint) text 把字节计算的尺寸转换成一个人类易读的尺寸单位
3. 数据库对象位置函数:
名字
返回类型
描述
pg_relation_filenode(relationregclass)
oid
获取指定对象的文件节点编号(通常为对象的oid值)。
pg_relation_filepath(relationregclass)
text
获取指定对象的完整路径名。
复制代码 代码如下:
mydatabase=# select pg_relation_filenode('testtable');
pg_relation_filenode
----------------------
17877
(1 row)
mydatabase=# select pg_relation_filepath('testtable');
pg_relation_filepath
----------------------------------------------
pg_tblspc/17633/PG_9.1_201105231/17636/17877
(1 row)
该博客中提供的所有信息均源自PostgreSQL官方文档,编写该篇博客的主要目的是便于今后的查阅,特此声明。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】