Oracle与PostgreSQL的NULL和索引使用区别是什么
发表于:2025-11-08 作者:千家信息网编辑
千家信息网最后更新 2025年11月08日,这篇文章主要讲解了"Oracle与PostgreSQL的NULL和索引使用区别是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Oracle与Pos
千家信息网最后更新 2025年11月08日Oracle与PostgreSQL的NULL和索引使用区别是什么
这篇文章主要讲解了"Oracle与PostgreSQL的NULL和索引使用区别是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Oracle与PostgreSQL的NULL和索引使用区别是什么"吧!
Oracle在创建索引时,不会存储NULL值,而PostgreSQL在创建索引时则会存储NULL值.在查询时,如使用Column is null这样的条件查询,Oracle不会使用索引而PostgreSQL则会使用索引.
Oracle
插入数据,200w多行的数据,然后插入一行值为null的数据.
TEST-orcl@DESKTOP-V430TU3>create table tbl1(id int);Table created.TEST-orcl@DESKTOP-V430TU3>create global temporary table tmp(id int);Table created.TEST-orcl@DESKTOP-V430TU3>insert into tmp select rownum from dba_objects;133456 rows created.TEST-orcl@DESKTOP-V430TU3>insert into tmp select * from tmp;133455 rows created.TEST-orcl@DESKTOP-V430TU3>/266910 rows created.TEST-orcl@DESKTOP-V430TU3>/533820 rows created.TEST-orcl@DESKTOP-V430TU3>/1067640 rows created.TEST-orcl@DESKTOP-V430TU3>insert into tbl1 select * from tmp;2135296 rows created.TEST-orcl@DESKTOP-V430TU3>commit;Commit complete.TEST-orcl@DESKTOP-V430TU3>exec dbms_stats.gather_table_stats('TEST','TBL1',cascade=>true);PL/SQL procedure successfully completed.TEST-orcl@DESKTOP-V430TU3>select index_name,index_type,blevel,leaf_blocks,num_rows,status,distinct_keys from user_indexes where table_name='TBL1';INDEX_NAME INDEX_TYPE BLEVEL------------------------------ --------------------------- ----------LEAF_BLOCKS NUM_ROWS STATUS DISTINCT_KEYS----------- ---------- -------- -------------IDX_TBL1_ID NORMAL 2 4662 2103843 VALID 134688TEST-orcl@DESKTOP-V430TU3>insert into tbl1 values(null);1 row created.TEST-orcl@DESKTOP-V430TU3>commit;Commit complete.TEST-orcl@DESKTOP-V430TU3>TEST-orcl@DESKTOP-V430TU3>exec dbms_stats.gather_table_stats('TEST','TBL1',cascade=>true);PL/SQL procedure successfully completed.TEST-orcl@DESKTOP-V430TU3>select index_name,index_type,blevel,leaf_blocks,num_rows,status,distinct_keys from user_indexes where table_name='TBL1';INDEX_NAME INDEX_TYPE BLEVEL------------------------------ --------------------------- ----------LEAF_BLOCKS NUM_ROWS STATUS DISTINCT_KEYS----------- ---------- -------- -------------IDX_TBL1_ID NORMAL 2 4771 2152683 VALID 134688执行查询
TEST-orcl@DESKTOP-V430TU3>set autotrace on explainTEST-orcl@DESKTOP-V430TU3>select * from tbl1 where id is null; ID----------Execution Plan----------------------------------------------------------Plan hash value: 312383637--------------------------------------------------------------------------| Id | Operation | Name | Rows | Bytes | Cost (%CPU)| Time |--------------------------------------------------------------------------| 0 | SELECT STATEMENT | | 1 | 5 | 898 (2)| 00:00:11 ||* 1 | TABLE ACCESS FULL| TBL1 | 1 | 5 | 898 (2)| 00:00:11 |--------------------------------------------------------------------------Predicate Information (identified by operation id):--------------------------------------------------- 1 - filter("ID" IS NULL)TEST-orcl@DESKTOP-V430TU3>PostgreSQL
数据表tbl1结构与Oracle一致.
testdb=# insert into tbl1 select generate_series(1,100000);INSERT 0 100000testdb=# explain (analyze,verbose) select * from tbl1 where id is null; QUERY PLAN -------------------------------------------------------------------------------------------------------- Seq Scan on public.tbl1 (cost=0.00..1569.33 rows=11 width=4) (actual time=26.052..130.752 rows=1 loops=1) Output: id Filter: (tbl1.id IS NULL) Rows Removed by Filter: 110000 Planning Time: 1.403 ms Execution Time: 130.814 ms(6 rows)testdb=# create index idx_tb1_id on tbl1(id);CREATE INDEXtestdb=# explain (analyze,verbose) select * from tbl1 where id is null; QUERY PLAN -------------------------------------------------------------------------------------------------------- Index Only Scan using idx_tb1_id on public.tbl1 (cost=0.42..8.56 rows=4 width=4) (actual time=0.133..0.136 rows=1 loops=1) Output: id Index Cond: (tbl1.id IS NULL) Heap Fetches: 1 Planning Time: 1.512 ms Execution Time: 0.199 ms(6 rows)
使用id is null进行查询,使用的是Index Only Scan.
感谢各位的阅读,以上就是"Oracle与PostgreSQL的NULL和索引使用区别是什么"的内容了,经过本文的学习后,相信大家对Oracle与PostgreSQL的NULL和索引使用区别是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是,小编将为大家推送更多相关知识点的文章,欢迎关注!
索引
数据
查询
学习
内容
存储
一致
一行
就是
思路
情况
数据表
文章
更多
条件
知识
知识点
篇文章
结构
跟着
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
小学网络安全班会方案
网络技术与区块链
传奇世界数据库添加法师宝宝
怎么给自己的服务器加上资源包
服务器产品性能的组织实施方案
花旗银行软件开发工资
支付宝网络安全软件
手机网络安全宣传常识
软件开发工作室怎样
服务器需要连接显示屏么
房屋设计效果图软件开发
qq三国得陇望蜀服务器在哪
我的世界服务器怎么快速找地牢
怎么添加时间服务器
了解科技互联网的APP
按键精灵数据库查找
chart显示数据库数据
抖音不让我搜索太多让服务器休息
包头软件开发定制app
计算机网络技术的实验
商显数据库
数据库id隔离技术
吉林潮流软件开发价格检测中心
学哪个软件开发技术好找工作
宝安做商城软件开发哪家好
怀柔区节能软件开发服务咨询报价
软件开发学徒是真的吗
开源大数据库
天津正规软件开发过程检测中心
农行软件开发中心待遇怎样