Oracle与PostgreSQL的NULL和索引使用区别是什么
发表于:2024-11-19 作者:千家信息网编辑
千家信息网最后更新 2024年11月19日,这篇文章主要讲解了"Oracle与PostgreSQL的NULL和索引使用区别是什么",文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习"Oracle与Pos
千家信息网最后更新 2024年11月19日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安全错误
数据库的锁怎样保障安全
服务器删除一块硬盘
厦门搜企网络技术公司
仟佰互联网科技股份有限公司
oracle 数据库截取函数
话费清单软件开发
双路服务器值不值得购买
linux服务器开发端口
如何找到软件开发人员
微创网络技术股份有限公司新闻
戴尔电脑怎么找不到服务器
闵行区市场软件开发服务报价表
山东机电软件开发怎么样
华为安卓手机的数据库是什么
黄晟 网络安全 大轴 joe
网络技术的微信公众号
王牌竞速未能连接至服务器
网络技术类别的学校
服务器在菲律宾
网络安全不稳定怎么处理
有效数据库管理系统
软件开发结算税点
新税法软件开发服务费
excel sql数据库
access 数据库推送数据
阜新网络安全保卫大队
去银行科技还是互联网科技
订餐app数据库
疫情期间网络安全培训
杭州直销软件开发有哪些流程
电子商务做软件开发怎么样