博客列表 >0103预处理更新操作

0103预处理更新操作

yestrue的博客
yestrue的博客原创
2018年01月06日 00:21:56694浏览
<?php
//连接数据库,并创建连接对象$mysqli
require 'public/connect.php';

$sql2 = "SELECT id,name,email FROM user WHERE id=?";
$data2 = 5;
$mysqli_stmt2 = $mysqli->prepare($sql2);
$mysqli_stmt2->bind_param('i',$data2);
if ($mysqli_stmt2->execute()) {
	$mysqli_stmt2->store_result();
    //尽管结果集对象存在,但有可能是空的,所以有必要进行非空判断
    $num = $mysqli_stmt2->num_rows;  //获取到结果集中的记录数量
    echo '------num'.$num;
    if ($num == 1) {  //如果找到了,并且只有一条符合条件的记录,才允许更新
        //1. 先获取到当前记录更新前的信息,保存到变量$row中
        echo 111;
         $mysqli_stmt2->bind_result($id,$name,$email);
        $row = $mysqli_stmt2->fetch();
     //    while ($mysqli_stmt2->fetch()) {
     //    // printf ("%s (%s)\n", $name, $email);
    	// }
    	echo $id;

        //2.先创建要更新的数据,临时保存到一个数组中
        $data = ['name'=>'皮特', 'email'=>'z@test.cn', 'password'=>'123'];
        //3.创建更新的预处理SQL语句
        $sql = "UPDATE user SET name=?, email=?, password=sha1(?) WHERE id = ?";
        //4.用连接对象$mysqli的prepare()方法来创建一个预处理对象
        $mysqli_stmt = $mysqli->prepare($sql);
        //5.调用预处理对象中的bind_param()方法将实际参数与SQL语句中的占位符进行绑定
        $mysqli_stmt->bind_param('sssi', $data['name'], $data['email'], $data['password'], $id );
        //6. 执行预处理更新操作: execute(),返回布尔值,成功true,失败为false
        if($mysqli_stmt->execute()) {
            //如果更新成功,应该根据受影响的记录数量,再进行一次判断
            if ($mysqli_stmt->affected_rows) {  //如果更新成功,会返回整数: 1
                echo '<h3>更新成功</h3>';
            }else {
                echo '<h3 style="color:red">没有记录被更新</h3>';
            }

        } else {
            echo '<h3 style="color:red">更新失败'.$mysqli_stmt->error.'</h3>';
        }

        //释放结果集
        // $mysqli_result->free();
        //关闭预处理语句
        $mysqli_stmt->close();

    } else {
        echo '<h3 style="color:red">数据表中没有查询到需要更新的记录</h3>';
    }

} else {
    echo '<h3 style="color:red">查询失败,请检查~~'.$mysqli->error.'</h3>';
}

//关闭连接
$mysqli->close();


声明:本文内容转载自脚本之家,由网友自发贡献,版权归原作者所有,如您发现涉嫌抄袭侵权,请联系admin@php.cn 核实处理。
全部评论
文明上网理性发言,请遵守新闻评论服务协议