开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 1009|回复: 9
收起左侧

[已解决] 超级列表框统计重复次数

 关闭 [复制链接]
结帖率:80% (4/5)
发表于 2023-5-6 14:25:43 | 显示全部楼层 |阅读模式   浙江省杭州市
8精币
sqlite数据库“data.db”中数据表"saomiao"的内容为:
yymm        time        number        name
20230416        18:04:03        6445316515         小胖
20230506        18:08:18        563543543         小胖
20230417        10:07:11        453534453         小土
20230317        10:52:02        453453543         小黑
20230416        10:58:21        4531234534         小胖
20230506        10:58:40        453132123         小胖
20230315        11:13:37        2343354554         小黑
20230416        11:13:41        434534543         小土
20230417        11:14:01        856374333         小黑
20230416        11:14:38        45247854214         小黑
20230417        11:14:42        434735453         小胖
20230315        11:14:45        2023043584         小胖
20230416        11:16:15        3453543354         小土
20230417        11:25:18        42332787485         小胖
20230417        11:27:44        5274274522         小胖

在sqlite数据表“saomiao”的“yymm”列和“number”列中模糊查找“搜索文本”中的数据,如果“搜索文本”为空,就查找今天的数据,把查找到的数据通过“超级列表框”展示出来,在“状态条1”中统计一共查到了多少条数据,不同的“name”分别有多少条,“name”列的数据是不确定的。

举例1:
搜索文本=“202304”
超级列表框输出的内容为:
20230416        18:04:03        6445316515         小胖
20230417        10:07:11        453534453         小土
20230416        10:58:21        4531234534         小胖
20230416        11:13:41        434534543         小土
20230417        11:14:01        856374333         小黑
20230416        11:14:38        45247854214         小黑
20230417        11:14:42        434735453         小胖
20230315        11:14:45        42023043584         小胖
20230416        11:16:15        3453543354         小土
20230417        11:25:18        42332787485         小胖
20230417        11:27:44        5274274522         小胖
“状态条1”输出内容为"共11条:小胖6,小黑2,小土3。"

举例2:
搜索文本=“”
超级列表框输出的内容为:
20230506        18:08:18        563543543         小胖
20230506        10:58:40        453132123         小胖
“状态条1”输出内容为"共2条:小胖2。"

举例3:
搜索文本=“4735”
超级列表框输出的内容为:
20230417        11:14:42        434735453         小胖
“状态条1”输出内容为"共1条:小胖1条。"

最佳答案

查看完整内容

[e=0].版本 2 .支持库 spec .子程序 刷新列表 .参数 搜索文本, 文本型, 可空 .局部变量 局部_索引, 整数型 .局部变量 局部_ID, 整数型 .局部变量 输出, 文本型 .局部变量 数据数组, 文本型, , "3" .局部变量 n, 整数型 .如果真 (sqlite.打开 (数据库路径, 真) = 假) 信息框 (“数据库打开失败”, 0, , ) .如果真结束 .如果 (搜索文本 ≠ “”) 记录集 = sqlite.取记录集 (“SELECT * FROM saomiao WHERE number LIKE ...

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

结帖率:100% (2/2)

签到天数: 8 天

发表于 2023-5-6 14:25:44 | 显示全部楼层   四川省绵阳市
  
子程序名返回值类型公开备 注
刷新列表  
参数名类 型参考可空数组备 注
搜索文本文本型
变量名类 型静态数组备 注
局部_索引整数型 
局部_ID整数型 
输出文本型 
数据数组文本型3
n整数型 
如果真 (sqlite.打开 (数据库路径, ))
信息框 (“数据库打开失败”, 0, , )

如果 (搜索文本 ≠ “”)
记录集 = sqlite.取记录集 (“SELECT * FROM saomiao WHERE number LIKE '%” + 搜索文本 + “%' or yymm LIKE '%” + 搜索文本 + “%'”)
记录集 = sqlite.取记录集 (“SELECT * FROM saomiao WHERE yymm = strftime('%Y%m%d', date('now'))”)

如果真 (记录集.打开 ())
信息框 (“记录集没打开!”, #错误图标, “提示”, )
返回 ()
超级列表框.全部删除 ()
记录集.到下一记录 ()
判断循环首 (记录集.尾记录后 ())
局部_索引 = 超级列表框.插入表项 (, 到文本 (局部_ID), , , , )
' 使用数组来存储数据,避免多个变量
数据数组 [1] = 记录集.读字段文本值 (“yymm”, )“ ” + 记录集.读字段文本值 (“time”, )
数据数组 [2] = 记录集.读字段文本值 (“number”, )
数据数组 [3] = 记录集.读字段文本值 (“name”, )
超级列表框.置标题 (局部_索引, 1, 数据数组 [1])
超级列表框.置标题 (局部_索引, 2, 数据数组 [2])
超级列表框.置标题 (局部_索引, 3, 数据数组 [3])
记录集.到下一记录 ()
处理事件 ()
判断循环尾 ()
n = 记录集.取记录个数 ()
调试输出 (n)
如果真 (n > 0)
如果 (搜索文本 ≠ “”)
记录集 = sqlite.取记录集 (“SELECT name,count(name) as count FROM saomiao WHERE number LIKE '%” + 搜索文本 + “%' or yymm LIKE '%” + 搜索文本 + “%' group by name ORDER BY COUNT(name) DESC”)
记录集 = sqlite.取记录集 (“select name,count(name) as count from saomiao WHERE yymm = strftime('%Y%m%d', date('now')) group by name ORDER BY COUNT(name) DESC”)

如果真 (记录集.到下一记录 ())
输出 = 记录集.读字段文本值 (“name”, )“” + 记录集.读字段文本值 (“count”, )“个”
判断循环首 (记录集.到下一记录 ())
输出 = 输出 + “,” + 记录集.读字段文本值 (“name”, )“” + 记录集.读字段文本值 (“count”, )“个”
判断循环尾 ()
输出 = “一共打了”到文本 (n)“个包:” + 输出 + “。”
状态条1.置文本 (0, 输出)

记录集.关闭 ()
如果 (n > 13)
超级列表框.置列宽 (1, 170)
超级列表框.置列宽 (2, 180)
超级列表框.置列宽 (3, 120)
超级列表框.置列宽 (1, 170)
超级列表框.置列宽 (2, 180)
超级列表框.置列宽 (3, 140)


i支持库列表   支持库注释   
spec特殊功能支持库

这样试试?

评分

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

查看全部评分

回复

使用道具 举报

结帖率:80% (4/5)
 楼主| 发表于 2023-5-6 14:31:07 | 显示全部楼层   浙江省杭州市
下面是我目前写的代码,超级列表框中的内容已经可以正常展示了,但是不知道怎么统计不同姓名出现的次数,请大神帮忙写一下,谢谢
  
子程序名返回值类型公开备 注
刷新列表  
参数名类 型参考可空数组备 注
搜索文本文本型
变量名类 型静态数组备 注
局部_索引整数型 
局部_ID整数型 
数据数组文本型3
如果真 (sqlite.打开 (数据库路径, ))
信息框 (“数据库打开失败”, 0, , )

如果 (搜索文本 ≠ “”)
记录集 = sqlite.取记录集 (“SELECT * FROM saomiao WHERE number LIKE '%” + 搜索文本 + “%' or yymm LIKE '%” + 搜索文本 + “%'”)
记录集 = sqlite.取记录集 (“SELECT * FROM saomiao WHERE yymm = strftime('%Y%m%d', date('now'))”)

如果真 (记录集.打开 ())
信息框 (“记录集没打开!”, #错误图标, “提示”, )
返回 ()
超级列表框.全部删除 ()
记录集.到下一记录 ()
判断循环首 (记录集.尾记录后 ())
局部_索引 = 超级列表框.插入表项 (, 到文本 (局部_ID), , , , )
' 使用数组来存储数据,避免多个变量
数据数组 [1] = 记录集.读字段文本值 (“yymm”, )“ ” + 记录集.读字段文本值 (“time”, )
数据数组 [2] = 记录集.读字段文本值 (“number”, )
数据数组 [3] = 记录集.读字段文本值 (“name”, )
超级列表框.置标题 (局部_索引, 1, 数据数组 [1])
超级列表框.置标题 (局部_索引, 2, 数据数组 [2])
超级列表框.置标题 (局部_索引, 3, 数据数组 [3])
记录集.到下一记录 ()
处理事件 ()
判断循环尾 ()
记录集.关闭 ()


i支持库列表   支持库注释   
sqlite3(未知支持库)
iext扩展界面支持库一


回复

使用道具 举报

结帖率:100% (2/2)

签到天数: 8 天

发表于 2023-5-6 14:31:16 | 显示全部楼层   四川省绵阳市
select name ,count(name) from saomiao group by name

直接用sqlcha询呗 where的自行添加

补充内容 (2023-5-6 14:31):
用sql进行分组cha询效率更好。

补充内容 (2023-5-6 14:35):
select name ,count(name) from saomiao WHERE number LIKE '%” + 搜索文本 + “%' or yymm LIKE '%” + 搜索文本 + “%'” group by name

补充内容 (2023-5-6 14:35):
select name ,count(name) from saomiao WHERE yymm = strftime('%Y%m%d', date('now')) group by name
回复

使用道具 举报

结帖率:80% (4/5)
 楼主| 发表于 2023-5-6 14:36:17 | 显示全部楼层   浙江省杭州市
钥匙key 发表于 2023-5-6 14:31
select name ,count(name) from saomiao group by name

直接用sqlcha询呗 where的自行添加

不知道怎么在前面cha询出来的结果上再继续cha询人名出现的次数,可以帮我写一下吗
回复

使用道具 举报

结帖率:100% (2/2)

签到天数: 8 天

发表于 2023-5-6 14:44:04 | 显示全部楼层   四川省绵阳市
自己适配一下。。没有原始代码。。

123.e

978.84 KB, 下载次数: 17

回复

使用道具 举报

结帖率:80% (4/5)
 楼主| 发表于 2023-5-6 14:57:06 | 显示全部楼层   浙江省杭州市
钥匙key 发表于 2023-5-6 14:44
自己适配一下。。没有原始代码。。

你的意思是前面cha询一次数据,把这些数据加入超级列表框,然后再继续cha询一次人名出现的次数吗?
回复

使用道具 举报

结帖率:100% (2/2)

签到天数: 8 天

发表于 2023-5-6 14:57:48 | 显示全部楼层   四川省绵阳市
easonchou 发表于 2023-5-6 14:57
你的意思是前面cha询一次数据,把这些数据加入超级列表框,然后再继续cha询一次人名出现的次数吗? ...

对。分别cha询。同样的条件就可以了。。
回复

使用道具 举报

结帖率:80% (4/5)
 楼主| 发表于 2023-5-6 15:30:03 | 显示全部楼层   浙江省杭州市
钥匙key 发表于 2023-5-6 14:57
对。分别cha询。同样的条件就可以了。。

参考你的代码写的,有时候列表框有数据但是状态条是空的,比如输入202305状态栏是空的,但是再输入一个0变成了2023050,再删除这个0又变成了202305,状态栏又有数据了。帮忙再看一下是不是那里写的不对,谢谢!
  
子程序名返回值类型公开备 注
刷新列表  
参数名类 型参考可空数组备 注
搜索文本文本型
变量名类 型静态数组备 注
局部_索引整数型 
局部_ID整数型 
输出文本型 
数据数组文本型3
n整数型 
如果真 (sqlite.打开 (数据库路径, ))
信息框 (“数据库打开失败”, 0, , )

如果 (搜索文本 ≠ “”)
记录集 = sqlite.取记录集 (“SELECT * FROM saomiao WHERE number LIKE '%” + 搜索文本 + “%' or yymm LIKE '%” + 搜索文本 + “%'”)
记录集 = sqlite.取记录集 (“SELECT * FROM saomiao WHERE yymm = strftime('%Y%m%d', date('now'))”)

如果真 (记录集.打开 ())
信息框 (“记录集没打开!”, #错误图标, “提示”, )
返回 ()
超级列表框.全部删除 ()
记录集.到下一记录 ()
判断循环首 (记录集.尾记录后 ())
局部_索引 = 超级列表框.插入表项 (, 到文本 (局部_ID), , , , )
' 使用数组来存储数据,避免多个变量
数据数组 [1] = 记录集.读字段文本值 (“yymm”, )“ ” + 记录集.读字段文本值 (“time”, )
数据数组 [2] = 记录集.读字段文本值 (“number”, )
数据数组 [3] = 记录集.读字段文本值 (“name”, )
超级列表框.置标题 (局部_索引, 1, 数据数组 [1])
超级列表框.置标题 (局部_索引, 2, 数据数组 [2])
超级列表框.置标题 (局部_索引, 3, 数据数组 [3])
记录集.到下一记录 ()
处理事件 ()
判断循环尾 ()
n = 记录集.取记录个数 ()
如果 (搜索文本 ≠ “”)
记录集 = sqlite.取记录集 (“SELECT name,count(name) as count FROM saomiao WHERE number LIKE '%” + 搜索文本 + “%' or yymm LIKE '%” + 搜索文本 + “%' group by name ORDER BY COUNT(name) DESC”)
记录集 = sqlite.取记录集 (“select name,count(name) as count from saomiao WHERE yymm = strftime('%Y%m%d', date('now')) group by name ORDER BY COUNT(name) DESC”)
记录集.到下一记录 ()
输出 = 记录集.读字段文本值 (“name”, )“” + 记录集.读字段文本值 (“count”, )“个”
判断循环首 (记录集.到下一记录 ())
输出 = 输出 + “,” + 记录集.读字段文本值 (“name”, )“” + 记录集.读字段文本值 (“count”, )“个”
判断循环尾 ()
如果 (n = 0)
输出 = “”
输出 = “一共打了”到文本 (n)“个包:” + 输出 + “。”
状态条1.置文本 (0, 输出)
记录集.关闭 ()
调试输出 (n)
如果 (n > 13)
超级列表框.置列宽 (1, 170)
超级列表框.置列宽 (2, 180)
超级列表框.置列宽 (3, 120)
超级列表框.置列宽 (1, 170)
超级列表框.置列宽 (2, 180)
超级列表框.置列宽 (3, 140)


i支持库列表   支持库注释   
sqlite3(未知支持库)
iext扩展界面支持库一
spec特殊功能支持库


回复

使用道具 举报

结帖率:100% (2/2)

签到天数: 8 天

发表于 2023-5-6 15:34:14 | 显示全部楼层   四川省绵阳市
easonchou 发表于 2023-5-6 15:30
参考你的代码写的,有时候列表框有数据但是状态条是空的,比如输入202305状态栏是空的,但是再输入一个0 ...

不太容易看。要不你把数据库和demo一起传上来?
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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