首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将数据插入MySql DB

将数据插入MySql DB
EN

Stack Overflow用户
提问于 2011-12-14 16:51:37
回答 3查看 251关注 0票数 0

我正在创建一个类,并且我有一个函数,通过它我想从一些输入中将一些数据插入到表中。如果我检查了表,但是一直收到错误消息"number of arguments in prepare in match the no of arg in bind_result“,它就会起作用。我也不知道我的方法是否正确。

代码语言:javascript
复制
private function insertData($foldName,$foldClass,$foldLink) {

    $sql = "INSERT INTO folders (folder_name,folder_class,folder_link) VALUES ('$foldName','$foldClass','$foldLink')";

    if($stmt = $this->connect->prepare($sql)) {
        $stmt->execute();
        $stmt->bind_result($foldName,$foldClass,$foldLink);
        $stmt->close();
        $error = false;
        $message['error'] = false;
        $message['message'] = "Data Successfuly Inserted";
        return json_encode($message);
    }
        else {
            $error = true;
            $message['error'] = true;
            $message['message'] = "Data Failed To Insert";
            return json_encode($message);
        }

}
EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-12-14 16:56:00

您根本不需要bind_result,因为您正在插入数据,并且没有选择任何数据。

但您应该使用已准备好的语句的核心功能。也就是说:安全地将变量传递给statement对象,而不是将它们的“原始”值插入SQL字符串:

代码语言:javascript
复制
$sql = "INSERT INTO folders (folder_name,folder_class,folder_link) VALUES (?,?,?)";
$stmt = $this->connect->prepare($sql);
$stmt->bind_param("sss", $foldName, $foldClass, $foldLink);
$stmt->execute();

(我还没有测试过它。)

票数 3
EN

Stack Overflow用户

发布于 2011-12-14 16:58:44

请看本手册页面上的第一个示例:http://php.net/manual/en/mysqli-stmt.bind-param.php

票数 2
EN

Stack Overflow用户

发布于 2011-12-14 17:31:35

如果要将表的数据作为一个整体清空,请使用truncate查询:

代码语言:javascript
复制
TRUNCATE TABLE `table_name`

这会将auto_increment重置为1,但是如果您不想清空整个表,您可以改为alter它:

代码语言:javascript
复制
ALTER TABLE `table_name` auto_increment = 1
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8501651

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档