亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > 綜合 > 正文

循序漸進講解Informix SQL的十一個技巧

2024-07-21 02:43:23
字體:
來源:轉載
供稿:網友
 

一、加快sql的執行速度

1.select 語句中使用sort,或join

如果你有排序和連接操作,你可以先select數據到一個臨時表中,然后再對臨時表進行處理。因為臨時表是建立在內存中,所以比建立在磁盤上表操作要快的多。

如:

SELECT time_records.*, case_name  FROM time_records, OUTER cases  WHERE time_records.client = "AA1000"  AND time_records.case_no = cases.case_no  ORDER BY time_records.case_no

這個語句返回34個經過排序的記錄,花費了5分鐘42秒。而:

SELECT time_records.*, case_name  FROM time_records, OUTER cases  WHERE time_records.client = "AA1000"  AND time_records.case_no = cases.case_no  INTO temp foo;  SELECT * from foo ORDER BY case_no  返回34條記錄,只花費了59秒。

2.使用not in 或者not exists 語句

下面的語句看上去沒有任何問題,但是可能執行的非常慢:

SELECT code FROM table1  WHERE code NOT IN ( SELECT code FROM table2 如果使用下面的方法: SELECT code, 0 flag  FROM table1  INTO TEMP tflag;  然后: UPDATE tflag SET flag = 1 WHERE code IN ( SELECT code  FROM table2  WHERE tflag.code = table2.code ; 然后: SELECT * FROM  tflag  WHERE flag = 0;

看上去也許要花費更長的時間,但是你會發現不是這樣。

事實上這種方式效率更快。有可能第一種方法也會很快,那是在對相關的每個字段都建立了索引的情況下,但是那顯然不是一個好的注意。

3.避免使用過多的“or"

如果有可能的話,盡量避免過多地使用or: WHERE a = "B" OR a = "C"

要比 WHERE a IN ("B","C") 慢。 有時甚至UNION會比OR要快。

4.使用索引

在所有的join和order by 的字段上建立索引。 在where中的大多數字段建立索引。

WHERE datecol >= "this/date" AND datecol <= "that/date"  要比  WHERE datecol BETWEEN "this/date" AND "that/date" 慢。

二、在shell腳本中使用一個sql查詢的結果

以下的是一個運行在sh/ksh下面的腳本。在online中,如果你想要更新一個有許多表的數據庫的統計信息。這個腳本不太好。因為這個腳本只能單個處理數據庫中的表,而不能同時處理大量的表。

例子:

# update_em  # Run UPDATE STATISTICS on a table by table basis  #  DATABASE=$1  if [ -z "$DATABASE" ]  then  echo "usage: update_em dbname" >&2  exit 1  fi  isql $DATABASE - < dev/null | isql $DATABASE -  output to pipe "cat" without headings  select "update statistics for table ", tabname, ";"  from systables where tabid >= 100 order by tabname;  EOF exit 0

也許你已經注意到exit的返回值對不同的isql不是都相同,因此這樣作不是很可靠,代替通過$?來檢查返回值的更好的主意是將標準錯誤重定向到一個文件中,然后在這個文件中grep “error"。例如:

# Generate the data  isql -qr <<!>stage.rep 2>$stage.err  database $database;  select ...  !  # Check for errors  if grep -i "error" $stage.err >/dev/null  then ...error_handler...  fi

三、對一個計算產生的字段創建視圖

應該這樣寫:

CREATE VIEW tst (cout) AS  SELECT ship_charge - totval  FROM orders WHERE ship_charge > 0;

四、只select 出數據庫中的部分數據(例如10%)

問題:如果你想要得到一個select 語句正常返回的數據的一部分,例如:

SELECT firstname, lastname, city, state  FROM bigdatabase  WHERE state = "TX"
 

回答: 有一個方法可以返回一個近似值,只需要在where后加上:AND rowid=(trunc(rowid/x)*x)

其中的x代表你想要返回的總的記錄的1/x。需要說明的是,這種方法只能返回一個近似的值,并且表中的數據在物理上分布的連續性。

五、創建一個表結構和永久表完全一致的臨時表。

例如:CREATE TEMP TABLE mytemp (PRodno LIKE

product.prodno desc LIKE product.desc)

你可以使用如下的語句:

SELECT prodno, desc FROM product  WHERE ROWID = -1  INSERT INTO TEMP mytemp

六、更改serial類型下一次插入操作產生的值

我們知道serial類型的字段是系統自動增加的整數字段,那么怎樣能控制下一個serial類型字段的值。想要下一個插入的serial類型的值比默認值大,可以用:

ALTER TABLE tabname MODIFY( ser_col_name SERIAL([new_start_number])

想要下一個插入的serial類型的值比默認的值要小,首先需要將serial類型重新置為1:

INSERT INTO table (serial_column) VALUES (2147483647);  INSERT INTO table (serial_column) VALUES (0); -- 重新從1開始!  ....然后執行ALTER TABLE(就像上面的做法一樣)。

七、在發生錯誤的時候終止sql腳本的執行

如果你創建了一個sql腳本,并且在UNIX命令行中使用以下的方式來執行這個腳本:

$ dbaccess <腳本文件名>

這時,腳本中的所有的sql語句都會被執行,即使其中的一個sql語句發生了錯誤。例如,如果你腳本中為如下的語句:

BEGIN WORK;  INSERT INTO history  SELECT *  FROM current  WHERE month = 11;  DELETE FROM current  WHERE month = 11;  COMMIT WORK;

如果INSERT語句失敗了,DELETE語句仍舊會繼續執行。直到commit work。這樣的后果可能會很嚴重。你可以通過設置一個環境變量來防止這種情況的發生。 DBACCNOIGN=1

八、設置decimal字段運算結果的精度

假定你使用dbaccess或者isql,設置環境變量DBFLTMASK=6 就可以設置為小數點后面6位,比如:

CREATE TEMP TABLE t  ( col_a DECIMAL(8,4) NOT NULL,  col_b DECIMAL(8,4) NOT NULL,  col_c DECIMAL(8,4) NOT NULL  );  INSERT INTO t VALUES(1.2345, 3.4567, 5.6789);  SELECT (col_a + col_b) / col_c AS value FROM t;  value 0.826075  如果DBFLTMASK=7 value 0.8260755
 

九、遇到sysprocplan表被鎖的提示

sysprocplan表是sysmaster庫中的一個表,其中記錄存儲過程經過優化的查詢計劃。每當查詢樹中的數據庫對象有任何結構上的變化,這個查詢計劃就會自動更新。如果對查詢樹中存在的任何表有update statistics操作,也會自動更新查詢計劃。在查詢計劃更新的時候,會對sysporcplan表中的相關記錄加鎖。

注意:每次你對一個表更新統計的時候,也同時會更新于這個表相關的存儲過程,即UPDATE STATISTICS FOR PROCEDURE 。

你可以作的另外一件事情就是:在存儲過程中使用SET OPTIMIZATION LOW,這會讓優化器在存儲過程運行的時候不會試圖去重新優化它。否則存儲過程通常都會被重新優化一次。

十、刪除掉表中重復的記錄

假設“keycol”字段的值唯一,而且沒有對表進行分片,并且沒有其它的人正在刪除"sometable"中的記錄,你可以執行如下的SQL:

delete from sometable as a  where rowid <> (select min(rowid) from sometable where keycol = a.keycol)

如果這個表使用表分片,rowid不存在,你還可以用如下的方法:

BEGIN WORK;  SELECT DISTINCT * FROM Table INTO TEMP Temp1;  DELETE FROM Table WHERE 1 = 1;  INSERT INTO Table SELECT * FROM Temp1;  COMMIT WORK;

對于規模較小或中等的表,并且你有足夠的存儲空間來存儲整個的臨時表的時候,這種方法通常十分有效。

十一、加快SELECT COUNT(DISTINCT)的速度

通?!癝ELECT COUNT(DISTINCT)”這樣的操作要花費比較長的時間,如果按照下面的示例去作:

SELECT UNIQUE xxx INTO TEMP XXX " 然后再"SELECT COUNT(*) FROM TEMP XXX"

此例一般可以提高幾倍的效率。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品91免费在线| 国产精品2018| 国产精品网址在线| 亚洲国产精品网站| 国产成人在线一区二区| 色偷偷综合社区| 国模私拍视频一区| 国产精品美女主播在线观看纯欲| 国产精品视频在线观看| 成人精品久久一区二区三区| 国产又爽又黄的激情精品视频| 在线观看久久av| 日韩精品在线播放| 国产剧情久久久久久| 亚州av一区二区| 亚洲欧美日韩第一区| 国产欧美精品日韩精品| 九九视频这里只有精品| 国产97免费视| 98午夜经典影视| 亚洲在线www| 久久99久国产精品黄毛片入口| 久久国产视频网站| 在线午夜精品自拍| 欧美丝袜一区二区| 日韩风俗一区 二区| 中文字幕国产精品| 中文字幕视频一区二区在线有码| 国产精品免费福利| 4438全国成人免费| 午夜精品99久久免费| 日韩麻豆第一页| 91精品视频网站| 国产精品久久久久久久午夜| 国产女同一区二区| 国产精品黄视频| 国产成人一区二区三区电影| 国产精品日韩在线一区| 日韩电影免费观看在线| 国产综合色香蕉精品| 热99在线视频| 麻豆成人在线看| 国产精品女主播视频| 亚洲一品av免费观看| 国产精品99久久99久久久二8| 欧洲中文字幕国产精品| 国产精品久久久久久搜索| 欧美另类在线观看| 欧美日韩国产一区中文午夜| 久久久999精品免费| 欧美日韩激情美女| 尤物tv国产一区| 亚洲国产日韩欧美在线图片| 久久这里有精品| 日韩av免费在线观看| 中文字幕日韩欧美在线| 欧美精品videossex88| 成人免费在线视频网站| 欧美高清视频免费观看| 亚洲石原莉奈一区二区在线观看| 欧美亚洲国产视频小说| 日韩一中文字幕| 久久久久久97| 成人黄色大片在线免费观看| 超薄丝袜一区二区| 国产精品一区二区电影| 亚洲无限乱码一二三四麻| 亚洲精品一区av在线播放| 亚洲娇小xxxx欧美娇小| 国产精品网址在线| 亚洲www在线观看| 中文字幕精品一区久久久久| 亚洲第一页在线| 2019av中文字幕| x99av成人免费| 国产日韩视频在线观看| 国产精品h在线观看| 97免费视频在线播放| 在线色欧美三级视频| 日韩免费观看在线观看| 欧美高清自拍一区| 亚洲福利视频网站| 一本一本久久a久久精品牛牛影视| 777午夜精品福利在线观看| 久久国产精品久久久| 色综合视频一区中文字幕| 久久亚洲影音av资源网| 日韩免费av一区二区| 自拍亚洲一区欧美另类| 日韩精品亚洲元码| 55夜色66夜色国产精品视频| 欧美激情精品久久久久久久变态| 91高潮精品免费porn| 日韩精品福利网站| 精品露脸国产偷人在视频| www.久久草.com| 欧美在线观看视频| 91色视频在线观看| 国产精品福利网| 亚洲国产精品999| 色诱女教师一区二区三区| 欧美伦理91i| 亚洲激情视频网站| 亚洲精品网址在线观看| 亚洲一区美女视频在线观看免费| 久久免费观看视频| 欧美裸体男粗大视频在线观看| 国产女人精品视频| 精品一区电影国产| 久久99精品久久久久久噜噜| 欧美激情三级免费| 亚洲伊人久久大香线蕉av| 日韩在线高清视频| 欧美成在线观看| 亚洲а∨天堂久久精品9966| 亚洲第一二三四五区| 精品视频久久久久久久| 欧美黑人巨大xxx极品| 国产自产女人91一区在线观看| 最近中文字幕mv在线一区二区三区四区| 一区国产精品视频| 综合国产在线观看| 国产精品久久久久不卡| 成人一区二区电影| 国产精品高潮呻吟久久av无限| 欧美在线国产精品| 免费不卡在线观看av| 欧美大片网站在线观看| 美女福利视频一区| 久久99青青精品免费观看| 欧美二区在线播放| 欧美日韩在线视频一区| 亚洲性69xxxbbb| 国产精品一区二区久久国产| 中日韩美女免费视频网址在线观看| 欧美综合国产精品久久丁香| 亚洲第一精品电影| 热99精品只有里视频精品| 国产亚洲精品久久| 九九热这里只有精品免费看| 精品日韩中文字幕| 国产精品1区2区在线观看| 国产视频精品免费播放| 欧美性猛交xxxx黑人猛交| 亚洲午夜av久久乱码| 久国内精品在线| 久久成人国产精品| 亚洲午夜未满十八勿入免费观看全集| 91在线免费网站| 黑人巨大精品欧美一区二区| 亚洲国产精品推荐| 日韩精品视频在线| 日韩av在线网站| 清纯唯美亚洲综合| 欧美资源在线观看| 日韩精品在线视频美女| 在线播放精品一区二区三区| 91久久久亚洲精品| 7m精品福利视频导航| 精品av在线播放| 91色琪琪电影亚洲精品久久| 92福利视频午夜1000合集在线观看| 亚洲欧美日韩另类| 欧美日韩国产成人在线|