开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 52351|回复: 315
收起左侧

[2019开源大赛(第四届)] sqlite3.30.1 数据库模块+支持库(彻底解决多线程死锁问题)

    [复制链接]
发表于 2019-12-3 14:30:41 | 显示全部楼层 |阅读模式   四川省宜宾市
本次更新对于支持库来说,接口改动不大,模块版的话是尽量和支持库接口保持一致,所以对于以前的模块接口可能改动就大了。
要解决多线程问题,主要是对sqlite3的锁机制进行了解,和事务有密切的关系。本次更新的版本在开始事务时,增加了一个 事务锁状态 的参数。
拿简单的话来描述就是 开始事务 时如果
设置了 事务锁状态_ 立即 参数,那么这个时候其他线程的连接就不能写操作了,但是可以读操作,但是在提交事务时也要等待所有读操作完成了才能提交。
设置了 事务锁状态_ 独占 参数,那么这个时候其他线程的连接读写都不可以了。
在等待的时候就处于繁忙状态,我们可以设置 数据库.繁忙超时()来设置等待时间。

还有种情况还是会死锁,就是记录集没有关闭,而且这次更新的支持库和模块都是必须手动关闭记录集的,所以一定注意。

当然多进程和多线程是一个道理,具体操作看例子。

esqlite3 V1.1 相对于1.0的更新

1、增加了全局命令:
S3互斥体进入
S3互斥体退出
S3聚合上下文
S3取数据库自上下文

2、增加了zySqlite数据库 命令
繁忙超时
繁忙处理
取文件名
是否只读
取互斥体
是否自动提交
进度处理
取下一记录集
取总影响行

3、增加了 zySqlite记录集 命令
是否繁忙
是否只读
取数据库句柄
取行数

4、数据库.开始事务() 增加了 事务锁状态 参数,此参数在多线程中非常重要。

5、记录集必须手动关闭,任何内部方法都不再自动关闭。


sqlite3.30.1.rar (1.7 MB, 下载次数: 6450)

点评

执行SQL语句的过程慢如蜗牛,这个要怎么破?   湖北省荆门市  发表于 2020-7-1 17:47
感谢分享,用了很久,非常好   江苏省南通市  发表于 2019-12-3 16:35

评分

参与人数 37好评 +34 精币 +68 收起 理由
ysn2382617094ws + 1 + 2 YYDS~!
aiky123 + 1 新技能已get√
ku2017 + 1 + 2 sqlite.开始事务 (, #SQLITE3_事务锁状态_独占) 然后创建表就会失败,屏蔽这代码就成.
dych1688 + 1 + 2 支持开源~!感谢分享
倾风听雨声 + 1 + 1 支持开源~!感谢分享
已注销541904 + 1 + 2 感谢发布原创作品,精易因你更精彩!
木小果 + 1 + 2 支持开源~!感谢分享
万里晴空 + 1 + 2 感谢分享,很给力!~
广二爷xxoo + 1 + 1 如何保存...
老道 + 1 + 2 新技能已get√
frh35860 + 1 + 2 GUID类型的xx该怎么读取?
易语言资源网 + 1 + 5 支持开源~!感谢分享
秋来潮汐 + 1 + 2 支持开源~!感谢分享
弹指一泪点 + 1 + 2 感谢分享,很给力!~
jksuan + 1 感谢发布原创作品,精易因你更精彩!
梵笙 + 1 + 3 新技能已get√
街边太多人与车 + 1 + 2 这么厉害!必须给个红包鼓励下~
starhacker + 1 支持开源~!感谢分享
飞琉k + 1 + 2 感谢分享,很给力!~
小呀小百百 + 1 + 2 支持开源~!感谢分享
陌小北 + 1 + 2 支持开源~!感谢分享
tianning16 + 1 + 1 支持开源~!感谢分享
oursn + 1 新技能已get√
545176793 + 1 + 2 支持开源~!感谢分享
lqdefeng + 1 + 1 感谢分享,很给力!~
kyo9766 + 2 感谢分享,很给力!~
Aurora + 1 + 2 感谢发布原创作品,精易因你更精彩!
先锋小七 + 1 + 3 K大的必须要顶了
勾栏听曲 + 1 + 2 感谢分享,很给力!~
沫茗 + 1 + 2 感谢发布原创作品,精易因你更精彩!
z3201 + 1 + 2 支持开源~!感谢分享
猫神父 + 1 + 2 感谢分享,很给力!~
日勿日勿 + 1 + 2 感谢分享,很给力!~
tiantangmuxin + 1 + 2 支持开源~!感谢分享
cayter + 1 支持开源~!感谢分享
冰点 + 1 + 5 支持开源~!感谢分享
飘在空气里 + 1 支持zy大佬

查看全部评分

本帖被以下淘专辑推荐:

结帖率:0% (0/1)

签到天数: 5 天

发表于 4 天前 | 显示全部楼层   山东省潍坊市
感谢分享
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 21 天

发表于 2024-2-10 08:07:40 | 显示全部楼层   湖北省十堰市
支持分享,感谢.............
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 21 天

发表于 2024-2-7 20:33:23 | 显示全部楼层   湖北省十堰市
谢谢分享...........
回复 支持 反对

使用道具 举报

发表于 2024-1-26 13:43:54 | 显示全部楼层   吉林省长春市
666666666666666666666666666
回复 支持 反对

使用道具 举报

签到天数: 15 天

发表于 2024-1-25 16:28:40 | 显示全部楼层   广东省揭阳市
666666666666666666666
回复 支持 反对

使用道具 举报

发表于 2024-1-25 16:18:14 | 显示全部楼层   吉林省长春市
6666666666666
回复 支持 反对

使用道具 举报

结帖率:81% (21/26)

签到天数: 1 天

发表于 2024-1-10 22:00:04 | 显示全部楼层   山东省淄博市
请教博主两个问题。 1.能否在zySqlite.执行SQL()的语句里直接写事务语句段,而不用开始事务命令?比如:BEGIN IMMEDIATE …select…COMMIT; 2.InterLockedExchange函数(dll命令),能否理解为自带原子锁的赋值命令,多线程赋值时,不需要加锁(许可证),某线程一旦开始赋值其他线程自动等待?其参数除了整数型(long)逻辑型(bool)等数据类型外,能否自定义数据类型?
回复 支持 反对

使用道具 举报

结帖率:60% (3/5)

签到天数: 11 天

发表于 2024-1-8 16:47:27 | 显示全部楼层   河南省郑州市
支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:60% (3/5)

签到天数: 11 天

发表于 2024-1-8 16:47:06 | 显示全部楼层   河南省郑州市
        支持开源~!感谢分享
回复 支持 反对

使用道具 举报

结帖率:0% (0/1)

签到天数: 22 天

发表于 2023-12-9 22:36:33 | 显示全部楼层   浙江省嘉兴市
正需要,谢谢了!
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 诚聘英才| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 800073686,邮箱:800073686@b.qq.com
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表