Nulls first/last功能简介
Nulls first/last功能主要用于order by排序子句中,影响空值Null在排序结果中的位置。简单来说,Nulls first表示Null值在排序时一直排在所有值的前面,也就是处理order by a desc时PostgresQL执行器认为Null值大于所有值,而order by a或order by a asc时执行器认为Null值小于所有值,将Null值排在前面。Nulls last表示Null值在排序时一直排在所有值的后面,也就是处理order by a desc时PostgresQL执行器认为Null值小于所有值,而order by a或order by a asc时执行器认为Null值大于所有值,将Null值排在前面。当不指定Nulls first/last功能时,执行器默认认为Null值要大于所有值,以此为依据处理order by子句的排序结果。Nulls first/last功能简单展示
以下测试均为Postgres数据库下测试,数据库版本为9.2.2,测试系统为Linux。普通表简单功能展示:Create table test1(a int, b int);Insertinto test1 values(1,2);Insertinto test1 values(3,4);Insertinto test1 values(5);Select * from test1 order by b desc nulls first;a b53 41 2 Select * from test1 order by b desc nulls last;a b3 41 25 Select *from test1 order by b desc nulls; 报错 分区表简单功能展示,注意PostgresQL数据库建分区表的方式:createtable test_hash(a int, b int);createtable test_hash1(check(a>=0 and a<5)) inherits(test_hash);createtable test_hash2(check(a>=5)) inherits(test_hash); createrule test_hash_1 as on insert to test_hash where(a>=0 and a<5) do insteadinsert into test_hash1 values(NEW.a,NEW.b);createrule test_hash_2 as on insert to test_hash where(a>=5) do instead insertinto test_hash2 values(NEW.a,NEW.b); Insertinto test_hash values(1,2);Insertinto test_hash values(3,4);Insertinto test_hash values(5); Select *from test_hash order by b desc nulls first;a b53 42 2 Select *from test_hash order by b desc nulls last;a b3 41 25以上均是select语句中的order by子句进行的Nulls first/last功能展示,创建索引等其他需要order by子句的地方同理。这里只是简单的展示了一下功能,有时间会写一些剖析PostgresQL数据库的文章出来。复用Oracle数据字典解析出SQL语句中用到的所有表Oracle创建分区索引总结相关资讯 PostgreSQL教程
- PostgreSQL 列所有表结构的查询语 (02/18/2013 08:37:22)
- PostgreSQL模块——pg_stat_ (11/20/2012 19:27:31)
- PostgreSQL集群方案hot standby初 (07/10/2012 09:42:30)
| - 循序渐进PostgreSQL: 学习pqxx C++ (12/08/2012 11:25:13)
- PostgreSQL 堆分配器mmgr详解 (09/12/2012 09:33:05)
- PostgreSQL数据库压力测试工具 (07/09/2012 19:47:31)
|
本文评论 查看全部评论 (0)