摘要:问题描述我自己以扩展为基础,封装了一个异步任务服务器框架,数据库操作使用扩展,但是在插入数据的时候,出现了异常情况,具体状况如下表引擎的正常插入,没有问题表引擎查询都可以的,但是插入失败,出现回滚现象,字段变化,表的变化,正常返回解决过程监
问题描述
我自己以swoole扩展为基础,封装了一个异步任务服务器框架,数据库操作使用pdo扩展,但是在插入数据的时候,出现了异常情况,具体状况如下:
MyISAM 表引擎的insert正常插入,没有问题
Innodb表引擎查询都可以的,但是插入失败,出现回滚现象,auto_increment字段变化,表的rows变化,lastInsertId正常返回
解决过程监控mysql日志,查看状态
进入mysql命令行,查看mysql的general-log状态
show global variables like "%genera%";
如果没有开启,执行如下命令
;general_log_file_path修改为自己象牙iode set global general_log_file="general_log_file_path"; set global general_log=on
然后监控日志,发现insert语句发送到mysql端了
查看innodb engine状态
怀疑是不是死锁了,查看innodb 的状态
show engine innodb status;
没有发现异常
到这里,已经有些抓狂了
然后google,各种尝试,都不得要领
纠结了挺长时间,后来看到有人说innodb引擎把insert当作一个事物处理,瞬间想到了一个问题,是不是pdo扩展里面,没有自动提交?
直接写了个简单的mysql pdo 连接数据库,并且插入数据到innodb表里面,结果没有任何问题,成功了,然后我就想到pdo里面有个参数PDO::ATTR_AUTOCOMMIT,是不是他在作怪?
使用getAttribute(PDO::ATTR_AUTOCOMMIT)) 获取他的值,打印,发现是1,证明是自动提交事务的
然后在我封装的框架里面,我打印了他的值,发现是0,问题找到
那么,在插入的时候,如何提交事务?
连接数据库的时候,options里面设置 PDO::ATTR_AUTOCOMMIT 为 1
插入操作的时候,自己执行commit,显式的完成一次事务,我采用了这个方法
遗留问题是,同样的PHP版本,为啥多带带的连接 PDO::ATTR_AUTOCOMMIT为1 ,在启动的swoole-httpserer里面是0,我没有继续深入。
总结解决问题一定要持之以恒,不要放弃,那么问题最终会获得比较理想的处理结果
另外要注意方法,尝试不同的思路,我就是一直没有想到可能是事务自动提交导致的,以至于浪费了很多时间
最后,希望goolge不要被封锁的这么严重,妈的,百度 必应搜索结果完全没法和google比,程序员,离不开google
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/46518.html
摘要:问题描述我自己以扩展为基础,封装了一个异步任务服务器框架,数据库操作使用扩展,但是在插入数据的时候,出现了异常情况,具体状况如下表引擎的正常插入,没有问题表引擎查询都可以的,但是插入失败,出现回滚现象,字段变化,表的变化,正常返回解决过程监 问题描述 我自己以swoole扩展为基础,封装了一个异步任务服务器框架,数据库操作使用pdo扩展,但是在插入数据的时候,出现了异常情况,具体状况如...
摘要:昨天运营提了个需求,要拉下每个玩家在前天一天内的消耗钻石数量,想着很简单,就是根据玩家分组下,然后用函数求和就好了。先是怀疑记的日志里可能存在或者为空的,于是去掉来试试,发现并没有出现空的情况,如下。 昨天运营提了个需求,要拉下每个玩家在前天一天内的消耗钻石数量,想着很简单,就是根据玩家id group by分组下,然后用sum函数求和就好了。因为涉及到公司隐私,故将钻石消耗表简化为如...
摘要:在不指定的情况下,默认版本号为。具体示例如下在需要更新数据库的模式时,需要更新版本号。此时我们指定一个高于之前版本的版本号,就会触发事件。数据操作事务在中,我们也能够使用事务来进行数据库的操作。 概述 本文通过对IndexedDB的使用方法和使用场景进行相关介绍,对常见的问题进行解答。 同时,因为MDN中的相关文档缺乏相关逻辑性,所以不容易理解。本文将通过项目中常见的数据存储和操作需求...
摘要:导入这个数据库加密包主要是为了数据库升级的时候使用的。上线时改成加密数据库即可。数据库升级这里可以重复添加文件。好了,这样的话的很多问题都已经解决了,接下来就让我们愉快的在项目中添加这个数据库包吧。 现在在Android中使用的数据库一般都是用的GreenDao,我们准备使用GreenDao的时候从网上看了很多文章,感觉很多技术点都不是我们关注的重点,经过实践以后觉得好多文章的内容都不...
阅读 2785·2023-04-25 17:46
阅读 3313·2021-11-25 09:43
阅读 859·2021-11-18 10:02
阅读 2868·2021-10-14 09:43
阅读 2555·2021-10-13 09:40
阅读 1347·2021-09-28 09:35
阅读 1979·2019-08-30 15:52
阅读 3037·2019-08-30 14:06