zoukankan      html  css  js  c++  java
  • MySQLi面向对象实践--insert、update、delete

    执行insert

    <?php
        $mysqli = new Mysqli();
        $mysqli->connect("localhost","root","root","test");
        if ( $mysqli->connect_errno ){
            die( $mysqli->connect_error );
        }
        $mysqli->set_charset("utf8");
        $sql = "insert into mysqli (id, name) values (null, 'liming')";
        $res = $mysqli->query($sql);
        var_dump($res);
        if( $res ){
            echo $mysqli->insert_id; 
        } else {
            echo "error:".$mysqli->errno." : ".$mysqli->error;
        }
        $mysqli->close();
    ?>

      

    执行update

    <?php
        $mysqli = new Mysqli();
        $mysqli->connect("localhost","root","root","test");
        if ( $mysqli->connect_errno ){
            die( $mysqli->connect_error );
        }
        $mysqli->set_charset("utf8");
        $sql = "update mysqli set name = 'doUpdate' where id>8;";
        $res = $mysqli->query($sql);
        var_dump($res);
        if( $res ){
            echo $mysqli->affected_rows; //返回上一条SQL语句影响的记录条数
        } else {
            echo "error:".$mysqli->errno." : ".$mysqli->error;
        }
        $mysqli->close();
    ?>

      

    执行删除

    <?php
        $mysqli = new Mysqli();
        $mysqli->connect("localhost","root","root","test");
        if ( $mysqli->connect_errno ){
            die( $mysqli->connect_error );
        }
        $mysqli->set_charset("utf8");
        $sql = "delete  from mysqli where id>8;";
        $res = $mysqli->query($sql);
        var_dump($res);
        if( $res ){
            echo $mysqli->affected_rows; //返回上一条SQL语句影响的记录条数
        } else {
            echo "error:".$mysqli->errno." : ".$mysqli->error;
        }
        $mysqli->close();
    ?>
    

      

    注意一

    对于affected_rows的值有这么几种情况,以删除记录为例

      1 ->SQL语句正常执行,删除的记录数大于0,则affected_rows为受影响的记录数

      2 ->SQL语句正常执行,没有一条记录符合条件,也就是删除的记录为0,则affected_rows为0

      3 ->SQL语句错误,也就是说SQL语句没有真正执行,因为出现错误就stop了,此时affected_rows的值为-1

    注意二

      insert_id是指当前得到SQL语句执行前,数据库表中的auto_increment值(该值可以通过在数据库命令行中执行show create table tableName来查看),而不是SQL语句插入之后auto_increment的值。

      假设第一次数据库为空,插入1条数据之后,id变为1,而auto_increment变为2,然后通过insert 语句一次性的插入多条数据,然后再获取auto_increment的值(即insert_id),值不会变为最后插入的那一条数据的主键自增的id,而是执行插入多条数据之前的2。

      如果表中没有auto_increment,则insert_id返回0。

  • 相关阅读:
    linux下安装MongoDB
    Prometheus+Grafana企业监控系统
    微服务项目运维管理
    Jenkins CI&CD 自动化发布项目实战(上篇)
    Docker入门与进阶(下)
    Docker入门与进阶(上)
    Git&Gitlab开发流程与运维管理
    报名中|面基啦~首站深圳线下云原生技术开放日来了
    kubernetes 降本增效标准指南| 容器化计算资源利用率现象剖析
    使用 Velero 跨云平台迁移集群资源到 TKE
  • 原文地址:https://www.cnblogs.com/-beyond/p/8457580.html
Copyright © 2011-2022 走看看