续上篇文章中的stmt使用方法。

本文介绍了MySQL预处理语句(prepared statement)的概念,它从4.1版本开始引入,通过mysqli_stmt类实现参数化SQL命令,提高处理效率。作者分享了使用stmt的方法,并表示自己是一个菜鸟,欢迎指正。

由于既然写就把不懂的捣鼓明白,这也是我一直有的问题,可能是个假程序猿,强迫自己去搞明白。

stmt介绍:

MySQL从4.1版本开始提供了一种名为预处理语句(prepared statement)的机制。它可以将整个命令向MySQL服务器发送一次,以后只有参数发生变化,MySQL服务器只需对命令的结构做一次分析就够了。这不仅大大减少了需要传输的数据量,还提高了命令的处理效率。可以用mysqli扩展模式中提供的mysqli_stmt类的对象,去定义和执行参数化的SQL命令。

那上篇文章中举例:
//需要执行的sql
$sql = "select member_miniapp_id,member_id from wxb_member_miniapp where member_miniapp_id=$member_miniapp_id";

//定义一个数组
$zxList = array();

//sql语句:$mysqli_dandu->prepare($sql)
if ($stmt = $mysqli_dandu->prepare($sql)) {
    // 处理打算执行的SQL命令
    $stmt->execute();
    // 输出查询的记录个数
    $stmt->bind_result($member_miniapp_id, $member_id);
    // 当查询结果绑定到变量中
    while ($stmt->fetch()) {
        $zxList[] = array(
            "member_miniapp_id" => $member_miniapp_id,
            "member_id" => $member_id
        );
    }
}

咱们打印一下$zxList这个数组:

这就是打印出来的数组。

 

bind_result()

预处理语句执行查询之后,利用该方法将变量绑定到所获取的字段

execute()

执行准备好的预处理语句

prepare()

无论是绑定参数还是绑定结果,都需要使用

该方法准备要执行的预处理语句

fetch()

获取预处理语句结果的每条记录,并将相应的字段赋给绑定结果

上面用到的方法名和介绍。

菜鸟一个,如有不对,敬请指点。ヾ(◍°∇°◍)ノ゙

 

`sqlite3_stmt *stmt;` 是SQLite数据库中用于表示预处理语句(prepared statement)的指针变量。预处理语句是一种优化数据库操作的方式,它允许你在执行之前准备一个SQL语句,然后多次执行这个语句,只需改变其中的参数值。以下是如何使用`sqlite3_stmt`的一般步骤: 1. 准备SQL语句: 使用`sqlite3_prepare_v2`函数准备你的SQL语句,该函数将SQL语句转换为预处理语句对象。 ```c int sqlite3_prepare_v2( sqlite3 *db, /* 数据库连接 */ const char *sql, /* SQL语句 */ int nByte, /* 预留空间 */ sqlite3_stmt **stmtPtr, /* 输出预处理语句指针 */ const char **zTail /* 输出SQL语句剩余部分 */ ); ``` 2. 绑定参数: 使用`sqlite3_bind_*`函数系列给预处理语句绑定参数。参数的绑定顺序应该和SQL语句中占位符的顺序一致。 ```c int sqlite3_bind_blob( sqlite3_stmt*, /* 预处理语句 */ int, /* 参数索引 */ const void*, /* 参数值 */ int nBytes, /* 参数值大小 */ void(*)(void*) /* 释放回调 */ ); // 其他绑定函数如sqlite3_bind_int, sqlite3_bind_text等也类似 ``` 3. 执行SQL语句: 使用`sqlite3_step`函数执行预处理语句。每次调用`sqlite3_step`会执行一次SQL语句。如果SQL语句是查询,则需要多次调用`sqlite3_step`直到返回` SQLITE_DONE`。 ```c int sqlite3_step(sqlite3_stmt *stmt); ``` 4. 清理资源: 执行完毕后,使用`sqlite3_finalize`函数清理预处理语句占用的资源。 ```c int sqlite3_finalize(sqlite3_stmt *stmt); ``` 示例代码: ```c sqlite3 *db; sqlite3_stmt *stmt; const char *sql = "INSERT INTO test (name, age) VALUES (?, ?);"; // 打开数据库连接 sqlite3_open("example.db", &db); // 准备SQL语句 if (sqlite3_prepare_v2(db, sql, -1, &stmt, NULL) != SQLITE_OK) { // 错误处理 } // 绑定参数 sqlite3_bind_text(stmt, 1, "John", -1, SQLITE_TRANSIENT); sqlite3_bind_int(stmt, 2, 25); // 执行SQL语句 sqlite3_step(stmt); // 清理资源 sqlite3_finalize(stmt); // 关闭数据库连接 sqlite3_close(db); ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值