mysql删除语句面向对象_MySQLi面向对象实践--insert、update、delete

本文介绍了如何使用MySQL进行数据操作,包括insert语句插入记录,update语句更新指定条件下的数据,以及delete语句删除多余或过期的数据。特别关注了affected_rows和insert_id的区别,以及它们在错误处理中的应用。
摘要由CSDN通过智能技术生成

执行insert

$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

$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();

?>

执行删除

$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。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值