校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

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

oracle索引的測試實例代碼

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

前言

在測試oracle索引性能時大意了,沒有仔細分析數據特點,將情況特此記錄下來。 

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

1. 隨機數據生成代碼分析

--為測試索引而準備的隨機數據生成代碼,先分析一下
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   : 測試表

--   || 字符串聯接

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

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

--b、利用rownum虛擬列生成遞增的整數數據;

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

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

--d、利用dbms_random.value函數生成隨機的數值型數據,都是double型,所以都加了 trunc(   )以截斷小數位,本例中是生成0到100之間的隨機整數;

--e、利用dbms_random.string函數生成隨機的字符型數據,本例中是生成長度為20的隨機字符串,字符串中可以包括字符或數字。

2. 生成測試表及數據

--2. 正式生成100W
drop table stu_test_100w; --如果原來有,則先刪除原來的表
 
--創(chuàng)建表及數據
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測試數據
-- 查看當前用戶模式下所有的表 
select * from tab where tname='STU_TEST_100W';
--先執(zhí)行一次查詢, 注意查詢所用的時間,此時并沒有加入索引 
select * from stu_test_100w where stu_name='smith13'; 

執(zhí)行結果: 

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

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

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

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

分析如下: 

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

  2。 因為數據太密集了,所以以上查詢的花的時間主要在1w條數據的顯示上, 所以我們可以觀察到不管是否用到了索引,都要共到6-7秒來顯示結果. 

  3.  那為什么用了索引還慢一些呢?  這就與索引的存儲結構有關系了.oracle默認使用的是B樹索引, 當使用索引列查詢時,查詢必須先查看索引,通過索引去定位數據,而咱們的數據分布又比較密集,所以使用索引所導致的時間損耗要大于直接磁盤搜索的時間.  

那么如何解決呢?

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

drop table stu_test_100w; --如果原來有,則先刪除原來的表
--重新生成表及隨機數據,注意 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í)行一次查詢, 注意查詢的時間,此時并沒有加入索引 
select * from stu_test_100w where stu_name='smith8821228'; 

執(zhí)行結果如下:

用時 0.312秒. 

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

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

使用索引后,同一個查詢只需0.015秒,在原來用時0.312的基礎下,下降了n倍.  

總結

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

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

標簽:柳州 銀川 泰安 南陽 河源 酒泉 焦作 梧州

巨人網絡通訊聲明:本文標題《oracle索引的測試實例代碼》,本文關鍵詞  oracle,索引,的,測試,實例,;如發(fā)現本文內容存在版權問題,煩請?zhí)峁┫嚓P信息告之我們,我們將及時溝通與處理。本站內容系統(tǒng)采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《oracle索引的測試實例代碼》相關的同類信息!
  • 本頁收集關于oracle索引的測試實例代碼的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 丽水市| 滦南县| 商水县| 焦作市| 清河县| 沅江市| 岳阳市| 琼结县| 阿尔山市| 浮梁县| 罗江县| 简阳市| 临安市| 公安县| 新巴尔虎左旗| 阿克苏市| 麻阳| 卫辉市| 榆中县| 清新县| 监利县| 安图县| 奉节县| 曲沃县| 宁化县| 巴林右旗| 吉木萨尔县| 富宁县| 潮州市| 论坛| SHOW| 德兴市| 灵石县| 盐城市| 江孜县| 孝昌县| 信宜市| 峨眉山市| 军事| 长白| 泰和县|