Oracle与PostgreSQL的NULL和索引使用区别是什么
发表于:2025-02-01 作者:千家信息网编辑
千家信息网最后更新 2025年02月01日,这篇文章主要讲解了"Oracle与PostgreSQL的NULL和索引使用区别是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Oracle与Pos
千家信息网最后更新 2025年02月01日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安全错误
数据库的锁怎样保障安全
网络安全法律常识基本知识
自学网络安全
监控远程服务器
合肥热途互联网科技服务
三元组数据库 图原生
大创软件开发论文
浙江pdu服务器专用电源购买
软件开发项目合作框架
蚂蚁金服网络技术有限公司总监
小学生网络安全知识文字
单节点数据库升级rac
长城科技服务器部门加班多吗
曜石服务器
数据库后缀名改了可以看吗
网络安全与网络弹性的区别
excel邮票管理数据库
万易互联网络科技有限公司
火车头数据库发布教程
湛江社交软件开发方案
云同步无法连接服务器是怎么回事
卡丁车视频软件开发
服务器网卡硬件地址相同
同济大学数据库第二章作业
给网络安全上把锁
湖北ukey服务器地址
平顶山软件开发技巧
docker 直播服务器
网络安全法立法的主要任务
网络安全知识内容应如何去做
美魅网络技术