<?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(); ?>
<?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的值有这么几种状况,以删除记录为例php
1 ->SQL语句正常执行,删除的记录数大于0,则affected_rows为受影响的记录数mysql
2 ->SQL语句正常执行,没有一条记录符合条件,也就是删除的记录为0,则affected_rows为0sql
3 ->SQL语句错误,也就是说SQL语句没有真正执行,由于出现错误就stop了,此时affected_rows的值为-1数据库
insert_id是指当前获得SQL语句执行前,数据库表中的auto_increment值(该值能够经过在数据库命令行中执行show create table tableName来查看),而不是SQL语句插入以后auto_increment的值。spa
假设第一次数据库为空,插入1条数据以后,id变为1,而auto_increment变为2,而后经过insert 语句一次性的插入多条数据,而后再获取auto_increment的值(即insert_id),值不会变为最后插入的那一条数据的主键自增的id,而是执行插入多条数据以前的2。命令行
若是表中没有auto_increment,则insert_id返回0。blog