Join 4,000+ others and never miss out on new tips, tutorials, and more.
4.x is outdated, please check the latest version 22.x
Latest version:
pecl install openswoole-22.1.2
The swoole contains the swoole async MySQL client. It has realized the protocal of MySQL and is a replacement of the other sync MySQL clients: libmysqlclient, mysqlnd, mysqli.
<?php
$db = new swoole_mysql;
$server = array(
'host' => '192.168.56.102',
'port' => 3306,
'user' => 'test',
'password' => 'test',
'database' => 'test',
'charset' => 'utf8',
'timeout' => 2,
);
$db->connect($server, function ($db, $r) {
if ($r === false) {
var_dump($db->connect_errno, $db->connect_error);
die;
}
$sql = 'show tables';
$db->query($sql, function(swoole_mysql $db, $r) {
if ($r === false)
{
var_dump($db->error, $db->errno);
}
elseif ($r === true )
{
var_dump($db->affected_rows, $db->insert_id);
}
var_dump($r);
$db->close();
});
});
Swoole\MySQL::construct()
Alias: swoole_mysql->construct()
Swoole\MySQL::on($event_name, callable $callback)
Alias: swoole_mysql->on($event_name, callable $callback)
Register callback function based on event name, current only 'Clost' event is supported.
Swoole\MySQL::connect(array $serverConfig, callable $callback)
Alias: swoole_mysql->connect(array $serverConfig, callable $callback);
Connect to the remote MySQL server.
Example:
<?php
// serverConfig
$server = array(
'host' => '192.168.56.102',
'user' => 'test',
'password' => 'test',
'database' => 'test',
'charset' => 'utf8',
);
// callback function
function onConnect(swoole_mysql $db, bool $result);
Swoole\MySQL::escape(string $str)
Alias: swoole_mysql->escape(string $str)
Escape SQL strings to avoid SQL injection attacks.
Example:
<?php
$db = new swoole_mysql;
$server = array(
'host' => '127.0.0.1',
'user' => 'root',
'password' => 'root',
'database' => 'test',
);
$db->connect($server, function ($db, $result) {
$data = $db->escape("abc'efg\r\n");
});
Swoole\MySQL::query($sql, callable $callback)
Alias: swoole_mysql->query($sql, callable $callback)
Run SQL query.
Callback function:
function onSQLReady(swoole_mysqli $link, mixed $result);
Swoole\MySQL::begin(callable $callback)
Alias: swoole_mysql->begin(callable $callback)
Start a MySQL transaction.
Example:
<?php
$db->begin(function( $db, $result) {
$db->query("update userinfo set level = 22 where id = 1", function($db, $result) {
$db->rollback(function($db, $result) {
echo "commit ok\n";
});
});
});
Swoole\MySQL::commit(callable $callback)
Alias: swoole_mysql->commit(callable $callback)
Commit the MySQL transaction.
Example:
<?php
$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::rollback(callable $callback)
Alias: swoole_mysql->rollback(callable $callback)
Rollback the MySQL transaction.
Swoole\MySQL->close()
Alias: swoole_mysql->close()
Close the MySQL connection.