mysqli提供了异步执行sql的功能,类似于select轮询机制。先提交SQL到预发布,再去轮询查询是否ok。query的时候加上MYSQLI_ASYNC选项,query就直接提交到mysql,但是本身不等待执行结果。mysqli不亏是加强版的mysql扩展,可惜不是pdo
<?php /** * 执行SQL * @param $sql * @return mysqli */ function query($sql) { // 1.创建连接 $servername = "localhost"; $username = "root"; $password = "root"; $database = "test"; $conn = new mysqli($servername, $username, $password, $database); if ($conn->connect_error) { die("连接失败: " . $conn->connect_error); } // 2.异步提交SQL $conn->query($sql, MYSQLI_ASYNC); // 3.返回SQL连接 return $conn; } // 1.保存全部的Conn变量 $all_conn = []; // 2.循环提交异步SQL $i = 4; while ($i--) { $sql = "select scenes_name_cn from erp_allocation_scenes where id = $i"; $all_conn [] = query($sql, MYSQLI_ASYNC); } // 3.循环等待全部的结果 $allResult = []; do { $links = $errors = $reject = $all_conn; if (!mysqli_poll($links, $errors, $reject, 1)) { continue; } foreach ($all_conn as $conn) { if ($result = $conn->reap_async_query()) { $allResult[] = $result->fetch_row(); if (is_object($result)) { $result->free(); } } else { throw new mysqli_sql_exception(sprintf("MySQLi Error: %s", mysqli_error($conn))); } } } while (count($allResult) == 5); // 4.输出查询结果 print_r($allResult);
项目需要使用websocket推送最新订单,客户服务器非linux不支持swoole,因此使用原生,直接上代码(1).PHP服务端<?php ini_set('error_reporting', E_ALL ^ E_NOTICE); ini_set...
本篇文章不是讲解如何用.net开发自己的dll然后PHP通过com调用。主要记录PHP官方支持的DOTNET 基本语法如下:$obj = new DOTNET("assembly", "classname")a...
先在centos安装openssl,然后开始://生成私钥openssl genrsa -out rsa_private_key.pem 1024//生成公钥openssl rsa -in rsa_private_key.pem&...
应用场景:PHP模拟购买,商品数量大于0才能购买常见代码:<?php //连接数据库 $con=mysqli_connect("localhost","ihuohuo","927464cy","ihuohuo");...
php多进程应用场景主要是非web端,fpm下是不支持多进程的,非类linux操作系统都不支持,请在cli模式使用.可以使用多进程做任务分发,批量计算,批量文件处理,批量爬虫,网络运维等等。下面看一份简单的入门demo//创建子进程 $pid=pcntl_fork(); //返回-1,创建失败,不...
如果想在windows中执行php,并且让php脚本在后台运行,可以用下面的cmd命令start /b php D:\wwwroot\default\demo1\run.php例如上面的命令意思后台运行run.php,如果想用php编写异步代码: ...