亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? optimizer.tcl

?? 嵌入式數據庫SQLITE,含移植到ARM_LINUX的說明
?? TCL
字號:
## Run this TCL script to generate HTML for the goals.html file.#set rcsid {$Id: optimizer.tcl,v 1.1 2005/08/30 22:44:06 drh Exp $}source common.tclheader {The SQLite Query Optimizer}proc CODE {text} {  puts "<blockquote><pre>"  puts $text  puts "</pre></blockquote>"}proc IMAGE {name {caption {}}} {  puts "<center><img src=\"$name\">"  if {$caption!=""} {    puts "<br>$caption"  }  puts "</center>"}proc PARAGRAPH {text} {  puts "<p>$text</p>\n"}proc HEADING {level name} {  puts "<h$level>$name</h$level>"}HEADING 1 {The SQLite Query Optimizer}PARAGRAPH {  This article describes how the SQLite query optimizer works.  This is not something you have to know in order to use SQLite - many  programmers use SQLite successfully without the slightest hint of what  goes on in the inside.  But a basic understanding of what SQLite is doing  behind the scenes will help you to write more efficient SQL.  And the  knowledge gained by studying the SQLite query optimizer has broad  application since most other relational database engines operate   similarly.  A solid understanding of how the query optimizer works is also  required before making meaningful changes or additions to the SQLite, so   this article should be read closely by anyone aspiring  to hack the source code.}HEADING 2 BackgroundPARAGRAPH {  It is important to understand that SQL is a programming language.  SQL is a perculiar programming language in that it  describes <u>what</u> the programmer wants to compute not <u>how</u>  to compute it as most other programming languages do.  But perculiar or not, SQL is still just a programming language.}PARAGRAPH {  It is very helpful to think of each SQL statement as a separate  program.  An important job of the SQL database engine is to translate each  SQL statement from its descriptive form that specifies what the  information is desired (the <u>what</u>)   into a procedural form that specifies how to go  about acquiring the desired information (the <u>how</u>).  The task of translating the <u>what</u> into a   <u>how</u> is assigned to the query optimizer.}PARAGRAPH {  The beauty of SQL comes from the fact that the optimizer frees the programmer  from having to worry over the details of <u>how</u>.  The programmer  only has to specify the <u>what</u> and then leave the optimizer  to deal with all of the minutae of implementing the  <u>how</u>.  Thus the programmer is able to think and work at a  much higher level and leave the optimizer to stress over the low-level  work.}HEADING 2 {Database Layout}PARAGRAPH {  An SQLite database consists of one or more "b-trees".  Each b-tree contains zero or more "rows".   A single row contains a "key" and some "data".  In general, both the key and the data are arbitrary binary  data of any length.  The keys must all be unique within a single b-tree.  Rows are stored in order of increasing key values - each  b-tree has a comparision functions for keys that determines  this order.}PARAGRAPH {  In SQLite, each SQL table is stored as a b-tree where the  key is a 64-bit integer and the data is the content of the  table row.  The 64-bit integer key is the ROWID.  And, of course,  if the table has an INTEGER PRIMARY KEY, then that integer is just  an alias for the ROWID.}PARAGRAPH {  Consider the following block of SQL code:}CODE {  CREATE TABLE ex1(     id INTEGER PRIMARY KEY,     x  VARCHAR(30),     y  INTEGER  );  INSERT INTO ex1 VALUES(NULL,'abc',12345);  INSERT INTO ex1 VALUES(NULL,456,'def');  INSERT INTO ex1 VALUES(100,'hello','world');  INSERT INTO ex1 VALUES(-5,'abc','xyz');  INSERT INTO ex1 VALUES(54321,NULL,987);}PARAGRAPH {  This code generates a new b-tree (named "ex1") containing 5 rows.  This table can be visualized as follows:}IMAGE table-ex1b2.gifPARAGRAPH {  Note that the key for each row if the b-tree is the INTEGER PRIMARY KEY  for that row.  (Remember that the INTEGER PRIMARY KEY is just an alias  for the ROWID.)  The other fields of the table form the data for each  entry in the b-tree.  Note also that the b-tree entries are in ROWID order  which is different from the order that they were originally inserted.}PARAGRAPH {  Now consider the following SQL query:}CODE {  SELECT y FROM ex1 WHERE x=456;}PARAGRAPH {  When the SQLite parser and query optimizer are handed this query, they  have to translate it into a procedure that will find the desired result.  In this case, they do what is call a "full table scan".  They start  at the beginning of the b-tree that contains the table and visit each  row.  Within each row, the value of the "x" column is tested and when it  is found to match 456, the value of the "y" column is output.  We can represent this procedure graphically as follows:}IMAGE fullscanb.gifPARAGRAPH {  A full table scan is the access method of last resort.  It will always  work.  But if the table contains millions of rows and you are only looking  a single one, it might take a very long time to find the particular row  you are interested in.  In particular, the time needed to access a single row of the table is  proportional to the total number of rows in the table.  So a big part of the job of the optimizer is to try to find ways to   satisfy the query without doing a full table scan.}PARAGRAPH {  The usual way to avoid doing a full table scan is use a binary search  to find the particular row or rows of interest in the table.  Consider the next query which searches on rowid instead of x:}CODE {  SELECT y FROM ex1 WHERE rowid=2;}PARAGRAPH {  In the previous query, we could not use a binary search for x because  the values of x were not ordered.  But the rowid values are ordered.  So instead of having to visit every row of the b-tree looking for one  that has a rowid value of 2, we can do a binary search for that particular  row and output its corresponding y value.  We show this graphically  as follows:}IMAGE direct1b.gifPARAGRAPH {  When doing a binary search, we only have to look at a number of  rows with is proportional to the logorithm of the number of entries  in the table.  For a table with just 5 entires as in the example above,  the difference between a full table scan and a binary search is  negligible.  In fact, the full table scan might be faster.  But in  a database that has 5 million rows, a binary search will be able to  find the desired row in only about 23 tries, whereas the full table  scan will need to look at all 5 million rows.  So the binary search  is about 200,000 times faster in that case.}PARAGRAPH {  A 200,000-fold speed improvement is huge.  So we always want to do  a binary search rather than a full table scan when we can.}PARAGRAPH {  The problem with a binary search is that the it only works if the  fields you are search for are in sorted order.  So we can do a binary  search when looking up the rowid because the rows of the table are  sorted by rowid.  But we cannot use a binary search when looking up  x because the values in the x column are in no particular order.}PARAGRAPH {  The way to work around this problem and to permit binary searching on  fields like x is to provide an index.  An index is another b-tree.  But in the index b-tree the key is not the rowid but rather the field  or fields being indexed followed by the rowid.  The data in an index b-tree is empty - it is not needed or used.  The following diagram shows an index on the x field of our example table:}IMAGE index-ex1-x-b.gifPARAGRAPH {  An important point to note in the index are that they keys of the  b-tree are in sorted order.  (Recall that NULL values in SQLite sort  first, followed by numeric values in numerical order, then strings, and  finally BLOBs.)  This is the property that will allow use to do a  binary search for the field x.  The rowid is also included in every  key for two reasons.  First, by including the rowid we guarantee that  every key will be unique.  And second, the rowid will be used to look  up the actual table entry after doing the binary search.  Finally, note  that the data portion of the index b-tree serves no purpose and is thus  kept empty to save space in the disk file.}PARAGRAPH {  Remember what the original query example looked like:}CODE {  SELECT y FROM ex1 WHERE x=456;}PARAGRAPH {  The first time this query was encountered we had to do a full table  scan.  But now that we have an index on x, we can do a binary search  on that index for the entry where x==456.  Then from that entry we  can find the rowid value and use the rowid to look up the corresponding  entry in the original table.  From the entry in the original table,  we can find the value y and return it as our result.  The following  diagram shows this process graphically:}IMAGE indirect1b1.gifPARAGRAPH {  With the index, we are able to look up an entry based on the value of  x after visiting only a logorithmic number of b-tree entries.  Unlike  the case where we were searching using rowid, we have to do two binary  searches for each output row.  But for a 5-million row table, that is  still only 46 searches instead of 5 million for a 100,000-fold speedup.}HEADING 3 {Parsing The WHERE Clause}# parsing the where clause# rowid lookup# index lookup# index lookup without the table# how an index is chosen# joins# join reordering# order by using an index# group by using an index# OR -> IN optimization# Bitmap indices# LIKE and GLOB optimization# subquery flattening# MIN and MAX optimizations

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产女同互慰高潮91漫画| 国产剧情一区二区| 国产欧美精品在线观看| 8x8x8国产精品| 欧美日韩综合一区| 欧美网站大全在线观看| 欧美在线观看你懂的| 欧洲一区在线电影| 一区二区三区日韩精品视频| 国产精品午夜在线| 国产精品不卡视频| 亚洲精品国产第一综合99久久| 亚洲天堂2014| 亚洲一二三区在线观看| 日韩精品每日更新| 精品伊人久久久久7777人| 国产毛片一区二区| 99久久er热在这里只有精品66| 日本高清免费不卡视频| 7777精品伊人久久久大香线蕉超级流畅 | 在线不卡中文字幕| 日韩三级免费观看| 久久久99精品免费观看不卡| 自拍视频在线观看一区二区| 亚洲一二三四久久| 国产一区二区三区综合| 在线中文字幕不卡| 欧美大片顶级少妇| 亚洲日本va在线观看| 日本亚洲欧美天堂免费| 成人免费视频免费观看| 欧美三级日韩在线| 国产日韩av一区| 午夜精品123| 懂色av一区二区夜夜嗨| 欧美日韩一区二区三区不卡| 久久久午夜精品| 亚洲午夜日本在线观看| 国产成人在线免费观看| 欧美色成人综合| 亚洲国产成人自拍| 日韩av电影一区| 91玉足脚交白嫩脚丫在线播放| 欧美一卡二卡三卡| 亚洲精品亚洲人成人网在线播放| 精品一区二区成人精品| 欧美午夜一区二区三区| 中文字幕欧美日韩一区| 精品一区二区三区香蕉蜜桃| 欧美少妇bbb| 国产精品理论片在线观看| 久久97超碰国产精品超碰| 在线亚洲+欧美+日本专区| 国产区在线观看成人精品| 麻豆精品视频在线观看免费| 欧亚洲嫩模精品一区三区| 国产精品久久久久9999吃药| 国产一区在线观看视频| 91精品久久久久久蜜臀| 亚洲美女在线国产| 成人av在线一区二区三区| 久久网这里都是精品| 日精品一区二区| 欧美日韩国产美| 一区二区三区蜜桃网| aa级大片欧美| 国产精品网站在线| 国产精品亚洲一区二区三区妖精| 91 com成人网| 青青草91视频| 在线91免费看| 日本怡春院一区二区| 欧美三级电影在线看| 亚洲国产日日夜夜| 欧美在线你懂的| 亚洲一区二区偷拍精品| 日本韩国欧美一区| 亚洲大片精品永久免费| 欧美日韩三级在线| 天堂成人国产精品一区| 欧美一级理论性理论a| 日韩成人精品在线| 日韩免费一区二区| 狠狠色丁香婷婷综合| 久久久久久久久久久久久久久99 | 亚洲一二三四久久| 欧美日韩精品一区二区三区蜜桃| 亚洲中国最大av网站| 欧美精品色一区二区三区| 天天射综合影视| 日韩欧美亚洲国产另类| 国产乱国产乱300精品| 国产偷国产偷亚洲高清人白洁| 国产成人在线观看免费网站| 亚洲欧洲另类国产综合| 欧美性色黄大片| 蜜臀久久久久久久| 欧美国产精品专区| 日本高清无吗v一区| 爽爽淫人综合网网站| 精品国产一区二区三区四区四 | 五月天一区二区| 精品粉嫩超白一线天av| 成人免费高清在线| 亚洲午夜精品久久久久久久久| 精品久久久影院| 色综合婷婷久久| 久久国产精品99久久人人澡| 中日韩av电影| 日韩天堂在线观看| eeuss鲁片一区二区三区在线看| 亚洲一区日韩精品中文字幕| 欧美videossexotv100| 99久久国产免费看| 久久国产福利国产秒拍| 亚洲欧美韩国综合色| 精品三级在线看| 日本韩国欧美国产| 国产91露脸合集magnet| 亚洲高清免费一级二级三级| 中文字幕欧美激情一区| 欧美一区二区视频网站| 成人h动漫精品一区二区| 奇米综合一区二区三区精品视频| 中文字幕一区二区三区在线播放| 制服丝袜av成人在线看| 91麻豆精品在线观看| 国产激情一区二区三区桃花岛亚洲| 亚洲在线观看免费| 中文字幕成人av| 欧美成人三级电影在线| 欧美婷婷六月丁香综合色| 91在线视频官网| 国产精品18久久久| 久久69国产一区二区蜜臀| 亚洲成人av免费| 一区二区三区免费在线观看| 亚洲日韩欧美一区二区在线| 国产欧美日韩精品a在线观看| 日韩欧美一区电影| 91麻豆精品国产91久久久久 | 欧美激情一区在线| 久久久久一区二区三区四区| 日韩女优av电影| 91麻豆精品国产91久久久| 欧美亚日韩国产aⅴ精品中极品| 成人黄色777网| 成人高清视频在线| 99视频有精品| av电影一区二区| 91小视频在线观看| 色综合久久综合| 91丨porny丨户外露出| 不卡的电视剧免费网站有什么| 成人一二三区视频| 丰满放荡岳乱妇91ww| 国产.精品.日韩.另类.中文.在线.播放| 精品亚洲porn| 国产乱码精品一区二区三区忘忧草| 激情久久久久久久久久久久久久久久| 日韩高清不卡一区二区| 六月丁香婷婷久久| 国产在线不卡一卡二卡三卡四卡| 国内精品久久久久影院薰衣草| 久久爱另类一区二区小说| 久久99久久99精品免视看婷婷| 国内成人免费视频| www.在线欧美| 色综合av在线| 欧美一区二区三区电影| 久久影院视频免费| 亚洲欧洲日韩一区二区三区| 亚洲丝袜美腿综合| 日韩激情一二三区| 精彩视频一区二区| 99久久精品免费看国产免费软件| 91色九色蝌蚪| 欧美一区二区私人影院日本| 久久综合视频网| 国产精品久久久久久久久免费相片| 亚洲综合一区二区三区| 久久人人超碰精品| 国产色综合久久| 亚洲精品免费在线播放| 老司机一区二区| av一本久道久久综合久久鬼色| 在线一区二区视频| 久久久精品国产免大香伊 | 亚洲成人一区二区| 国产精品88av| 欧美亚洲国产一卡| 久久女同性恋中文字幕| 亚洲午夜久久久久中文字幕久| 久久电影网站中文字幕| 色综合久久久久综合体| 337p粉嫩大胆噜噜噜噜噜91av| 亚洲精品视频在线观看免费| 国产在线观看免费一区| 欧美精品久久99久久在免费线| 国产精品久久久爽爽爽麻豆色哟哟|