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

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

?? capi2.test

?? sqlite庫
?? TEST
?? 第 1 頁 / 共 2 頁
字號:
# 2003 January 29## The author disclaims copyright to this source code.  In place of# a legal notice, here is a blessing:##    May you do good and not evil.#    May you find forgiveness for yourself and forgive others.#    May you share freely, never taking more than you give.##***********************************************************************# This file implements regression tests for SQLite library.  The# focus of this script testing the callback-free C/C++ API.## $Id: capi2.test,v 1.31 2006/02/10 13:33:31 danielk1977 Exp $#set testdir [file dirname $argv0]source $testdir/tester.tcl# Return the text values from the current row pointed at by STMT as a list.proc get_row_values {STMT} {  set VALUES [list]  for {set i 0} {$i < [sqlite3_data_count $STMT]} {incr i} {    lappend VALUES [sqlite3_column_text $STMT $i]  }  return $VALUES}# Return the column names followed by declaration types for the result set# of the SQL statement STMT.## i.e. for:# CREATE TABLE abc(a text, b integer); # SELECT * FROM abc;## The result is {a b text integer}proc get_column_names {STMT} {  set VALUES [list]  for {set i 0} {$i < [sqlite3_column_count $STMT]} {incr i} {    lappend VALUES [sqlite3_column_name $STMT $i]  }  for {set i 0} {$i < [sqlite3_column_count $STMT]} {incr i} {    lappend VALUES [sqlite3_column_decltype $STMT $i]  }  return $VALUES}# Check basic functionality#do_test capi2-1.1 {  set DB [sqlite3_connection_pointer db]  execsql {CREATE TABLE t1(a,b,c)}  set VM [sqlite3_prepare $DB {SELECT name, rowid FROM sqlite_master} -1 TAIL]  set TAIL} {}do_test capi2-1.2 {  sqlite3_step $VM} {SQLITE_ROW}do_test capi2-1.3 {  sqlite3_data_count $VM} {2}do_test capi2-1.4 {  get_row_values $VM} {t1 1}do_test capi2-1.5 {  get_column_names $VM} {name rowid text INTEGER}do_test capi2-1.6 {  sqlite3_step $VM } {SQLITE_DONE}do_test capi2-1.7 {  list [sqlite3_column_count $VM] [get_row_values $VM] [get_column_names $VM]} {2 {} {name rowid text INTEGER}}do_test capi2-1.8 {  sqlite3_step $VM} {SQLITE_MISUSE}# Update: In v2, once SQLITE_MISUSE is returned the statement handle cannot# be interrogated for more information. However in v3, since the column# count, names and types are determined at compile time, these are still# accessible after an SQLITE_MISUSE error.do_test capi2-1.9 {  list [sqlite3_column_count $VM] [get_row_values $VM] [get_column_names $VM]} {2 {} {name rowid text INTEGER}}do_test capi2-1.10 {  sqlite3_data_count $VM} {0}do_test capi2-1.11 {  sqlite3_finalize $VM} {SQLITE_OK}# Check to make sure that the "tail" of a multi-statement SQL script# is returned by sqlite3_prepare.#do_test capi2-2.1 {  set SQL {    SELECT name, rowid FROM sqlite_master;    SELECT name, rowid FROM sqlite_master WHERE 0;    -- A comment at the end  }  set VM [sqlite3_prepare $DB $SQL -1 SQL]  set SQL} {    SELECT name, rowid FROM sqlite_master WHERE 0;    -- A comment at the end  }do_test capi2-2.2 {  set r [sqlite3_step $VM]  lappend r [sqlite3_column_count $VM] \            [get_row_values $VM] \            [get_column_names $VM]} {SQLITE_ROW 2 {t1 1} {name rowid text INTEGER}}do_test capi2-2.3 {  set r [sqlite3_step $VM]  lappend r [sqlite3_column_count $VM] \            [get_row_values $VM] \            [get_column_names $VM]} {SQLITE_DONE 2 {} {name rowid text INTEGER}}do_test capi2-2.4 {  sqlite3_finalize $VM} {SQLITE_OK}do_test capi2-2.5 {  set VM [sqlite3_prepare $DB $SQL -1 SQL]  set SQL} {    -- A comment at the end  }do_test capi2-2.6 {  set r [sqlite3_step $VM]  lappend r [sqlite3_column_count $VM] \            [get_row_values $VM] \            [get_column_names $VM]} {SQLITE_DONE 2 {} {name rowid text INTEGER}}do_test capi2-2.7 {  sqlite3_finalize $VM} {SQLITE_OK}do_test capi2-2.8 {  set VM [sqlite3_prepare $DB $SQL -1 SQL]  list $SQL $VM} {{} {}}# Check the error handling.#do_test capi2-3.1 {  set rc [catch {      sqlite3_prepare $DB {select bogus from sqlite_master} -1 TAIL  } msg]  lappend rc $msg $TAIL} {1 {(1) no such column: bogus} {}}do_test capi2-3.2 {  set rc [catch {      sqlite3_prepare $DB {select bogus from } -1 TAIL  } msg]  lappend rc $msg $TAIL} {1 {(1) near " ": syntax error} {}}do_test capi2-3.3 {  set rc [catch {      sqlite3_prepare $DB {;;;;select bogus from sqlite_master} -1 TAIL  } msg]  lappend rc $msg $TAIL} {1 {(1) no such column: bogus} {}}do_test capi2-3.4 {  set rc [catch {      sqlite3_prepare $DB {select bogus from sqlite_master;x;} -1 TAIL  } msg]  lappend rc $msg $TAIL} {1 {(1) no such column: bogus} {x;}}do_test capi2-3.5 {  set rc [catch {      sqlite3_prepare $DB {select bogus from sqlite_master;;;x;} -1 TAIL  } msg]  lappend rc $msg $TAIL} {1 {(1) no such column: bogus} {;;x;}}do_test capi2-3.6 {  set rc [catch {      sqlite3_prepare $DB {select 5/0} -1 TAIL  } VM]  lappend rc $TAIL} {0 {}}do_test capi2-3.7 {  list [sqlite3_step $VM] \       [sqlite3_column_count $VM] \       [get_row_values $VM] \       [get_column_names $VM]} {SQLITE_ROW 1 {{}} {5/0 {}}}do_test capi2-3.8 {  sqlite3_finalize $VM} {SQLITE_OK}do_test capi2-3.9 {  execsql {CREATE UNIQUE INDEX i1 ON t1(a)}  set VM [sqlite3_prepare $DB {INSERT INTO t1 VALUES(1,2,3)} -1 TAIL]  set TAIL} {}do_test capi2-3.9b {db changes} {0}do_test capi2-3.10 {  list [sqlite3_step $VM] \       [sqlite3_column_count $VM] \       [get_row_values $VM] \       [get_column_names $VM]} {SQLITE_DONE 0 {} {}}# Update for v3 - the change has not actually happened until the query is# finalized. Is this going to cause trouble for anyone? Lee Nelson maybe?# (Later:) The change now happens just before SQLITE_DONE is returned.do_test capi2-3.10b {db changes} {1}do_test capi2-3.11 {  sqlite3_finalize $VM} {SQLITE_OK}do_test capi2-3.11b {db changes} {1}do_test capi2-3.12 {  sqlite3_finalize $VM} {SQLITE_MISUSE}do_test capi2-3.13 {  set VM [sqlite3_prepare $DB {INSERT INTO t1 VALUES(1,3,4)} -1 TAIL]  list [sqlite3_step $VM] \       [sqlite3_column_count $VM] \       [get_row_values $VM] \       [get_column_names $VM]} {SQLITE_ERROR 0 {} {}}# Update for v3: Preparing a statement does not affect the change counter.# (Test result changes from 0 to 1).  (Later:) change counter updates occur# when sqlite3_step returns, not at finalize time.do_test capi2-3.13b {db changes} {0}do_test capi2-3.14 {  list [sqlite3_finalize $VM] [sqlite3_errmsg $DB]} {SQLITE_CONSTRAINT {column a is not unique}}do_test capi2-3.15 {  set VM [sqlite3_prepare $DB {CREATE TABLE t2(a NOT NULL, b)} -1 TAIL]  set TAIL} {}do_test capi2-3.16 {  list [sqlite3_step $VM] \       [sqlite3_column_count $VM] \       [get_row_values $VM] \       [get_column_names $VM]} {SQLITE_DONE 0 {} {}}do_test capi2-3.17 {  list [sqlite3_finalize $VM] [sqlite3_errmsg $DB]} {SQLITE_OK {not an error}}do_test capi2-3.18 {  set VM [sqlite3_prepare $DB {INSERT INTO t2 VALUES(NULL,2)} -1 TAIL]  list [sqlite3_step $VM] \       [sqlite3_column_count $VM] \       [get_row_values $VM] \       [get_column_names $VM]} {SQLITE_ERROR 0 {} {}}do_test capi2-3.19 {  list [sqlite3_finalize $VM] [sqlite3_errmsg $DB]} {SQLITE_CONSTRAINT {t2.a may not be NULL}}do_test capi2-3.20 {  execsql {    CREATE TABLE a1(message_id, name , UNIQUE(message_id, name) );    INSERT INTO a1 VALUES(1, 1);  }} {}do_test capi2-3.21 {  set VM [sqlite3_prepare $DB {INSERT INTO a1 VALUES(1, 1)} -1 TAIL]  sqlite3_step $VM} {SQLITE_ERROR}do_test capi2-3.22 {  sqlite3_errcode $DB} {SQLITE_ERROR}do_test capi2-3.23 {  sqlite3_finalize $VM} {SQLITE_CONSTRAINT}do_test capi2-3.24 {  sqlite3_errcode $DB} {SQLITE_CONSTRAINT}# Two or more virtual machines exists at the same time.#do_test capi2-4.1 {  set VM1 [sqlite3_prepare $DB {INSERT INTO t2 VALUES(1,2)} -1 TAIL]  set TAIL} {}do_test capi2-4.2 {  set VM2 [sqlite3_prepare $DB {INSERT INTO t2 VALUES(2,3)} -1 TAIL]  set TAIL} {}do_test capi2-4.3 {  set VM3 [sqlite3_prepare $DB {INSERT INTO t2 VALUES(3,4)} -1 TAIL]  set TAIL} {}do_test capi2-4.4 {  list [sqlite3_step $VM2] \       [sqlite3_column_count $VM2] \       [get_row_values $VM2] \       [get_column_names $VM2]} {SQLITE_DONE 0 {} {}}do_test capi2-4.5 {  execsql {SELECT * FROM t2 ORDER BY a}} {2 3}do_test capi2-4.6 {  sqlite3_finalize $VM2} {SQLITE_OK}do_test capi2-4.7 {  list [sqlite3_step $VM3] \       [sqlite3_column_count $VM3] \       [get_row_values $VM3] \       [get_column_names $VM3]} {SQLITE_DONE 0 {} {}}do_test capi2-4.8 {  execsql {SELECT * FROM t2 ORDER BY a}} {2 3 3 4}do_test capi2-4.9 {  sqlite3_finalize $VM3} {SQLITE_OK}do_test capi2-4.10 {  list [sqlite3_step $VM1] \       [sqlite3_column_count $VM1] \       [get_row_values $VM1] \       [get_column_names $VM1]} {SQLITE_DONE 0 {} {}}do_test capi2-4.11 {  execsql {SELECT * FROM t2 ORDER BY a}} {1 2 2 3 3 4}do_test capi2-4.12 {  sqlite3_finalize $VM1} {SQLITE_OK}# Interleaved SELECTs#do_test capi2-5.1 {  set VM1 [sqlite3_prepare $DB {SELECT * FROM t2} -1 TAIL]  set VM2 [sqlite3_prepare $DB {SELECT * FROM t2} -1 TAIL]  set VM3 [sqlite3_prepare $DB {SELECT * FROM t2} -1 TAIL]  list [sqlite3_step $VM1] \       [sqlite3_column_count $VM1] \       [get_row_values $VM1] \       [get_column_names $VM1]} {SQLITE_ROW 2 {2 3} {a b {} {}}}do_test capi2-5.2 {  list [sqlite3_step $VM2] \       [sqlite3_column_count $VM2] \       [get_row_values $VM2] \       [get_column_names $VM2]} {SQLITE_ROW 2 {2 3} {a b {} {}}}do_test capi2-5.3 {  list [sqlite3_step $VM1] \       [sqlite3_column_count $VM1] \       [get_row_values $VM1] \       [get_column_names $VM1]} {SQLITE_ROW 2 {3 4} {a b {} {}}}do_test capi2-5.4 {  list [sqlite3_step $VM3] \       [sqlite3_column_count $VM3] \       [get_row_values $VM3] \       [get_column_names $VM3]} {SQLITE_ROW 2 {2 3} {a b {} {}}}do_test capi2-5.5 {  list [sqlite3_step $VM3] \       [sqlite3_column_count $VM3] \       [get_row_values $VM3] \       [get_column_names $VM3]} {SQLITE_ROW 2 {3 4} {a b {} {}}}do_test capi2-5.6 {  list [sqlite3_step $VM3] \       [sqlite3_column_count $VM3] \       [get_row_values $VM3] \       [get_column_names $VM3]} {SQLITE_ROW 2 {1 2} {a b {} {}}}do_test capi2-5.7 {  list [sqlite3_step $VM3] \       [sqlite3_column_count $VM3] \       [get_row_values $VM3] \       [get_column_names $VM3]} {SQLITE_DONE 2 {} {a b {} {}}}do_test capi2-5.8 {  sqlite3_finalize $VM3} {SQLITE_OK}do_test capi2-5.9 {  list [sqlite3_step $VM1] \       [sqlite3_column_count $VM1] \       [get_row_values $VM1] \       [get_column_names $VM1]} {SQLITE_ROW 2 {1 2} {a b {} {}}}do_test capi2-5.10 {  sqlite3_finalize $VM1} {SQLITE_OK}do_test capi2-5.11 {  list [sqlite3_step $VM2] \       [sqlite3_column_count $VM2] \       [get_row_values $VM2] \       [get_column_names $VM2]} {SQLITE_ROW 2 {3 4} {a b {} {}}}do_test capi2-5.12 {  list [sqlite3_step $VM2] \       [sqlite3_column_count $VM2] \       [get_row_values $VM2] \       [get_column_names $VM2]} {SQLITE_ROW 2 {1 2} {a b {} {}}}do_test capi2-5.11 {

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
激情偷乱视频一区二区三区| 国产精品欧美精品| 亚洲精品成人悠悠色影视| 精品一区二区三区免费| 欧美日韩国产高清一区二区| **欧美大码日韩| 成人精品视频一区二区三区| 国产亚洲综合在线| 国产美女一区二区| 久久伊人中文字幕| 国产精品乡下勾搭老头1| 精品国产三级电影在线观看| 蜜桃av一区二区在线观看 | 欧美日韩国产一二三| 丝袜美腿亚洲综合| 欧美一区三区四区| 麻豆精品国产91久久久久久| 欧洲精品视频在线观看| 日韩理论电影院| 91福利精品视频| 亚洲成人免费影院| 在线观看日韩av先锋影音电影院| 亚洲一区二区三区视频在线| 欧美日韩日日骚| 久久国产福利国产秒拍| 精品少妇一区二区三区免费观看 | 亚洲自拍偷拍麻豆| 欧美日韩国产另类不卡| 天堂蜜桃一区二区三区 | 亚洲精品国产一区二区精华液| 一本大道av一区二区在线播放| 亚洲精品成人悠悠色影视| 99久久婷婷国产综合精品电影| 国产精品久久久一区麻豆最新章节| 99免费精品在线观看| 亚洲激情欧美激情| 日韩视频免费直播| 麻豆精品国产传媒mv男同 | 中文字幕人成不卡一区| 日本韩国精品在线| 日产国产高清一区二区三区| 欧美成人一区二区三区片免费| 国产精品123区| 亚洲精品乱码久久久久久久久| 欧美一区二区三区视频免费| 国产精品一卡二卡| 一个色妞综合视频在线观看| 精品久久久久一区二区国产| 99久久久国产精品免费蜜臀| 日韩av电影天堂| 最新欧美精品一区二区三区| 欧美日韩亚洲高清一区二区| 国产精品1024| 午夜精品一区二区三区电影天堂 | 国产伦精品一区二区三区免费迷 | 久久99精品国产麻豆婷婷| 中文欧美字幕免费| 亚洲精品一线二线三线无人区| 国产99一区视频免费| 天天色天天操综合| 国产精品天干天干在线综合| 欧美猛男gaygay网站| 99久久免费精品高清特色大片| 日韩极品在线观看| 国产精品三级视频| 在线视频你懂得一区二区三区| 久久国产人妖系列| 午夜欧美视频在线观看| 欧美高清在线一区二区| 91精品国产日韩91久久久久久| 成人永久免费视频| 青青草国产精品97视觉盛宴| 亚洲色图清纯唯美| 国产香蕉久久精品综合网| 6080yy午夜一二三区久久| 国产精品系列在线观看| 亚洲第一成年网| 亚洲美女免费在线| 国产色91在线| 久久久久久日产精品| 欧美电影免费观看高清完整版在| 日本高清成人免费播放| 成人黄色网址在线观看| 国产露脸91国语对白| 久久精品99国产国产精| 午夜精品123| 亚洲成人资源在线| 亚洲国产综合91精品麻豆| 一个色综合av| 亚洲自拍偷拍欧美| 国产视频一区在线播放| 久久亚区不卡日本| 91精品福利在线一区二区三区 | 欧美精品一卡二卡| 欧美视频精品在线观看| 91国内精品野花午夜精品| 91久久精品午夜一区二区| a亚洲天堂av| 国产成人h网站| 国产高清久久久| 国产激情一区二区三区桃花岛亚洲| 国产麻豆精品视频| 成人中文字幕电影| 暴力调教一区二区三区| 成人激情黄色小说| 色94色欧美sute亚洲13| 91在线高清观看| 色偷偷88欧美精品久久久| 国产福利一区二区三区视频| 久久国产综合精品| 国产一区二区不卡| 成人激情图片网| 在线视频欧美区| 欧美日韩视频在线一区二区| 欧美色电影在线| 欧美另类变人与禽xxxxx| 色婷婷av一区二区三区软件 | 欧美在线观看视频在线| 欧美三级中文字幕在线观看| 欧美日韩亚洲综合一区| 日韩欧美一区二区免费| 日本一区免费视频| 中文字幕乱码亚洲精品一区| 亚洲欧美综合网| 亚洲成人免费观看| 爽爽淫人综合网网站| 亚洲国产精品久久人人爱蜜臀| 香蕉成人啪国产精品视频综合网 | 奇米一区二区三区av| 国产在线国偷精品免费看| 99久久精品久久久久久清纯| www.欧美.com| av亚洲精华国产精华精华| 欧美亚洲愉拍一区二区| 精品卡一卡二卡三卡四在线| 国产精品美女www爽爽爽| 中文字幕亚洲一区二区va在线| 亚洲三级在线免费| 蜜臀av一区二区三区| 9色porny自拍视频一区二区| 在线观看成人小视频| 精品久久久久久综合日本欧美| 中文字幕一区二区三| 日韩精品福利网| 91在线视频观看| 精品福利一二区| 亚洲在线免费播放| 国产电影一区在线| 欧美日韩精品一二三区| 日韩美女天天操| 欧美国产日韩在线观看| 五月婷婷综合激情| 99精品国产91久久久久久| 日韩午夜三级在线| 一区二区三区日韩精品| 国产又粗又猛又爽又黄91精品| 91蝌蚪porny| 久久久91精品国产一区二区精品| 亚洲欧美在线aaa| 国产主播一区二区| 3d动漫精品啪啪1区2区免费 | 久久国产精品一区二区| 欧美日韩高清在线| 亚洲福利一区二区| 欧美亚洲动漫另类| 亚洲精品国产一区二区三区四区在线| 不卡电影免费在线播放一区| 国产日韩亚洲欧美综合| 国产高清久久久久| 亚洲国产精品成人综合| 国产91丝袜在线播放| 国产日本欧洲亚洲| 成人97人人超碰人人99| 中文字幕一区av| 色噜噜狠狠一区二区三区果冻| 亚洲欧美一区二区三区孕妇| 一道本成人在线| 一区二区三区**美女毛片| 在线观看av不卡| 香蕉成人伊视频在线观看| 欧美一卡二卡三卡四卡| 久国产精品韩国三级视频| 久久亚洲精品国产精品紫薇| 国产激情视频一区二区在线观看| 国产欧美视频在线观看| av日韩在线网站| 一区二区三区四区蜜桃| 欧美丰满高潮xxxx喷水动漫| 国产成人精品免费在线| 国产精品私人自拍| 色综合 综合色| 亚洲高清在线精品| 日韩一区二区免费在线观看| 精品一区二区国语对白| 中文字幕不卡的av| 色久优优欧美色久优优| 日本美女视频一区二区| 久久精品亚洲精品国产欧美| 91小视频在线| 日本中文在线一区|