首页
下载
文档
问答社区
视频
捐赠
源代码
AI 助理
赞助商
CRMEB
Apipost
腾讯云
微擎
禅道
51Talk
商业产品
Swoole AI 智能文档翻译器
Swoole-Compiler PHP 代码加密器
CRMEB 新零售社交电商系统
登录
注册
全部
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
发表新帖
swoole支持sqlite吗?
### 问题描述 swoole文档、hyperf文档、谷歌搜索都没有结果,是不支持么? swoole-cli非常好用,无依赖也不会对环境造成任何污染,不支持sqlite的话很可惜,因为很多小东西只需要sqlite就可以了 ### Swoole版本,PHP版本,以及操作系统版本信息 5.0.1 ### 相关代码 ``` <?php declare(strict_types=1); use Swoole\Coroutine; use function Swoole\Coroutine\go; use function Swoole\Coroutine\run; run(function () { go(function () { echo Coroutine::getCid() . ': ' . get_millisecond(), PHP_EOL; $db = new \PDO('sqlite:./data.sqlite3'); $stmt = $db->prepare('SELECT * FROM `sectors`'); $stmt->execute(); $data = $stmt->fetchAll(); // var_dump($data); $count = 0; foreach ($data as $vo) { $count++; $s = str_repeat('X', pow(1024, 2)); } echo Coroutine::getCid() . ': ' . $count . ', ' . get_millisecond(), PHP_EOL; }); go(function () { echo Coroutine::getCid() . ': ' . get_millisecond(), PHP_EOL; }); }); function get_millisecond(): float { list($microsecond, $time) = explode(' ', microtime()); //' '中间是一个空格 return (float) sprintf('%.0f', (floatval($microsecond) + floatval($time)) * 1000); } ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 期望看到 ``` 2: 1670900339699 3: 1670900342064 2: 80476, 1670900342051 ``` 实际上 ``` 2: 1670900339699 2: 80476, 1670900342051 3: 1670900342064 ``` sqlite造成了阻塞? \Swoole\Database\PDOPool依赖的PDOConfig只支持mysql所以没测试
发布于1年前 · 19 次浏览 · 来自
提问
新用户(923)
### 问题描述 swoole文档、hyperf文档、谷歌搜索都没有结果,是不支持么? swoole-cli非常好用,无依赖也不会对环境造成任何污染,不支持sqlite的话很可惜,因为很多小东西只需要sqlite就可以了 ### Swoole版本,PHP版本,以及操作系统版本信息 5.0.1 ### 相关代码 ``` <?php declare(strict_types=1); use Swoole\Coroutine; use function Swoole\Coroutine\go; use function Swoole\Coroutine\run; run(function () { go(function () { echo Coroutine::getCid() . ': ' . get_millisecond(), PHP_EOL; $db = new \PDO('sqlite:./data.sqlite3'); $stmt = $db->prepare('SELECT * FROM `sectors`'); $stmt->execute(); $data = $stmt->fetchAll(); // var_dump($data); $count = 0; foreach ($data as $vo) { $count++; $s = str_repeat('X', pow(1024, 2)); } echo Coroutine::getCid() . ': ' . $count . ', ' . get_millisecond(), PHP_EOL; }); go(function () { echo Coroutine::getCid() . ': ' . get_millisecond(), PHP_EOL; }); }); function get_millisecond(): float { list($microsecond, $time) = explode(' ', microtime()); //' '中间是一个空格 return (float) sprintf('%.0f', (floatval($microsecond) + floatval($time)) * 1000); } ``` ### 你期待的结果是什么?实际看到的错误信息又是什么? 期望看到 ``` 2: 1670900339699 3: 1670900342064 2: 80476, 1670900342051 ``` 实际上 ``` 2: 1670900339699 2: 80476, 1670900342051 3: 1670900342064 ``` sqlite造成了阻塞? \Swoole\Database\PDOPool依赖的PDOConfig只支持mysql所以没测试
赞
0
分享
收藏
提问
分享
讨论
建议
公告
开发框架
CodeGalaxy
评论
2022-12-16
Rango
不支持 `sqlite` 协程化,只能以同步方式运行。若 `SQL` 执行时间过长可能会导致进程阻塞。
赞
0
回复
微信公众号
热门内容
暂无回复的问答
- CodeGalaxy K3s 轻量集群节点之间如何实现负载均衡
- 关于openssl CURL WARNING swSSL_connect: SSL_connect(fd=69) failed. Error: error:141A318A:SSL routines:tls_process_ske_dhe:dh key too small[1|394]
- 多个模型如何进行事务异常回退?
- websocket开启wss报错
- 协程tcp服务器如何使用多进程?recv()方法接收信息,打印出来的pid一直是同一个。没用使用到多进程啊。