真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

如何正確的使用oracle索引-創(chuàng)新互聯(lián)

如何正確的使用oracle索引?相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

站在用戶的角度思考問(wèn)題,與客戶深入溝通,找到武侯網(wǎng)站設(shè)計(jì)與武侯網(wǎng)站推廣的解決方案,憑借多年的經(jīng)驗(yàn),讓設(shè)計(jì)與互聯(lián)網(wǎng)技術(shù)結(jié)合,創(chuàng)造個(gè)性化、用戶體驗(yàn)好的作品,建站類型包括:網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣、國(guó)際域名空間、虛擬空間、企業(yè)郵箱。業(yè)務(wù)覆蓋武侯地區(qū)。

1. 隨機(jī)數(shù)據(jù)生成代碼分析

--為測(cè)試索引而準(zhǔn)備的隨機(jī)數(shù)據(jù)生成代碼,先分析一下
select rownum as id,
     'smith'||trunc(dbms_random.value(0, 100)) as stu_name,
     dbms_random.string('x', 20) stu_pwd,
     to_char(add_months(sysdate,-DBMS_RANDOM.VALUE(100,200)) + rownum / 24 / 3600, 'yyyy-mm-dd hh34:mi:ss') as birthday ,
     decode( TRUNC(DBMS_RANDOM.VALUE(1,5)),1,'湖南省',2,'湖北省',3,'江西省','北京市') as address
   from dual
   connect by level <= 100;

--先分析以下上面的代碼

-- 偽列:  rownum

--  dual   : 測(cè)試表

--   || 字符串聯(lián)接

--1. 測(cè)試生成100條記錄     connect by level<=100 :

--a、利用Oracle特有的“connect by”樹(shù)形連接語(yǔ)法生成測(cè)試記錄,“l(fā)evel <= 100”表示要生成100記錄;

--b、利用rownum虛擬列生成遞增的整數(shù)數(shù)據(jù);

--c、利用sysdate函數(shù)加一些簡(jiǎn)單運(yùn)算來(lái)生成日期數(shù)據(jù),本例中是每條記錄的時(shí)間加1秒;

--       add_months(sysdate,-DBMS_RANDOM.VALUE(100,200))   用當(dāng)前時(shí)間 減去   至少100個(gè)月,最多200個(gè)月,來(lái)生成生日

--d、利用dbms_random.value函數(shù)生成隨機(jī)的數(shù)值型數(shù)據(jù),都是double型,所以都加了 trunc(   )以截?cái)嘈?shù)位,本例中是生成0到100之間的隨機(jī)整數(shù);

--e、利用dbms_random.string函數(shù)生成隨機(jī)的字符型數(shù)據(jù),本例中是生成長(zhǎng)度為20的隨機(jī)字符串,字符串中可以包括字符或數(shù)字。

2. 生成測(cè)試表及數(shù)據(jù)

--2. 正式生成100W
drop table stu_test_100w; --如果原來(lái)有,則先刪除原來(lái)的表
 
--創(chuàng)建表及數(shù)據(jù)
create table stu_test_100w
as
select rownum as id,
     'smith'||trunc(dbms_random.value(0, 99)) as stu_name,
     dbms_random.string('x', 20) stu_pwd,
     to_char(add_months(sysdate,-DBMS_RANDOM.VALUE(100,200)) + rownum / 24 / 3600, 'yyyy-mm-dd hh34:mi:ss') as birthday ,
     decode( TRUNC(DBMS_RANDOM.VALUE(1,5)),1,'湖南省',2,'湖北省',3,'江西省','北京市') as address
   from dual
   connect by level <= 1000000; -- 生成 100w測(cè)試數(shù)據(jù)
-- 查看當(dāng)前用戶模式下所有的表 
select * from tab where tname='STU_TEST_100W';
--先執(zhí)行一次查詢, 注意查詢所用的時(shí)間,此時(shí)并沒(méi)有加入索引 
select * from stu_test_100w where stu_name='smith23';

執(zhí)行結(jié)果:

如何正確的使用oracle索引

以上是沒(méi)有用到索引時(shí)的執(zhí)行用時(shí)  6.781秒.

下面創(chuàng)建索引后,再用同一查詢來(lái)測(cè)試.

--********生成索引后,再執(zhí)行一次查詢
drop index index_student_test;
 
create index index_student_test
on stu_test_100w(stu_name);  --索引是針對(duì)某個(gè)表的某個(gè)列
 
--先執(zhí)行一次查詢, 注意查詢的時(shí)間,此時(shí)加入了索引 
select * from stu_test_100w where stu_name='smith23';

如何正確的使用oracle索引

為什么用了索引后時(shí)間查詢能還下降了呢????

分析如下:

  1. 索引生成的字段的值分存得太密集了,查看上面的代碼會(huì)發(fā)現(xiàn)我們stu_name只生成在了  smith0-99之間,即只有100種可能性, 對(duì)于100w數(shù)據(jù)則言,即每個(gè)名字都有約1w個(gè).

  2。 因?yàn)閿?shù)據(jù)太密集了,所以以上查詢的花的時(shí)間主要在1w條數(shù)據(jù)的顯示上, 所以我們可以觀察到不管是否用到了索引,都要共到6-7秒來(lái)顯示結(jié)果.

  3.  那為什么用了索引還慢一些呢?  這就與索引的存儲(chǔ)結(jié)構(gòu)有關(guān)系了.oracle默認(rèn)使用的是B樹(shù)索引, 當(dāng)使用索引列查詢時(shí),查詢必須先查看索引,通過(guò)索引去定位數(shù)據(jù),而咱們的數(shù)據(jù)分布又比較密集,所以使用索引所導(dǎo)致的時(shí)間損耗要大于直接磁盤(pán)搜索的時(shí)間.

那么如何解決呢?

隨機(jī)生成的姓名分布廣一些(這與真實(shí)的數(shù)據(jù)也一樣).  即將隨機(jī)生成代碼修改為     'smith'||trunc(dbms_random.value(0, 9999999)) as stu_name,

drop table stu_test_100w; --如果原來(lái)有,則先刪除原來(lái)的表
--重新生成表及隨機(jī)數(shù)據(jù),注意 stu_name列的取值范圍加大
create table stu_test_100w
as
select rownum as id,
     'smith'||trunc(dbms_random.value(0, 9999999)) as stu_name,
     dbms_random.string('x', 20) stu_pwd,
     to_char(add_months(sysdate,-DBMS_RANDOM.VALUE(100,200)) + rownum / 24 / 3600, 'yyyy-mm-dd hh34:mi:ss') as birthday ,
     decode( TRUNC(DBMS_RANDOM.VALUE(1,5)),1,'湖南省',2,'湖北省',3,'江西省','北京市') as address
   from dual
   connect by level <= 1000000; 
 
--先執(zhí)行一次查詢, 注意查詢的時(shí)間,此時(shí)并沒(méi)有加入索引 
select * from stu_test_100w where stu_name='smith8821228';

執(zhí)行結(jié)果如下:

如何正確的使用oracle索引

用時(shí) 0.312秒.

接著創(chuàng)建索引后,再測(cè)試同一個(gè)查詢

--********生成索引后,再執(zhí)行一次查詢
drop index index_student_test;
 
create index index_student_test
on stu_test_100w(stu_name);  --索引是針對(duì)某個(gè)表的某個(gè)列
--先執(zhí)行一次查詢, 注意查詢的時(shí)間,此時(shí)加入了索引 
select * from stu_test_100w where stu_name='smith8821228';

如何正確的使用oracle索引

使用索引后,同一個(gè)查詢只需0.015秒,在原來(lái)用時(shí)0.312的基礎(chǔ)下,下降了n倍.

看完上述內(nèi)容,你們掌握如何正確的使用oracle索引的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!


網(wǎng)站標(biāo)題:如何正確的使用oracle索引-創(chuàng)新互聯(lián)
網(wǎng)頁(yè)URL:http://weahome.cn/article/gjshi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部