温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

swoole学习之异步Mysql

发布时间:2021-03-18 11:43:40 来源:亿速云 阅读:176 作者:小新 栏目:编程语言

这篇文章将为大家详细讲解有关swoole学习之异步Mysql,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

swoole学习之异步Mysql

官方示例:

$db = new swoole_mysql();$server = array(
    'host' => '127.0.0.1',
    'port' => 3306,
    'user' => 'test',
    'password' => 'test',
    'database' => 'test',
    'charset' => 'utf8', //指定字符集
    'timeout' => 2,  // 可选:连接超时时间(非查询超时时间),默认为SW_MYSQL_CONNECT_TIMEOUT(1.0));$db->connect($server, function ($db, $result) {
    if ($result === false) {
        var_dump($db->connect_errno, $db->connect_error);
        die;
    }
    $sql = 'show tables';
    $db->query($sql, function(swoole_mysql $db, $result) {
        if ($result === false)
        {
            var_dump($db->error, $db->errno);
        }
        elseif ($result === true )
        {
            var_dump($db->affected_rows, $db->insert_id);
        }
        var_dump($result);
        $db->close();
    });});

常用函数:

connect($config, $callback) 连接数据库
$config= array(
    'host' => '127.0.0.1',
    'port' => 3306,
    'user' => 'test',
    'password' => 'test',
    'database' => 'test',
    'charset' => 'utf8', //指定字符集
    'timeout' => 2,  // 可选:连接超时时间(非查询超时时间),默认为SW_MYSQL_CONNECT_TIMEOUT(1.0));
  • host 主机ip地址

  • port端口号,默认3306

  • user用户名

  • password密码

  • database选择的数据库

  • charset设置客户端字符集

  • timeout 连接超时时间,默认1.0

$callback回调函数function($db, $result )

  • $db swoole_mysql的对象

  • $result 返回值 , 为true的时候才能执行query , 为false的时候 , 可以通过$db->connect_errno$db->connect_error获取错误码和错误信息

query($sql, $callback) 执行sql语句
$sql = "select * from test ";$db->query($sql,function($link,$result){});

$sql为要执行的SQL语句
$callback回调函数
每个MySQLi连接只能同时执行一条SQL,必须等待返回结果才能执行下一条SQL

回调函数function($link,$result)

  • 当SQL执行失败即$result == false的时候,通过$link->error可获得错误信息,$link->errno获得错误码

  • 执行成功,$result == true ,通过$link->affected_rows获得受影响的行数 , $link->insert_id获得insert操作的自增ID

  • 执行成功 且SQL为查询语句的时候, $result返回的是查询结果数组

close关闭连接
 $db->close();

将整个SQL连接关闭

on($event_name,$callback) 回调函数

目前swoole_mysql只有一个onClose回调函数

//mysql连接关闭时,自动触发$db->on('close',function($db){
	echo "mysql connection is closed";});

swoole_mysql中的事物

在官方文档中有详细介绍:

begin(function($db,$result))开启事物
  • 启动一个MySQL事务,事务启动成功会回调指定的函数

  • commitrollback结合实现MySQL事务处理

  • 同一个MySQL连接对象,同一时间只能启动一个事务

  • 必须等到上一个事务commit或rollback才能继续启动新事务

  • 否则底层会抛出Swoole\MySQL\Exception异常,异常code21

commit($callback)提交事物
  • 提交事务,当服务器返回响应时回调此函数

  • 必须先调用begin启动事务才能调用commit否则底层会抛出Swoole\MySQL\Exception异常

  • 异常code22

rollback($callback)事物回滚
  • 必须先调用begin启动事务才能调用rollback否则底层会抛出Swoole\MySQL\Exception异常

  • 异常code22

官方示例:

$db->begin(function( $db, $result) {
    $db->query("update userinfo set level = 22 where id = 1", function($db, $result) {
        $db->commit(function($db, $result) {
            echo "commit ok\n";
        });
    });});

关于“swoole学习之异步Mysql”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI