MySQLi面向对象--insertupdatedelete

Posted 寻觅beyond

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了MySQLi面向对象--insertupdatedelete相关的知识,希望对你有一定的参考价值。

执行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。

 

以上是关于MySQLi面向对象--insertupdatedelete的主要内容,如果未能解决你的问题,请参考以下文章

二十mysqli基于面向过程与面向对象的编程

mysqli 面向对象连接和面向过程连接

Mysqli面向对象操作数据库

MySQLi面向对象实践---预处理

MySQLi面向对象实践--select

mysqli操作mysql数据库(面向对象风格)