⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 capi3c.test

📁 sqlite-3.4.1,嵌入式数据库.是一个功能强大的开源数据库,给学习和研发以及小型公司的发展带来了全所未有的好处.
💻 TEST
📖 第 1 页 / 共 3 页
字号:
do_test capi3c-11.9 {  set STMT [sqlite3_prepare_v2 $DB "SELECT a FROM t2" -1 TAIL]  sqlite3_step $STMT} {SQLITE_ROW}do_test capi3c-11.9.1 {  sqlite3_get_autocommit $DB} 0do_test capi3c-11.9.2 {  catchsql {    ROLLBACK;  }} {1 {cannot rollback transaction - SQL statements in progress}}do_test capi3c-11.9.3 {  sqlite3_get_autocommit $DB} 0do_test capi3c-11.10 {  sqlite3_step $STMT} {SQLITE_ROW}do_test capi3c-11.11 {  sqlite3_step $STMT} {SQLITE_ROW}do_test capi3c-11.12 {  sqlite3_step $STMT} {SQLITE_DONE}do_test capi3c-11.13 {  sqlite3_finalize $STMT} {SQLITE_OK}do_test capi3c-11.14 {  execsql {    SELECT a FROM t2;  }} {1 2 3}do_test capi3c-11.14.1 {  sqlite3_get_autocommit $DB} 0do_test capi3c-11.15 {  catchsql {    ROLLBACK;  }} {0 {}}do_test capi3c-11.15.1 {  sqlite3_get_autocommit $DB} 1do_test capi3c-11.16 {  execsql {    SELECT a FROM t2;  }} {1 2}# Sanity check on the definition of 'outstanding VM'. This means any VM# that has had sqlite3_step() called more recently than sqlite3_finalize() or# sqlite3_reset(). So a VM that has just been prepared or reset does not# count as an active VM.do_test capi3c-11.17 {  execsql {    BEGIN;  }} {}do_test capi3c-11.18 {  set STMT [sqlite3_prepare_v2 $DB "SELECT a FROM t1" -1 TAIL]  catchsql {    COMMIT;  }} {0 {}}do_test capi3c-11.19 {  sqlite3_step $STMT} {SQLITE_ROW}do_test capi3c-11.20 {  catchsql {    BEGIN;    COMMIT;  }} {1 {cannot commit transaction - SQL statements in progress}}do_test capi3c-11.20 {  sqlite3_reset $STMT  catchsql {    COMMIT;  }} {0 {}}do_test capi3c-11.21 {  sqlite3_finalize $STMT} {SQLITE_OK}# The following tests - capi3c-12.* - check that it's Ok to start a# transaction while other VMs are active, and that it's Ok to execute# atomic updates in the same situation #do_test capi3c-12.1 {  set STMT [sqlite3_prepare_v2 $DB "SELECT a FROM t2" -1 TAIL]  sqlite3_step $STMT} {SQLITE_ROW}do_test capi3c-12.2 {  catchsql {    INSERT INTO t1 VALUES(3, NULL);  }} {0 {}}do_test capi3c-12.3 {  catchsql {    INSERT INTO t2 VALUES(4);  }} {0 {}}do_test capi3c-12.4 {  catchsql {    BEGIN;    INSERT INTO t1 VALUES(4, NULL);  }} {0 {}}do_test capi3c-12.5 {  sqlite3_step $STMT} {SQLITE_ROW}do_test capi3c-12.5.1 {  sqlite3_step $STMT} {SQLITE_ROW}do_test capi3c-12.6 {  sqlite3_step $STMT} {SQLITE_DONE}do_test capi3c-12.7 {  sqlite3_finalize $STMT} {SQLITE_OK}do_test capi3c-12.8 {  execsql {    COMMIT;    SELECT a FROM t1;  }} {1 2 3 4}# Test cases capi3c-13.* test the sqlite3_clear_bindings() and # sqlite3_sleep APIs.#if {[llength [info commands sqlite3_clear_bindings]]>0} {  do_test capi3c-13.1 {    execsql {      DELETE FROM t1;    }    set STMT [sqlite3_prepare_v2 $DB "INSERT INTO t1 VALUES(?, ?)" -1 TAIL]    sqlite3_step $STMT  } {SQLITE_DONE}  do_test capi3c-13.2 {    sqlite3_reset $STMT    sqlite3_bind_text $STMT 1 hello 5    sqlite3_bind_text $STMT 2 world 5    sqlite3_step $STMT  } {SQLITE_DONE}  do_test capi3c-13.3 {    sqlite3_reset $STMT    sqlite3_clear_bindings $STMT    sqlite3_step $STMT  } {SQLITE_DONE}  do_test capi3c-13-4 {    sqlite3_finalize $STMT    execsql {      SELECT * FROM t1;    }  } {{} {} hello world {} {}}}if {[llength [info commands sqlite3_sleep]]>0} {  do_test capi3c-13-5 {    set ms [sqlite3_sleep 80]    expr {$ms==80 || $ms==1000}  } {1}}# Ticket #1219:  Make sure binding APIs can handle a NULL pointer.#do_test capi3c-14.1 {  set rc [catch {sqlite3_bind_text 0 1 hello 5} msg]  lappend rc $msg} {1 SQLITE_MISUSE}# Ticket #1650:  Honor the nBytes parameter to sqlite3_prepare.#do_test capi3c-15.1 {  set sql {SELECT * FROM t2}  set nbytes [string length $sql]  append sql { WHERE a==1}  set STMT [sqlite3_prepare_v2 $DB $sql $nbytes TAIL]  sqlite3_step $STMT  sqlite3_column_int $STMT 0} {1}do_test capi3c-15.2 {  sqlite3_step $STMT  sqlite3_column_int $STMT 0} {2}do_test capi3c-15.3 {  sqlite3_finalize $STMT} {SQLITE_OK}# Make sure code is always generated even if an IF EXISTS or # IF NOT EXISTS clause is present that the table does not or# does exists.  That way we will always have a prepared statement# to expire when the schema changes.#do_test capi3c-16.1 {  set sql {DROP TABLE IF EXISTS t3}  set STMT [sqlite3_prepare_v2 $DB $sql -1 TAIL]  sqlite3_finalize $STMT  expr {$STMT!=""}} {1}do_test capi3c-16.2 {  set sql {CREATE TABLE IF NOT EXISTS t1(x,y)}  set STMT [sqlite3_prepare_v2 $DB $sql -1 TAIL]  sqlite3_finalize $STMT  expr {$STMT!=""}} {1}# But still we do not generate code if there is no SQL#do_test capi3c-16.3 {  set STMT [sqlite3_prepare_v2 $DB {} -1 TAIL]  sqlite3_finalize $STMT  expr {$STMT==""}} {1}do_test capi3c-16.4 {  set STMT [sqlite3_prepare_v2 $DB {;} -1 TAIL]  sqlite3_finalize $STMT  expr {$STMT==""}} {1}# Ticket #2154.#do_test capi3c-17.1 {  set STMT [sqlite3_prepare_v2 $DB {SELECT max(a) FROM t2} -1 TAIL]  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-17.2 {  sqlite3_column_int $STMT 0} 4do_test capi3c-17.3 {  sqlite3_step $STMT} SQLITE_DONEdo_test capi3c-17.4 {  sqlite3_reset $STMT  db eval {CREATE INDEX i2 ON t2(a)}  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-17.5 {  sqlite3_column_int $STMT 0} 4do_test capi3c-17.6 {  sqlite3_step $STMT} SQLITE_DONEdo_test capi3c-17.7 {  sqlite3_reset $STMT  db eval {DROP INDEX i2}  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-17.8 {  sqlite3_column_int $STMT 0} 4do_test capi3c-17.9 {  sqlite3_step $STMT} SQLITE_DONEdo_test capi3c-17.10 {  sqlite3_finalize $STMT  set STMT [sqlite3_prepare_v2 $DB {SELECT b FROM t1 WHERE a=?} -1 TAIL]  sqlite3_bind_int $STMT 1 2  db eval {    DELETE FROM t1;    INSERT INTO t1 VALUES(1,'one');    INSERT INTO t1 VALUES(2,'two');    INSERT INTO t1 VALUES(3,'three');    INSERT INTO t1 VALUES(4,'four');  }  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-17.11 {  sqlite3_column_text $STMT 0} twodo_test capi3c-17.12 {  sqlite3_step $STMT} SQLITE_DONEdo_test capi3c-17.13 {  sqlite3_reset $STMT  db eval {CREATE INDEX i1 ON t1(a)}  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-17.14 {  sqlite3_column_text $STMT 0} twodo_test capi3c-17.15 {  sqlite3_step $STMT} SQLITE_DONEdo_test capi3c-17.16 {  sqlite3_reset $STMT  db eval {DROP INDEX i1}  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-17.17 {  sqlite3_column_text $STMT 0} twodo_test capi3c-17.18 {  sqlite3_step $STMT} SQLITE_DONEdo_test capi3c-17.99 {  sqlite3_finalize $STMT} SQLITE_OK# On the mailing list it has been reported that finalizing after# an SQLITE_BUSY return leads to a segfault.  Here we test that case.#do_test capi3c-18.1 {  sqlite3 db2 test.db  set STMT [sqlite3_prepare_v2 $DB {SELECT max(a) FROM t1} -1 TAIL]  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-18.2 {  sqlite3_column_int $STMT 0} 4do_test capi3c-18.3 {  sqlite3_reset $STMT  db2 eval {BEGIN EXCLUSIVE}  sqlite3_step $STMT} SQLITE_BUSYdo_test capi3c-18.4 {  sqlite3_finalize $STMT} SQLITE_BUSYdo_test capi3c-18.5 {  db2 eval {COMMIT}  db2 close} {}# Ticket #2158.  The sqlite3_step() will still return SQLITE_SCHEMA# if the database schema changes in a way that makes the statement# no longer valid.#do_test capi3c-19.1 {  db eval {     CREATE TABLE t3(x,y);     INSERT INTO t3 VALUES(1,2);  }  set STMT [sqlite3_prepare_v2 $DB {SELECT * FROM t3} -1 TAIL]  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-19.2 {  sqlite3_column_int $STMT 0} 1do_test capi3c-19.3 {  sqlite3_step $STMT} SQLITE_DONEdo_test capi3c-19.4 {  sqlite3_reset $STMT  db eval {DROP TABLE t3}  sqlite3_step $STMT} SQLITE_SCHEMAdo_test capi3c-19.4.2 {  sqlite3_errmsg $DB} {no such table: t3}do_test capi3c-19.5 {  sqlite3_reset $STMT  db eval {     CREATE TABLE t3(x,y);     INSERT INTO t3 VALUES(1,2);  }  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-19.6 {  sqlite3_column_int $STMT 1} 2do_test capi3c-19.99 {  sqlite3_finalize $STMT} SQLITE_OK# Make sure a change in a separate database connection does not# cause an SQLITE_SCHEMA return.#do_test capi3c-20.1 {  set STMT [sqlite3_prepare_v2 $DB {SELECT * FROM t3} -1 TAIL]  sqlite3 db2 test.db  db2 eval {CREATE TABLE t4(x)}  sqlite3_step $STMT} SQLITE_ROWdo_test capi3c-20.2 {  sqlite3_column_int $STMT 1} 2do_test capi3c-20.3 {  sqlite3_step $STMT} SQLITE_DONEdo_test capi3c-20.4 {  db2 close  sqlite3_finalize $STMT} SQLITE_OK# Test that sqlite3_step() sets the database error code correctly.# See ticket #2497.#ifcapable progress {  do_test capi3c-21.1 {    set STMT [sqlite3_prepare_v2 $DB {SELECT * FROM t3} -1 TAIL]    db progress 5 "expr 1"    sqlite3_step $STMT  } {SQLITE_INTERRUPT}  do_test capi3c-21.2 {    sqlite3_errcode $DB  } {SQLITE_INTERRUPT}  do_test capi3c-21.3 {    sqlite3_finalize $STMT  } {SQLITE_INTERRUPT}  do_test capi3c-21.4 {    set STMT [sqlite3_prepare $DB {SELECT * FROM t3} -1 TAIL]    db progress 5 "expr 1"    sqlite3_step $STMT  } {SQLITE_ERROR}  do_test capi3c-21.5 {    sqlite3_errcode $DB  } {SQLITE_ERROR}  do_test capi3c-21.6 {    sqlite3_finalize $STMT  } {SQLITE_INTERRUPT}  do_test capi3c-21.7 {    sqlite3_errcode $DB  } {SQLITE_INTERRUPT}}  finish_test

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -