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

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

?? optimizer.tcl

?? sqlite database for embed 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一区二区三区免费野_久草精品视频
国产精品美女久久久久aⅴ国产馆| 在线观看亚洲精品视频| 色婷婷av一区二区三区大白胸| 欧美一区二区视频在线观看2020| 欧美激情资源网| 精品写真视频在线观看| 91精品国产麻豆国产自产在线| 日本不卡视频在线| 日韩欧美色电影| 福利91精品一区二区三区| 中文字幕巨乱亚洲| 欧美中文字幕一区二区三区亚洲| 亚洲自拍都市欧美小说| 欧美羞羞免费网站| 久久66热偷产精品| 国产精品日日摸夜夜摸av| 在线国产电影不卡| 国产一区二区三区视频在线播放| 国产精品美女久久久久久久久久久| 国产精品自拍在线| 性久久久久久久久久久久| 精品欧美一区二区三区精品久久| 91免费看视频| 免费成人性网站| 亚洲国产视频在线| 亚洲色图在线播放| 欧美本精品男人aⅴ天堂| 欧美性videosxxxxx| 国产精品一区一区三区| 日本91福利区| 美女一区二区在线观看| 亚洲va中文字幕| 国产精品福利一区二区| 中文字幕av一区二区三区高 | 久久人人97超碰com| 色婷婷av一区二区三区之一色屋| 成人午夜av影视| 粉嫩高潮美女一区二区三区| 高清国产午夜精品久久久久久| 首页国产丝袜综合| 国产精品久久久一本精品| 日本伊人午夜精品| 日本aⅴ免费视频一区二区三区| 亚洲日本va午夜在线电影| 自拍视频在线观看一区二区| 久久精品亚洲乱码伦伦中文 | 欧美精品一区二区三区蜜臀| 3d成人动漫网站| 欧美日韩国产综合视频在线观看| 91精品国产色综合久久不卡电影 | 亚洲精品国产一区二区精华液| 亚洲日本在线a| 日本不卡在线视频| 成人免费va视频| 99久久综合国产精品| 欧美日韩成人综合在线一区二区| 欧美丝袜自拍制服另类| 欧美一区二区三区在线电影| 久久免费偷拍视频| 国产精品久久久久久久久免费桃花 | 91精品国产综合久久福利软件| 精品福利一二区| 亚洲欧美日韩国产一区二区三区| 青娱乐精品视频| 日本伦理一区二区| 精品少妇一区二区三区在线播放 | 91久久精品午夜一区二区| 久久久久国产精品免费免费搜索| 亚洲国产日韩av| 91麻豆高清视频| 中文字幕日韩av资源站| 欧美伊人久久久久久午夜久久久久| 91精品国产乱码久久蜜臀| 中文一区在线播放| 91麻豆免费看| 一区二区三区在线观看动漫| 亚洲在线观看免费| 91日韩精品一区| 中文字幕视频一区二区三区久| 另类小说一区二区三区| 精品久久99ma| 国产精品一二三区| 日本一区二区在线不卡| 精品无人码麻豆乱码1区2区| 91精品国产高清一区二区三区| 亚洲激情综合网| 欧美日韩精品一区视频| 日本aⅴ免费视频一区二区三区 | 欧美日韩国产高清一区二区三区 | 六月丁香综合在线视频| 亚洲欧美一区二区三区久本道91 | 欧美一区二区精品久久911| 成人avav影音| 曰韩精品一区二区| 欧美精品久久99| 久久久国际精品| 色综合久久久久综合99| 精品欧美一区二区三区精品久久| 日本特黄久久久高潮| 日韩欧美在线影院| 91美女蜜桃在线| 久久成人久久爱| 亚洲免费电影在线| 91麻豆精品国产91| 麻豆传媒一区二区三区| 国产日韩精品一区二区三区| 波多野结衣中文字幕一区二区三区| 中文字幕中文字幕中文字幕亚洲无线| 一本一本大道香蕉久在线精品| 午夜久久久久久电影| 国产精品久久久一区麻豆最新章节| 欧美性xxxxx极品少妇| 成人深夜视频在线观看| 韩国视频一区二区| 首页国产丝袜综合| 久久综合资源网| 精品乱人伦一区二区三区| 欧美一级淫片007| 色偷偷一区二区三区| 欧美性猛片xxxx免费看久爱| 欧美日韩激情在线| 91精品蜜臀在线一区尤物| 欧美狂野另类xxxxoooo| 欧美一区二区精品久久911| 精品久久一区二区| 国产精品免费久久久久| 久久综合久久99| 自拍偷拍欧美精品| 日本欧美在线看| 国产高清在线精品| 欧美视频日韩视频在线观看| 欧美一区二区日韩一区二区| 久久先锋影音av鲁色资源| 国产精品高清亚洲| 日产精品久久久久久久性色| 日本系列欧美系列| 成人小视频免费在线观看| 91色九色蝌蚪| 中文字幕不卡在线| 蜜桃一区二区三区在线观看| 国产精品一区二区三区99| 成人动漫中文字幕| 日韩亚洲欧美在线| 亚洲另类一区二区| 风流少妇一区二区| 久久久久久久精| 久久99久久99精品免视看婷婷| 欧美性xxxxxxxx| 亚洲一区二区3| 日韩久久久精品| 日韩国产在线一| 欧美成人一区二区三区在线观看| 蜜臀av性久久久久蜜臀aⅴ | 18成人在线观看| 色综合久久久网| 亚洲国产日韩a在线播放性色| 欧美性一二三区| 日本大胆欧美人术艺术动态| 色综合久久久久网| 久久精品国产999大香线蕉| 中国av一区二区三区| 成人激情午夜影院| 亚洲国产精品激情在线观看| 丁香激情综合五月| 亚洲最色的网站| 欧美一区二区视频在线观看 | 亚洲蜜臀av乱码久久精品蜜桃| 国产乱子伦一区二区三区国色天香| 欧美一区二区三区不卡| 懂色av一区二区三区免费看| 日韩伦理电影网| 欧美区在线观看| 国产成人av一区| 亚洲午夜私人影院| 国产午夜亚洲精品理论片色戒 | 成人午夜短视频| 自拍偷拍亚洲欧美日韩| 日韩一级黄色大片| 欧美午夜理伦三级在线观看| 午夜伦欧美伦电影理论片| 日本一区二区三区国色天香 | 亚洲欧美一区二区久久| 日韩网站在线看片你懂的| 色天使色偷偷av一区二区| 国产在线不卡一卡二卡三卡四卡| 亚洲欧美在线视频| 欧美国产激情一区二区三区蜜月| 欧美日韩国产免费| 欧美自拍偷拍一区| 91视频国产观看| 色婷婷国产精品久久包臀| 99久久综合精品| 成人99免费视频| 色婷婷香蕉在线一区二区| 懂色av一区二区在线播放| 国产凹凸在线观看一区二区| 国产在线一区二区| 性久久久久久久| 青青国产91久久久久久| 91一区在线观看|