Welcome 微信登录

首页 / 数据库 / MySQL / PostgresQL中的NUlls first/last功能

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)
表情: 姓名: 字数

版权所有©石家庄振强科技有限公司2024 冀ICP备08103738号-5 网站地图