doc: update the SQLite C interoperability example
parent
006d260d20
commit
d44fe50953
41
doc/docs.md
41
doc/docs.md
|
@ -1713,15 +1713,29 @@ fn main(){
|
||||||
#flag -lsqlite3
|
#flag -lsqlite3
|
||||||
#include "sqlite3.h"
|
#include "sqlite3.h"
|
||||||
|
|
||||||
struct C.sqlite3
|
// See also the example from https://www.sqlite.org/quickstart.html
|
||||||
struct C.sqlite3_stmt
|
struct C.sqlite3{}
|
||||||
|
struct C.sqlite3_stmt{}
|
||||||
|
|
||||||
fn C.sqlite3_open(charptr, C.sqlite3)
|
type FnSqlite3Callback fn(voidptr, int, &charptr, &charptr) int
|
||||||
fn C.sqlite3_column_int(stmt C.sqlite3_stmt, n int) int
|
|
||||||
// Or just define the type of parameter & leave C. prefix
|
fn C.sqlite3_open(charptr, &&C.sqlite3) int
|
||||||
fn C.sqlite3_prepare_v2(sqlite3, charptr, int, sqlite3_stmt, charptr) int
|
fn C.sqlite3_close(&C.sqlite3) int
|
||||||
fn C.sqlite3_step(sqlite3)
|
fn C.sqlite3_column_int(stmt &C.sqlite3_stmt, n int) int
|
||||||
fn C.sqlite3_finalize(sqlite3_stmt)
|
// ... you can also just define the type of parameter & leave out the C. prefix
|
||||||
|
fn C.sqlite3_prepare_v2(&sqlite3, charptr, int, &&sqlite3_stmt, &charptr) int
|
||||||
|
fn C.sqlite3_step(&sqlite3_stmt)
|
||||||
|
fn C.sqlite3_finalize(&sqlite3_stmt)
|
||||||
|
fn C.sqlite3_exec(db &sqlite3, sql charptr, FnSqlite3Callback, cb_arg voidptr, emsg &charptr) int
|
||||||
|
fn C.sqlite3_free(voidptr)
|
||||||
|
|
||||||
|
fn my_callback(arg voidptr, howmany int, cvalues &charptr, cnames &charptr) int {
|
||||||
|
for i in 0..howmany {
|
||||||
|
print('| ${cstring_to_vstring(cnames[i])}: ${cstring_to_vstring(cvalues[i]):20} ')
|
||||||
|
}
|
||||||
|
println('|')
|
||||||
|
return 0
|
||||||
|
}
|
||||||
|
|
||||||
fn main() {
|
fn main() {
|
||||||
path := 'users.db'
|
path := 'users.db'
|
||||||
|
@ -1733,7 +1747,16 @@ fn main() {
|
||||||
C.sqlite3_step(stmt)
|
C.sqlite3_step(stmt)
|
||||||
nr_users := C.sqlite3_column_int(stmt, 0)
|
nr_users := C.sqlite3_column_int(stmt, 0)
|
||||||
C.sqlite3_finalize(stmt)
|
C.sqlite3_finalize(stmt)
|
||||||
println(nr_users)
|
println('There are $nr_users users in the database.')
|
||||||
|
//
|
||||||
|
error_msg := charptr(0)
|
||||||
|
query_all_users := 'select * from users'
|
||||||
|
rc := C.sqlite3_exec(db, query_all_users.str, my_callback, 7, &error_msg)
|
||||||
|
if rc != C.SQLITE_OK {
|
||||||
|
eprintln( cstring_to_vstring(error_msg) )
|
||||||
|
C.sqlite3_free(error_msg)
|
||||||
|
}
|
||||||
|
C.sqlite3_close(db)
|
||||||
}
|
}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue