linux下的數據庫也很多,有開源的,也有收費的。對於我們來說,肯定要使用開源的數據庫。以前用過Berkely DB,但是需要licience。所以結合效率性能以及大小限制,最終選定了Sqlite DB。我們對它的評價是“sqlite是一個優秀的完全free的開源數據項目”。
下面是一個簡單的使用實例:
int main( int argc, char **argv )
{
sqlite3 *db;
sqlite3_stmt * stmt;
const char *zTail;
//打開數據庫
int r = sqlite3_open("mysqlite.db",&db)
if(r){
printf("%s",sqlite3_errmsg(db));
}
//創建Table
sqlite3_prepare(db,
"CREATE TABLE players ( ID INTEGER PRIMARY KEY, name TEXT, age INTERER );",
-1,&stmt,&zTail);
sqlite3_step(stmt);
sqlite3_finalize(stmt);
//插入數據
sqlite3_prepare(db,
"INSERT INTO players (name,num) VALUES(?,?);",
-1,&stmt,&zTail);
char str[] = "Kevin";
int n = 23;
sqlite3_bind_text(stmt,1,str,-1,SQLITE_STATIC);
sqlite3_bind_int(stmt,2,n);
r = sqlite3_step(stmt);
if( r!=SQLITE_DONE){
printf("%s",sqlite3_errmsg(db));
}
sqlite3_reset(stmt);
//插入第二個數據
char str2[] = "Jack";
int n2 = 16;
sqlite3_bind_text(stmt,1,str2,-1,SQLITE_STATIC);
sqlite3_bind_int(stmt,2,n2);
r = sqltie3_step(stmt);
if( r!=SQLITE_DONE){
printf("%s",sqlite3_errmsg(db));
}
sqltie3_finalize(stmt);
//查詢所有數據
sqlite3_prepare(db,
"SELECT ID, name, num FROM players ORDER BY num;",
-1,&stmt,&zTail);
r = sqlite3_step(stmt);
int number;
int id;
const unsigned char * name;
while( r == SQLITE_ROW ){
id = sqlite3_column_int( stmt, 0 );
name = sqlite3_column_text( stmt,1 );
number = sqlite3_column_int( stmt, 2 );
printf("ID: %d Name: %s Age: %d /n",id,name,number);
sqlite3_step(stmt);
}
sqlite3_finalize(stmt);
//關閉數據庫
sqlite3_close(db);
return 0;
}
同時加上頭文件#include <stdio.h> #icnlude <sqlite3.h> 編譯運行gcc -o sample sample.c ./sample
結果如下:
ID:1 Name:Kevin Age:23
ID:2 Name:Jack Age:16
簡要說明一下SQLite數據庫執行SQL語句的過程
- ** 調用sqlite3_prepare()將SQL語句編譯爲sqlite內部一個結構體(sqlite3_stmt).該結構體中包含了將要執行的的SQL語句的信息.
** 如果需要傳入參數,在SQL語句中用'?'作爲佔位符,再調用sqlite3_bind_XXX()函數將對應的參數傳入.
** 調用sqlite3_step(),這時候SQL語句才真正執行.注意該函數的返回值,SQLITE_DONE和SQLITE_ROW都是表示執行成功, 不同的是SQLITE_DONE表示沒有查詢結果,象UPDATE,INSERT這些SQL語句都是返回SQLITE_DONE,SELECT查詢語句在 查詢結果不爲空的時候返回SQLITE_ROW,在查詢結果爲空的時候返回SQLITE_DONE.
** 每次調用sqlite3_step()的時候,只返回一行數據,使用sqlite3_column_XXX()函數來取出這些數據.要取出全部的數據需要 反覆調用sqlite3_step(). (注意, 在bind參數的時候,參數列表的index從1開始,而取出數據的時候,列的index是從0開始).
** 在SQL語句使用完了之後要調用sqlite3_finalize()來釋放stmt佔用的內存.該內存是在sqlite3_prepare()時分配的.
** 如果SQL語句要重複使用,可以調用sqlite3_reset()來清楚已經綁定的參數.