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);
<?php $base64_body = substr(strstr($_POST[base64],','),1); $data= base64_decode($base64_body); file_put_contents($_SERVER[&q...
php官方的超全局变量$_SERVER['PHP_SELF']也能直接获取,只不过如果url参数太多也会获取。下面提供一个方法获取/* * 获取当前PHP文件名称 */ if (!function_exists('phpself...
php官方已经提供了Iterator(迭代器)接口,通过网上资料的学习,目前看适合超大集合或者数组提取使用。学习一个函数的实现对比内存占用差距.使用迭代器和普通循环实现range()函数。(1).普通循环实现range()函数。function newrange($low, $h...
(1).前端文件:<form action="upload.php" method="post" enctype="multipart/form-data"> &...
【一】.介绍session由于HTTP是无状态的请求,创建一个会话需要保持必须需要身份标识。当用户第一次访问,PHP会为用户创建一个唯一的sessionid,并将sessionid通过cookie发送给浏览器,并在服务器的临时文件创建一个以sessionid为名的文件用来保存这个sessionid保...
(1).在PHP中可以查看的环境变量包括: (1.1).电脑环境变量 (2.1).服务器环境变量(2).getenv()函数获取一个环境变量的值.参数1是环境变量的key,参数2值为true的时候仅从你的电脑环境变量中查找,参数2值为false会从两种变量中全部查询//获取我电脑登录的用户名,输出A...