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

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

?? optimizer.tcl

?? sqlite嵌入式數據庫源碼
?? 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一区二区三区免费野_久草精品视频
欧美午夜视频网站| 亚洲精品日日夜夜| 国产精品日韩精品欧美在线| 亚洲免费伊人电影| 国产又黄又大久久| 欧美在线一区二区| 国产精品视频麻豆| 韩国av一区二区三区| 欧美视频三区在线播放| 国产女人水真多18毛片18精品视频 | 欧美日韩国产色站一区二区三区| 精品欧美一区二区久久| 亚洲精品国久久99热| 精久久久久久久久久久| 欧美午夜精品电影| 中文字幕视频一区| 狠狠色丁香婷综合久久| 欧美美女视频在线观看| 一区二区三区在线视频观看| 国产一区二区三区av电影| 日韩一区二区视频| 亚洲一区二区三区视频在线播放 | 在线观看中文字幕不卡| 亚洲色图都市小说| 成人av电影观看| 久久久久免费观看| 久久99精品国产.久久久久久 | 国产欧美日韩综合精品一区二区| 日韩专区一卡二卡| 欧美亚洲国产一区在线观看网站| 中文字幕一区二区在线观看| 国产成人亚洲综合a∨婷婷| 欧美精品一区二区三| 麻豆91免费看| 欧美成人猛片aaaaaaa| 久久精品国产成人一区二区三区 | 欧美日韩在线播放一区| 一区二区三区av电影| 日本高清不卡aⅴ免费网站| 亚洲色图欧洲色图婷婷| 欧洲一区二区三区在线| 一区二区在线电影| 精品视频一区三区九区| 亚洲丰满少妇videoshd| 欧美日本一区二区在线观看| 青青青伊人色综合久久| 精品国产91乱码一区二区三区| 五月激情丁香一区二区三区| 欧美精品自拍偷拍| 狠狠色综合日日| 国产精品女主播av| 91首页免费视频| 首页国产欧美日韩丝袜| 欧美一卡2卡三卡4卡5免费| 久久99精品久久久久久国产越南| 精品国精品国产尤物美女| 国产成人精品一区二| 亚洲啪啪综合av一区二区三区| 欧美曰成人黄网| 久久激情五月婷婷| 欧美激情一区二区三区不卡 | 成人a区在线观看| 一区二区三区视频在线看| 欧美一区二区精品在线| 国产剧情一区二区三区| 一区二区三区国产豹纹内裤在线| 欧美丰满少妇xxxbbb| 国产精品99久久久久久有的能看 | 毛片基地黄久久久久久天堂| 久久综合色之久久综合| 色综合天天综合网天天看片| 日韩国产欧美三级| 国产精品久久久久9999吃药| 777色狠狠一区二区三区| 成人性生交大合| 五月婷婷久久丁香| 国产欧美一区在线| 制服丝袜亚洲色图| 成人免费av在线| 免费观看久久久4p| 亚洲素人一区二区| 欧美大片在线观看| 在线看不卡av| www.亚洲色图.com| 久久福利视频一区二区| 亚洲午夜久久久| 中文字幕在线一区免费| 欧美成人video| 欧美三级日韩三级| 成人黄动漫网站免费app| 蜜桃av一区二区| 亚洲一区日韩精品中文字幕| 国产精品视频免费| 日韩丝袜情趣美女图片| 欧美天天综合网| 91啪亚洲精品| 成人午夜伦理影院| 国产精品羞羞答答xxdd| 美国毛片一区二区| 日本午夜一区二区| 亚洲无人区一区| 亚洲午夜在线视频| 一区二区三区在线视频观看58| 国产女人18毛片水真多成人如厕 | 欧美v亚洲v综合ⅴ国产v| 欧美手机在线视频| 91国产福利在线| 99re在线精品| 欧美另类一区二区三区| 91香蕉视频在线| 精品一区二区三区av| 亚洲免费在线电影| 亚洲视频一二三区| 国产精品不卡一区| 理论片日本一区| 亚洲日本欧美天堂| 在线播放亚洲一区| 欧美性猛片aaaaaaa做受| 91精品国产免费| 国产精品成人午夜| 日本在线不卡视频一二三区| 国产白丝网站精品污在线入口| 在线免费观看日本欧美| 精品精品国产高清一毛片一天堂| 中文字幕五月欧美| 国产一区在线观看视频| 欧美中文字幕久久| 国产欧美一区二区三区沐欲| 亚洲高清久久久| 不卡视频在线看| 宅男在线国产精品| 亚洲精品日韩专区silk| 狠狠狠色丁香婷婷综合激情| 91蝌蚪国产九色| xfplay精品久久| 亚洲成人免费在线观看| 成人网在线播放| 欧美成人a在线| 午夜视频在线观看一区二区| 福利一区二区在线| 日韩一级欧美一级| 亚洲成人资源在线| 色综合久久久久综合体桃花网| 精品美女在线播放| 日韩精品高清不卡| 欧美日韩中文字幕一区| 中文字幕一区二区三区在线播放| 麻豆成人久久精品二区三区红| 色婷婷久久99综合精品jk白丝| 久久新电视剧免费观看| 免费成人在线观看| 欧美日韩一区成人| 一区二区在线观看av| 成人一级片在线观看| 久久只精品国产| 麻豆一区二区99久久久久| 欧美在线制服丝袜| 亚洲久草在线视频| 99精品欧美一区二区三区综合在线| 2014亚洲片线观看视频免费| 久草这里只有精品视频| 日韩精品一区在线| 蜜桃一区二区三区在线| 欧美一区二区三区不卡| 人人精品人人爱| 91精品国产免费| 男女激情视频一区| 日韩欧美国产系列| 美女在线观看视频一区二区| 制服丝袜亚洲网站| 免费高清在线一区| 精品国产一区二区精华| 国内外成人在线| 久久久噜噜噜久久中文字幕色伊伊| 久久精品国产精品亚洲红杏| 欧美精品一区男女天堂| 丁香婷婷综合网| 亚洲欧洲另类国产综合| 91日韩一区二区三区| 亚洲成人一区二区在线观看| 在线播放国产精品二区一二区四区| 亚洲成人av电影| 日韩一卡二卡三卡四卡| 国产毛片一区二区| 国产精品福利av | 欧美午夜精品一区二区三区 | 日本中文在线一区| 精品国内片67194| 国产精品2024| 亚洲四区在线观看| 欧美巨大另类极品videosbest | 国产精品黄色在线观看| 日本精品一级二级| 日日夜夜精品视频免费| 26uuu国产日韩综合| 成人app在线| 亚洲福中文字幕伊人影院| 日韩区在线观看| 国产.欧美.日韩| 亚洲成人在线观看视频|