婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識(shí)庫 > oracle索引的測試實(shí)例代碼

oracle索引的測試實(shí)例代碼

熱門標(biāo)簽:杭州網(wǎng)絡(luò)外呼系統(tǒng)運(yùn)營商 電銷套路機(jī)器人 安陽企業(yè)電銷機(jī)器人供應(yīng)商 網(wǎng)貸外呼系統(tǒng)合法嗎 地圖標(biāo)注效果的制作 汽車4s店百度地圖標(biāo)注店 鶴壁電話機(jī)器人價(jià)格 手機(jī)地圖標(biāo)注門店 地圖標(biāo)注坐標(biāo)圖標(biāo)

前言

在測試oracle索引性能時(shí)大意了,沒有仔細(xì)分析數(shù)據(jù)特點(diǎn),將情況特此記錄下來。 

需求:  對(duì)一張100w記錄的表的 stuname列進(jìn)行查詢,測試在建立索引與不建立索引的區(qū)別. 以下是開始用的創(chuàng)建代碼及執(zhí)行效果. 

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

--為測試索引而準(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 hh24:mi:ss') as birthday ,
     decode( TRUNC(DBMS_RANDOM.VALUE(1,5)),1,'湖南省',2,'湖北省',3,'江西省','北京市') as address
   from dual
   connect by level = 100; 

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

-- 偽列:  rownum

--  dual   : 測試表

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

--1. 測試生成100條記錄     connect by level=100 : 

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

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

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

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

--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ù),本例中是生成長度為20的隨機(jī)字符串,字符串中可以包括字符或數(shù)字。

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

--2. 正式生成100W
drop table stu_test_100w; --如果原來有,則先刪除原來的表
 
--創(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 hh24:mi:ss') as birthday ,
     decode( TRUNC(DBMS_RANDOM.VALUE(1,5)),1,'湖南省',2,'湖北省',3,'江西省','北京市') as address
   from dual
   connect by level = 1000000; -- 生成 100w測試數(shù)據(jù)
-- 查看當(dāng)前用戶模式下所有的表 
select * from tab where tname='STU_TEST_100W';
--先執(zhí)行一次查詢, 注意查詢所用的時(shí)間,此時(shí)并沒有加入索引 
select * from stu_test_100w where stu_name='smith13'; 

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

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

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

--********生成索引后,再執(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='smith13';  

為什么用了索引后時(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秒來顯示結(jié)果. 

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

那么如何解決呢?

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

drop table stu_test_100w; --如果原來有,則先刪除原來的表
--重新生成表及隨機(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 hh24: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í)并沒有加入索引 
select * from stu_test_100w where stu_name='smith8821228'; 

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

用時(shí) 0.312秒. 

接著創(chuàng)建索引后,再測試同一個(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';  

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

總結(jié)

到此這篇關(guān)于oracle索引測試的文章就介紹到這了,更多相關(guān)oracle索引測試內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

您可能感興趣的文章:
  • oracle數(shù)據(jù)庫關(guān)于索引建立及使用的詳細(xì)介紹
  • Oracle Index索引無效的原因與解決方法
  • oracle使用索引與不使用索引的性能詳析
  • ORACLE檢查找出損壞索引(Corrupt Indexes)的方法詳解
  • Oracle復(fù)合索引與空值的索引使用問題小結(jié)
  • oracle分區(qū)索引的失效和重建代碼示例
  • Oracle關(guān)于重建索引爭論的總結(jié)
  • Oracle 分區(qū)索引介紹和實(shí)例演示
  • Oracle CBO優(yōu)化模式中的5種索引訪問方法淺析
  • oracle索引總結(jié)

標(biāo)簽:柳州 銀川 泰安 南陽 河源 酒泉 焦作 梧州

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《oracle索引的測試實(shí)例代碼》,本文關(guān)鍵詞  oracle,索引,的,測試,實(shí)例,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《oracle索引的測試實(shí)例代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于oracle索引的測試實(shí)例代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av
    美美哒免费高清在线观看视频一区二区 | 欧美一级在线观看| 国产精品99久| 成人午夜免费视频| 欧美视频在线观看一区二区| 综合分类小说区另类春色亚洲小说欧美| 欧美韩国日本不卡| 午夜精品福利久久久| 日韩精品每日更新| 国产精品传媒在线| 人人超碰91尤物精品国产| 在线播放日韩导航| 青青草国产成人99久久| 久久久亚洲精品一区二区三区 | 91精品国产一区二区三区香蕉| 国产欧美视频一区二区三区| 天涯成人国产亚洲精品一区av| 色综合久久久久网| 美国欧美日韩国产在线播放| 国产日产欧美一区二区视频| 日本黄色一区二区| 国产一区91精品张津瑜| 亚洲国产精品自拍| 日韩一区二区三区免费观看| av在线播放不卡| 麻豆免费精品视频| 亚洲欧美色一区| 久久久久久久久久久99999| 91亚洲精品久久久蜜桃网站| 国产精品影音先锋| 国产一区二区久久| 老鸭窝一区二区久久精品| 亚洲福中文字幕伊人影院| 亚洲一区二区三区四区在线免费观看 | 亚洲h在线观看| 亚洲视频一区在线| 欧美xxxxx牲另类人与| 欧美一区午夜视频在线观看| 97精品久久久久中文字幕| 国产成人免费视| 国产精品一色哟哟哟| 九色porny丨国产精品| 国产一本一道久久香蕉| 国产精华液一区二区三区| 国产精品一区免费在线观看| 石原莉奈在线亚洲三区| 日韩高清在线观看| 午夜视频在线观看一区| 国产成人在线网站| 东方欧美亚洲色图在线| 成人免费看黄yyy456| 91麻豆精品国产自产在线| 99精品视频在线播放观看| 日韩高清一级片| 国产三级一区二区| 欧美精品丝袜久久久中文字幕| 亚洲色图第一区| 欧美中文字幕久久| 亚洲自拍偷拍网站| 精品国产sm最大网站免费看| 色婷婷综合激情| 成人的网站免费观看| 国产成人精品亚洲777人妖| 风间由美一区二区av101| 色综合一区二区| 国产精品丝袜91| 亚洲激情中文1区| 国产精品久久三| 亚洲丝袜另类动漫二区| 中文字幕在线一区免费| 欧美日韩国产免费一区二区| 国产精品久久影院| 中文字幕亚洲一区二区av在线| 日本一区二区三区dvd视频在线 | 亚洲午夜在线观看视频在线| 亚洲午夜三级在线| 国产91丝袜在线18| 中文字幕av一区二区三区高| 日韩福利视频导航| 欧美一级搡bbbb搡bbbb| 在线观看亚洲a| 97精品电影院| 91麻豆精品一区二区三区| 4438x成人网最大色成网站| 国产精品小仙女| 99在线精品视频| 一本大道久久精品懂色aⅴ| 91色视频在线| 99re免费视频精品全部| 欧美在线视频不卡| 日韩美女天天操| 久久精品综合网| 午夜精品一区二区三区三上悠亚| 爽好久久久欧美精品| 国产精品18久久久久久久久久久久| 精品无人区卡一卡二卡三乱码免费卡| 精品一区二区三区在线播放| 丰满岳乱妇一区二区三区| 欧美久久久久久蜜桃| 国产精品私人影院| 日本中文字幕一区二区有限公司| 日韩成人伦理电影在线观看| 99麻豆久久久国产精品免费| 欧美成人乱码一区二区三区| 亚洲第一狼人社区| 91免费视频网| 成人免费在线视频| 国产一区二区三区国产| 欧美亚洲综合久久| 国产欧美精品日韩区二区麻豆天美| 亚洲高清中文字幕| 在线免费av一区| 99久精品国产| 国产成人在线色| 亚洲国产综合在线| 中文字幕在线观看一区| 欧美一激情一区二区三区| 亚洲自拍偷拍图区| 三级影片在线观看欧美日韩一区二区 | 美国av一区二区| 欧美日韩大陆一区二区| 亚洲动漫第一页| 91麻豆精品国产自产在线| 久久精品国产亚洲一区二区三区| 麻豆中文一区二区| 国产欧美精品国产国产专区| 成熟亚洲日本毛茸茸凸凹| 欧美经典一区二区| 欧美亚洲综合一区| 波多野结衣视频一区| 天天综合色天天综合| 国产精品久久午夜夜伦鲁鲁| 日本精品裸体写真集在线观看| 亚洲黄色尤物视频| 中文字幕一区二区三区精华液| 欧美日韩国产bt| 26uuu精品一区二区三区四区在线| 欧美成人精品福利| 一区二区三区四区蜜桃| 亚洲图片欧美视频| 精品一区在线看| 国产一区二区三区四| 亚洲午夜激情网站| 一区二区成人在线视频| 国产日产欧美一区二区视频| 久久综合成人精品亚洲另类欧美 | 亚洲一区二区三区国产| 中文一区在线播放| 成人久久18免费网站麻豆| 日本不卡在线视频| 亚洲欧美日韩久久| gogogo免费视频观看亚洲一| 日本视频免费一区| 中国色在线观看另类| 国产精品乡下勾搭老头1| 蜜臀国产一区二区三区在线播放| 亚洲福利一二三区| 国产喷白浆一区二区三区| 欧美日本在线看| 激情综合五月婷婷| 亚洲成av人片在www色猫咪| 精品国产一区二区三区av性色| 91福利在线看| 99re热这里只有精品视频| 亚洲国产精品人人做人人爽| 久久亚洲捆绑美女| 欧美变态tickle挠乳网站| 精品少妇一区二区三区视频免付费 | 从欧美一区二区三区| 美女一区二区视频| 久久在线观看免费| 国产欧美日韩麻豆91| 国产精品三级电影| 亚洲人精品一区| 成人va在线观看| 成人美女视频在线看| 久久美女艺术照精彩视频福利播放 | 精品国产乱码久久| 亚洲精品菠萝久久久久久久| 亚洲午夜精品久久久久久久久| 一区二区三区欧美激情| 亚洲午夜久久久久中文字幕久| 国产午夜精品一区二区| 97精品电影院| 色综合久久久久网| 欧美性色aⅴ视频一区日韩精品| 777久久久精品| 亚洲国产另类av| 亚洲大尺度视频在线观看| 国产高清一区日本| 日韩欧美卡一卡二| 日韩欧美国产小视频| 国内精品嫩模私拍在线| 欧美国产激情二区三区| 亚洲男人天堂av网| 色综合天天在线| 午夜精品视频在线观看| 欧美精品免费视频| 国产做a爰片久久毛片| 国产精品丝袜一区|