sqlite3_exec(db,“insert into dy values(‘%d’,’%s’,’%s’),NULL,NULL,&err
时间: 2023-11-12 21:03:56 浏览: 58
这段代码中,使用了 SQLite3 的 C API 中的 sqlite3_exec() 函数来执行 SQL 语句。
具体来说,这条 SQL 语句是将三个值插入到名为 "dy" 的表中。第一个值是一个整数,第二个值和第三个值是两个字符串。这些值分别用 %d、%s 和 %s 表示,对应后面传入的三个参数。NULL 和 &err 作为最后两个参数传递给函数,分别表示不需要回调函数和错误信息存储变量。
需要注意的是,这段代码存在 SQL 注入漏洞,因为它没有对传入的字符串进行任何过滤或转义。如果这些字符串中包含 SQL 关键字或特殊字符,可能会导致 SQL 注入攻击。为了避免这种情况,建议使用参数化查询或者进行适当的输入过滤和转义。
相关问题
sqlite3_prepare_v2函数和sqlite3_exec函数比较
`sqlite3_prepare_v2`和`sqlite3_exec`函数都是SQLite数据库的API函数,但在功能和使用方面有所不同。
`sqlite3_prepare_v2`函数是用于准备SQL语句的,它需要三个参数:一个SQLite数据库连接对象,一个SQL语句字符串和一个指向已编译SQL语句的指针。它将SQL语句编译为字节码,但并不执行该语句,因此它通常与`sqlite3_step`函数结合使用,以逐步执行SQL语句。
例如,以下代码演示了如何使用`sqlite3_prepare_v2`和`sqlite3_step`函数来执行SELECT语句:
```
sqlite3_stmt* stmt;
const char* sql = "SELECT * FROM mytable";
sqlite3_prepare_v2(db, sql, -1, &stmt, NULL);
while (sqlite3_step(stmt) == SQLITE_ROW) {
// 处理结果集
}
sqlite3_finalize(stmt);
```
相比之下,`sqlite3_exec`函数可以在一次调用中执行一条完整的SQL语句。它需要四个参数:一个SQLite数据库连接对象,一个SQL语句字符串,一个回调函数和一个回调函数的第一个参数。该回调函数将在每次执行SQL语句时调用,以处理结果集或执行其他自定义操作。
例如,以下代码演示了如何使用`sqlite3_exec`函数来执行INSERT语句:
```
const char* sql = "INSERT INTO mytable (id, name) VALUES (1, 'John')";
sqlite3_exec(db, sql, NULL, NULL, NULL);
```
总的来说,`sqlite3_prepare_v2`函数比`sqlite3_exec`函数更灵活,因为它允许逐步执行SQL语句,并提供更多的控制和错误处理机制。但是,如果您只需要执行一次简单的SQL语句,则`sqlite3_exec`函数可能更方便。
#include <stdio.h> #include "sqlite3.h" static int callback(void* NotUsed, int argc, char** argv, char** azColName) { int i; for (i = 0; i < argc; i++) { printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL"); } printf("\n"); return 0; } int main(int argc, char** argv) { sqlite3* db; char* zErrMsg = 0; int rc; char* dbfile = "test.db"; char* sql; rc = sqlite3_open(dbfile, &db); if (rc) { fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db)); sqlite3_close(db); return -1; } //在数据库中创建一个名为person的表 sql = "create table person(id int primary key,first_name text,last_name text);"; rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); if (rc != SQLITE_OK) { fprintf(stderr, "SQL error: %s\n", zErrMsg); sqlite3_free(zErrMsg); } sql = "insert into person values (1,'zhang','san');" "insert into person values (2,'li','si');" "insert into person values (3,'wang','wu');" "insert into person values (4,'zhao','liu');" "insert into person values (5,'sun','qi');"; rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); if (rc != SQLITE_OK) { fprintf(stderr, "SQL error: %s\n", zErrMsg); sqlite3_free(zErrMsg); } sql = "select * from person where id=3;"; rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); if (rc != SQLITE_OK) { fprintf(stderr, "Failed to select data: %s\n", zErrMsg); sqlite3_free(zErrMsg); } sql = "delete from person where id=5;"; rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); if (rc != SQLITE_OK) { fprintf(stderr, "Failed to delete data: %s\n", zErrMsg); sqlite3_free(zErrMsg); } sql = "select * from person;"; rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); if (rc != SQLITE_OK) { fprintf(stderr, "SQL error: %s\n", zErrMsg); sqlite3_free(zErrMsg); } sqlite3_close(db); return 0; }添加注释
//引入头文件
#include <stdio.h>
#include "sqlite3.h"
//回调函数
static int callback(void* NotUsed, int argc, char** argv, char** azColName) {
int i;
for (i = 0; i < argc; i++) {
printf("%s = %s\n", azColName[i], argv[i] ? argv[i] : "NULL");
}
printf("\n");
return 0;
}
//主函数
int main(int argc, char** argv) {
sqlite3* db;
char* zErrMsg = 0;
int rc;
char* dbfile = "test.db";
char* sql;
rc = sqlite3_open(dbfile, &db); //连接数据库
if (rc) {
fprintf(stderr, "Can't open database: %s\n", sqlite3_errmsg(db));
sqlite3_close(db);
return -1;
}
sql = "create table person(id int primary key,first_name text,last_name text);";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); //创建表
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
sql = "insert into person values (1,'zhang','san');" "insert into person values (2,'li','si');" "insert into person values (3,'wang','wu');" "insert into person values (4,'zhao','liu');" "insert into person values (5,'sun','qi');";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); //插入数据
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
sql = "select * from person where id=3;";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); //查询数据
if (rc != SQLITE_OK) {
fprintf(stderr, "Failed to select data: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
sql = "delete from person where id=5;";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); //删除数据
if (rc != SQLITE_OK) {
fprintf(stderr, "Failed to delete data: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
sql = "select * from person;";
rc = sqlite3_exec(db, sql, callback, 0, &zErrMsg); //查询数据
if (rc != SQLITE_OK) {
fprintf(stderr, "SQL error: %s\n", zErrMsg);
sqlite3_free(zErrMsg);
}
sqlite3_close(db); //关闭数据库连接
return 0;
}
阅读全文