Mysql的部分操作

前言

发现自己越来越大,却越来越害羞了,昨天下午和好多人玩了半天,虽然回来头晕晕的,不过还好的了。自己确实应该多接触接触人了呢。

正文

批量执行sql语句

最好不要把dml和dql语句混用,这样不利于控制

批量执行dml语句
dml语句可以混合使用 delete insert update 但是最好不要使用select

$sql = "dml语句1; dml语句2; dml语句3;";
$res = $mysql->multi_query($sql);
if(!$res) {
    echo "test失败".$mysql->error;
}
else {
    echo "执行成功";
}
批量执行dql语句
$sql = "dql语句1; dql语句2; dql语句3;";

if($mysql->multi_query($sql)){
    do {
        //取结果集中一个结果
        if($res = $mysql->store_result()){
            //取结果的每一行
            while ($row = $res->fetch_row()){
                $i=0;
                foreach ($row as $key => $value) {
                    if($i)
                        echo "  ";
                    echo "$value";
                    $i++;
                }
                echo "<br>";
            }
            echo "<br>---<br>";
            //资源用完,即时销毁
            $res->free();
        }
        //如果没有多余的结果了,就退出
        if(!$mysql->more_results())
            break;
    }while ($mysql->next_result());
}

事务处理

无法进行事务处理的解决方法

不知道为什么 一直没法回滚.好像是环境配置的问题?

显示当前autocommit值:
show VARIABLES like '%autocommit%';

设置autocommit为False
set autocommit = 0;

查看数据库test的表stu使用的存储引擎
show TABLE STATUS FROM test WHERE name = "stu";

发现我的引擎是MyISAM,效率更高,但不支持事务,不支持外键。
InnoDB效率略低,支持事务和外键。

更改 mysql目录下的my.ini
default-storage-engine=INNODB
然后重新建表
事务处理示例
$mysql->autocommit(false);
$sql1= "update stu set cost=cost-2 where id = 0";
$sql2= "update stu set cost1=cost+2 where id = 1";
$r1 = $mysql->query($sql1);
$r2 = $mysql->query($sql2);
if(!$r1 || !$r2){
    //$mysql->rollback();
    die( "错误".$mysql->error);
    $mysql->rollback();
}
else{
    echo "操作成功";
    //$mysql->commit();
    $mysqli->commit();
}

后记

以平和的心态去接触身边更多的人。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值