开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 1007|回复: 4
收起左侧

[已解决] 关于sqlite数据库问题

 关闭 [复制链接]
结帖率:100% (17/17)
发表于 2020-4-22 10:46:24 | 显示全部楼层 |阅读模式   四川省眉山市
20精币
按这个方式写不能全部写进去,只有写入数据1子程序成功了
.版本 2
.支持库 sqlite3
.支持库 EThread
.支持库 spec

.程序集 窗口程序集_启动窗口
.程序集变量 数据库, Sqlite数据库
.程序集变量 表, Sqlite表

.子程序 _按钮1_被单击

数据库.打开 (取运行目录 () + “\测试.db”, )
表.打开 (“测试”, 数据库)
启动线程 (&写入数据1, , )
延时 (10)
启动线程 (&写入数据2, , )
延时 (10)
启动线程 (&写入数据3, , )


.子程序 写入数据1
.局部变量 计次, 整数型

数据库.开始事务 ()
表.到尾记录 ()
.计次循环首 (100, 计次)
    表.插入 ()
    表.写字段值 (1, “一号数据” + 到文本 (计次))
    表.到下一记录 ()
    .如果真 (表.提交 () = 假)
        调试输出 (“一号数据” + 到文本 (计次))
    .如果真结束

.计次循环尾 ()
数据库.提交事务 ()

.子程序 写入数据2
.局部变量 计次, 整数型

数据库.开始事务 ()
表.到尾记录 ()
.计次循环首 (100, 计次)
    表.插入 ()
    表.写字段值 (1, “二号数据” + 到文本 (计次))
    表.到下一记录 ()
    .如果真 (表.提交 () = 假)
        调试输出 (“二号数据” + 到文本 (计次))
    .如果真结束

.计次循环尾 ()
数据库.提交事务 ()

.子程序 写入数据3
.局部变量 计次, 整数型

数据库.开始事务 ()
表.到尾记录 ()
.计次循环首 (100, 计次)
    表.插入 ()
    表.写字段值 (1, “三号数据” + 到文本 (计次))
    表.到下一记录 ()
    .如果真 (表.提交 () = 假)
        调试输出 (“三号数据” + 到文本 (计次))
    .如果真结束

.计次循环尾 ()
数据库.提交事务 ()


最佳答案

查看完整内容

sqlite3好像不支持多线程吧。如果多线程或者多用户操作,还是用mysql等网络数据库吧

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳

结帖率:100% (2/2)
发表于 2020-4-22 10:46:25 | 显示全部楼层   内蒙古自治区呼和浩特市
落月无痕 发表于 2020-4-24 08:58
我的意思是多线程或多用户能同时写入数据库

sqlite3好像不支持多线程吧。如果多线程或者多用户操作,还是用mysql等网络数据库吧

评分

参与人数 1荣誉 +1 收起 理由
项目部004 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (17/17)

签到天数: 17 天

 楼主| 发表于 2020-4-22 10:48:19 | 显示全部楼层   四川省眉山市
源码.......

数据库测试.e

844.69 KB, 下载次数: 6

回复

使用道具 举报

结帖率:0% (0/1)
发表于 2020-4-22 19:52:51 | 显示全部楼层   上海市上海市
.版本 2
.支持库 sqlite3
.支持库 iext

.程序集 数据库程序集
.程序集变量 数据库, Sqlite数据库
.程序集变量 数据库_表, Sqlite表
.程序集变量 数据库_记录集, Sqlite记录集
.程序集变量 数据库_字段信息, Sqlite字段信息, , "5"

.子程序 数据库操作
.参数 类型, 文本型
.参数 文件名称, 文本型, 可空
.参数 文件大小, 文本型, 可空
.参数 文件时间, 文本型, 可空
.参数 文件源路径, 文本型, 可空
.参数 文件现路径, 文本型, 可空
.参数 超级列表框, 超级列表框, 可空
.参数 透明标签, 透明标签, 可空
.参数 是否文件夹, 逻辑型, 可空
.局部变量 计次, 整数型
.局部变量 索引, 整数型
.局部变量 临时文本, 文本型

.判断开始 (数据库.打开 (运行目录 + “fydb.db”, 真) = 真)
    .判断开始 (类型 = “添加”)
        .判断开始 (是否文件夹 = 假)
            .判断开始 (数据库.表是否存在 (“db_file”) = 假)
                数据库_字段信息 [1].名称 = “name”
                数据库_字段信息 [2].名称 = “kb”
                数据库_字段信息 [3].名称 = “time”
                数据库_字段信息 [4].名称 = “spatch”
                数据库_字段信息 [5].名称 = “npatch”
                连续赋值 (#备注型, 数据库_字段信息 [1].类型, 数据库_字段信息 [2].类型, 数据库_字段信息 [3].类型, 数据库_字段信息 [4].类型, 数据库_字段信息 [5].类型)
                数据库.创建表 (“db_file”, 数据库_字段信息)
                数据库.执行SQL语句 (“insert into db_file(” + “name,time,kb,spatch,npatch)values('” + 文件名称 + “','” + 文件大小 + “','” + 文件时间 + “','” + 文件源路径 + “','” + 文件现路径 + “')”)
            .默认
                数据库.执行SQL语句 (“insert into db_file(” + “name,time,kb,spatch,npatch)values('” + 文件名称 + “','” + 文件大小 + “','” + 文件时间 + “','” + 文件源路径 + “','” + 文件现路径 + “')”)
                数据库_表.打开 (“db_file”, 数据库)
            .判断结束

        .判断 (数据库.表是否存在 (“db_filex”) = 假)
            数据库_字段信息 [1].名称 = “name”
            数据库_字段信息 [2].名称 = “time”
            数据库_字段信息 [3].名称 = “spatch”
            数据库_字段信息 [4].名称 = “npatch”
            数据库_字段信息 [5].名称 = “ok”
            连续赋值 (#备注型, 数据库_字段信息 [1].类型, 数据库_字段信息 [2].类型, 数据库_字段信息 [3].类型, 数据库_字段信息 [4].类型, 数据库_字段信息 [5].类型)
            数据库.创建表 (“db_filex”, 数据库_字段信息)
            数据库.执行SQL语句 (“insert into db_filex(” + “name,time,spatch,npatch,ok)values('” + 文件名称 + “','” + 文件时间 + “','” + 文件源路径 + “','” + 文件现路径 + “','” + 到文本 (是否文件夹) + “')”)
        .默认
            数据库.执行SQL语句 (“insert into db_filex(” + “name,time,spatch,npatch,ok)values('” + 文件名称 + “','” + 文件时间 + “','” + 文件源路径 + “','” + 文件现路径 + “','” + 到文本 (是否文件夹) + “')”)
            数据库_表.打开 (“db_filex”, 数据库)
        .判断结束
        数据库.关闭 ()
    .判断 (类型 = “读取”)
        超级列表框.全部删除 ()
        .判断开始 (是否文件夹 = 假)
            数据库_表.打开 (“db_file”, 数据库)
            数据库_表.到首记录 ()
            读取结束 = 假
            处理事件 ()
            .判断开始 (日志窗口关闭 = 假)
                透明标签.标题 = “记录:读取中...”
            .默认
                返回 ()
            .判断结束

            .判断循环首 (数据库_表.尾记录后 () = 假 且 日志窗口关闭 = 假)
                处理事件 ()
                .判断开始 (日志窗口关闭 = 假)
                    索引 = 超级列表框.插入表项 (-1, , , , , )
                .默认
                    返回 ()
                .判断结束

                数据库_表.读字段值 (“name”, 临时文本)
                .判断开始 (日志窗口关闭 = 假)
                    超级列表框.置标题 (索引, 0, 临时文本)
                .默认
                    返回 ()
                .判断结束
                数据库_表.读字段值 (“kb”, 临时文本)
                .判断开始 (日志窗口关闭 = 假)
                    超级列表框.置标题 (索引, 2, 临时文本)
                .默认
                    返回 ()
                .判断结束
                数据库_表.读字段值 (“time”, 临时文本)
                .判断开始 (日志窗口关闭 = 假)
                    超级列表框.置标题 (索引, 1, 临时文本)
                .默认
                    返回 ()
                .判断结束
                数据库_表.读字段值 (“spatch”, 临时文本)
                .判断开始 (文件是否存在 (临时文本))
                    .判断开始 (日志窗口关闭 = 假)
                        超级列表框.置标题 (索引, 5, “真”)
                    .默认
                        返回 ()
                    .判断结束

                .默认
                    .判断开始 (日志窗口关闭 = 假)
                        超级列表框.置标题 (索引, 5, “假”)
                    .默认
                        返回 ()
                    .判断结束

                .判断结束
                .判断开始 (日志窗口关闭 = 假)
                    超级列表框.置标题 (索引, 3, 临时文本)
                .默认
                    返回 ()
                .判断结束
                数据库_表.读字段值 (“npatch”, 临时文本)


                .判断开始 (文件是否存在 (临时文本))
                    .判断开始 (日志窗口关闭 = 假)
                        超级列表框.置标题 (索引, 6, “真”)
                    .默认
                        返回 ()
                    .判断结束

                .默认
                    .判断开始 (日志窗口关闭 = 假)
                        超级列表框.置标题 (索引, 6, “假”)
                    .默认
                        返回 ()
                    .判断结束


                .判断结束

                .判断开始 (日志窗口关闭 = 假)
                    超级列表框.置标题 (索引, 4, 临时文本)
                .默认
                    返回 ()
                .判断结束

                数据库_表.到下一记录 ()
                .判断开始 (日志窗口关闭 = 假)
                    超级列表框.刷新显示 ()
                .默认
                    返回 ()
                .判断结束

                处理事件 ()
            .判断循环尾 ()
            处理事件 ()
            读取结束 = 真
            .判断开始 (日志窗口关闭 = 假)
                透明标签.标题 = “记录:” + 到文本 (超级列表框.取表项数 ()) + “条”
            .默认
                返回 ()
            .判断结束


            数据库_表.关闭 ()
        .默认

        .判断结束

    .判断 (类型 = “删除源文件”)
        .判断开始 (是否文件夹 = 假)
            .判断开始 (数据库.执行SQL语句 (“delete from db_file where spatch='” + 文件源路径 + “'”))
                透明标签.标题 = “记录:” + 到文本 (超级列表框.取表项数 ()) + “条”
            .默认

            .判断结束

        .判断 (数据库.执行SQL语句 (“delete from db_filex where spatch='” + 文件源路径 + “'”))
            透明标签.标题 = “记录:” + 到文本 (超级列表框.取表项数 ()) + “条”
        .默认

        .判断结束
        数据库.关闭 ()
    .判断 (类型 = “清空”)
        .判断开始 (是否文件夹 = 真)
            .判断开始 (数据库.清空表 (“db_filex”))
                超级列表框.全部删除 ()
            .默认

            .判断结束

            透明标签.标题 = “记录:” + 到文本 (超级列表框.取表项数 ()) + “条”
        .判断 (数据库.清空表 (“db_file”))
            超级列表框.全部删除 ()
            透明标签.标题 = “记录:” + 到文本 (超级列表框.取表项数 ()) + “条”
        .默认

        .判断结束

        数据库.关闭 ()
    .判断 (类型 = “删除目标文件”)
        .判断开始 (是否文件夹 = 假)
            .判断开始 (数据库.执行SQL语句 (“delete from db_file where npatch='” + 文件现路径 + “'”))
                透明标签.标题 = “记录:” + 到文本 (超级列表框.取表项数 ()) + “条”
            .默认

            .判断结束

        .判断 (数据库.执行SQL语句 (“delete from db_filex where npatch='” + 文件现路径 + “'”))
            透明标签.标题 = “记录:” + 到文本 (超级列表框.取表项数 ()) + “条”
        .默认

        .判断结束
        数据库.关闭 ()
    .默认

    .判断结束

.默认

.判断结束

我都这样写的。能读能写
回复

使用道具 举报

结帖率:100% (17/17)

签到天数: 17 天

 楼主| 发表于 2020-4-24 08:58:40 | 显示全部楼层   四川省眉山市
sunchun10 发表于 2020-4-22 19:52
.版本 2
.支持库 sqlite3
.支持库 iext

我的意思是多线程或多用户能同时写入数据库
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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