亚洲欧美第一页_禁久久精品乱码_粉嫩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一区二区三区免费野_久草精品视频
欧洲亚洲精品在线| 777久久久精品| 日韩中文字幕亚洲一区二区va在线| 日韩欧美区一区二| 在线亚洲免费视频| 国产成人免费视频一区| 丝瓜av网站精品一区二区| 中文字幕av不卡| 精品少妇一区二区三区在线视频| 一本一本大道香蕉久在线精品 | 洋洋成人永久网站入口| 精品精品国产高清a毛片牛牛 | 日韩一区二区在线免费观看| a在线播放不卡| 国产麻豆精品在线观看| 日韩电影在线免费看| 亚洲激情av在线| 欧美国产精品v| 国产亚洲欧美激情| 久久夜色精品国产噜噜av| 欧美日韩成人高清| 欧美日精品一区视频| 91老司机福利 在线| 成人h动漫精品一区二| 国内精品视频666| 久久国产精品第一页| 婷婷久久综合九色综合伊人色| 亚洲人成7777| 亚洲另类一区二区| 亚洲乱码国产乱码精品精小说| 国产午夜久久久久| 26uuu成人网一区二区三区| 欧美一区二区高清| 日韩免费在线观看| 欧美v日韩v国产v| 精品国产91洋老外米糕| 日韩午夜三级在线| 日韩欧美国产三级| 日韩视频一区二区三区在线播放| 91精品国产色综合久久ai换脸| 欧美日韩精品电影| 欧美男人的天堂一二区| 91精品国产综合久久精品麻豆| 欧美挠脚心视频网站| 69p69国产精品| 欧美电影免费观看高清完整版在| 日韩一区二区三区电影在线观看| 91精品在线观看入口| 日韩欧美一区二区三区在线| 精品免费一区二区三区| 久久精品视频在线免费观看| 国产精品素人视频| 一区二区三区高清| 日韩高清国产一区在线| 裸体一区二区三区| 国产精品996| 成人国产精品免费观看视频| 日本精品一区二区三区高清| 欧美片在线播放| 精品久久人人做人人爽| 国产精品激情偷乱一区二区∴| 中文字幕一区二区三区视频| 亚洲一区二区三区国产| 日本三级亚洲精品| 国产伦精品一区二区三区免费迷 | 午夜欧美2019年伦理| 久久国产精品99久久人人澡| 国产黄色91视频| 色猫猫国产区一区二在线视频| 欧美猛男男办公室激情| 久久九九久久九九| 亚洲激情欧美激情| 韩国av一区二区三区| 91色porny| 日韩女优电影在线观看| 1区2区3区国产精品| 日本欧洲一区二区| 成人晚上爱看视频| 欧美精品v日韩精品v韩国精品v| 精品国产123| 一区二区三区美女| 国产毛片精品国产一区二区三区| 色综合久久久久久久久久久| 日韩色在线观看| 亚洲视频中文字幕| 久久国产精品第一页| 日本高清不卡aⅴ免费网站| 精品久久五月天| 夜夜夜精品看看| 大桥未久av一区二区三区中文| 欧美日韩免费不卡视频一区二区三区| 精品粉嫩超白一线天av| 亚洲柠檬福利资源导航| 极品少妇xxxx精品少妇偷拍| 欧美午夜免费电影| 中文字幕久久午夜不卡| 日本欧美在线观看| 在线观看视频91| 国产精品美女久久久久aⅴ国产馆 国产精品美女久久久久av爽李琼 国产精品美女久久久久高潮 | 欧美午夜一区二区三区免费大片| 久久免费精品国产久精品久久久久 | 91九色最新地址| 国产欧美一区二区精品仙草咪| 亚洲福利一区二区三区| 99国产精品视频免费观看| 日韩美女主播在线视频一区二区三区 | 日韩国产欧美在线播放| 99re视频这里只有精品| 久久免费美女视频| 美女精品自拍一二三四| 欧美日韩国产一级| 亚洲综合色视频| 色综合久久88色综合天天6| 国产日韩欧美不卡在线| 激情综合网天天干| 日韩欧美一区二区在线视频| 亚洲宅男天堂在线观看无病毒| 丁香天五香天堂综合| 国产网红主播福利一区二区| 麻豆91精品91久久久的内涵| 欧美日韩国产小视频| 夜夜爽夜夜爽精品视频| eeuss国产一区二区三区| 欧美国产乱子伦| 国产白丝网站精品污在线入口| 精品久久久久久久久久久久久久久久久| 亚洲一区二区高清| 欧美色爱综合网| 午夜欧美在线一二页| 欧美唯美清纯偷拍| 午夜伊人狠狠久久| 欧美片网站yy| 喷白浆一区二区| 日韩免费高清电影| 国产乱码精品一品二品| 精品国产露脸精彩对白| 国产精品自产自拍| 国产视频亚洲色图| 风流少妇一区二区| 国产精品美女一区二区在线观看| 成人精品视频.| 亚洲人快播电影网| 欧美图区在线视频| 美女一区二区久久| 久久精子c满五个校花| 成人一级视频在线观看| ...xxx性欧美| 欧美在线观看一二区| 亚洲综合网站在线观看| 在线观看国产精品网站| 视频一区二区中文字幕| 精品美女在线播放| 国产一区二区三区高清播放| 日本一区二区三区视频视频| 不卡的电视剧免费网站有什么| 成人免费一区二区三区在线观看| 色狠狠桃花综合| 日韩电影网1区2区| 久久蜜臀中文字幕| av电影在线观看一区| 亚洲成av人片在线观看无码| 日韩欧美电影一区| 不卡的看片网站| 午夜伊人狠狠久久| 久久先锋影音av| 91小视频在线免费看| 日本va欧美va瓶| 精品福利一二区| 成人三级在线视频| 亚洲成人激情自拍| 国产清纯美女被跳蛋高潮一区二区久久w | 亚洲色图欧美在线| 91精品国产高清一区二区三区蜜臀 | 欧美日韩视频专区在线播放| 老司机午夜精品| 亚洲柠檬福利资源导航| 欧美一级高清片在线观看| 国产99久久久久久免费看农村| 亚洲精品第一国产综合野| 91精品在线观看入口| 成人高清免费观看| 免费久久99精品国产| 1024成人网| 精品久久一区二区| 在线观看一区不卡| 成人精品电影在线观看| 日韩影院精彩在线| 亚洲精品欧美专区| 精品福利在线导航| 欧美日韩成人在线一区| 成人精品在线视频观看| 蜜臀av国产精品久久久久| 国产精品美女一区二区| 欧美成人免费网站| 在线观看亚洲精品| 99在线精品视频| 国产成人免费高清| 美女视频网站久久| 亚洲成人在线免费| 日韩伦理免费电影|