开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

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

[易语言] 求一个sqlite3 分页cha询的源码例子

[复制链接]
结帖率:9% (1/11)
发表于 11 小时前 | 显示全部楼层 |阅读模式   重庆市重庆市
9精币
求一个sqlite3 分页cha询的源码例子


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

签到天数: 3 天

 楼主| 发表于 11 小时前 | 显示全部楼层   重庆市重庆市
易语言例子
回复

使用道具 举报

结帖率:100% (9/9)

签到天数: 10 天

发表于 6 小时前 | 显示全部楼层   山东省济南市
[JavaScript] 纯文本查看 复制代码
.版本 2
.支持库 esqlite31
.支持库 spec

.程序集 zySqlite3数据库分页
.程序集变量 sqlit, zySqlite数据库
.程序集变量 集_每页显示数, 整数型
.程序集变量 集_当前页码, 整数型
.程序集变量 集_总记录数, 整数型
.程序集变量 集_总页数, 整数型
.程序集变量 集_筛选条件, 文本型
.程序集变量 集_是否超限, 逻辑型
.程序集变量 集_表名, 文本型
.程序集变量 是否打开, 逻辑型

.子程序 _初始化, , , 当基于本类的对象被创建后,此方法会被自动调用



.子程序 _销毁, , , 当基于本类的对象被销毁前,此方法会被自动调用

关闭 ()




.子程序 初始化, 整数型, 公开
.参数 数据库路径, 文本型
.参数 表名, 文本型
.参数 每页显示数, 整数型
.参数 筛选条件, 文本型, 可空, 可空。如:where 性别 = '男'
.局部变量 stmt, zySqlite记录集

' -----------------------------------------------------------------
集_表名 = 表名
集_筛选条件 = 筛选条件
集_每页显示数 = 每页显示数
是否打开 = sqlit.打开 (数据库路径, #SQLITE_打开_读写)
stmt = sqlit.取记录集 (“select count(*) from ” + 集_表名 + “ ” + 筛选条件, )
集_总记录数 = stmt.cha询标量 ()
.' 判断循环首 (stmt.到下一条 ())
' 集_总记录数 = stmt.读整数型 (0)
.' 判断循环尾 ()
stmt.关闭 ()
.判断开始 (集_总记录数 % 集_每页显示数 = 0)
集_总页数 = 取整 (集_总记录数 ÷ 集_每页显示数)
.默认
集_总页数 = 取整 (集_总记录数 ÷ 集_每页显示数) + 1
.判断结束
返回 (集_总页数)

.子程序 是否已连接, 逻辑型, 公开

返回 (是否打开)

.子程序 置表名, , 公开
.参数 欲操作的表名, 文本型
.局部变量 stmt, zySqlite记录集

集_表名 = 欲操作的表名
' 因为表明发生了变化,所以总记录数
' ---------------------------------------
stmt = sqlit.取记录集 (“select count(*) from ” + 集_表名 + “ ” + 集_筛选条件, )
集_总记录数 = stmt.cha询标量 ()
.' 判断循环首 (stmt.到下一条 ())
' 集_总记录数 = stmt.读整数型 (0)
.' 判断循环尾 ()
stmt.关闭 ()
.判断开始 (集_总记录数 % 集_每页显示数 = 0)
集_总页数 = 取整 (集_总记录数 ÷ 集_每页显示数)
.默认
集_总页数 = 取整 (集_总记录数 ÷ 集_每页显示数) + 1
.判断结束
' ---------------------------------------

.子程序 关闭, , 公开

连续赋值 (0, 集_每页显示数, 集_当前页码, 集_总记录数, 集_总页数)
集_是否超限 = 假
集_表名 = “”
sqlit.关闭 ()
是否打开 = 假

.子程序 取总记录数, 整数型, 公开

返回 (集_总记录数)

.子程序 置每页显示数, 整数型, 公开, 如果是超级列表框,请用 SendMessage (超级列表框1.取窗口句柄 (), 4136, 0, 0) 命令,自动设定
.参数 数量, 整数型

集_每页显示数 = 数量
返回 (集_每页显示数)

.子程序 取每页显示数, 整数型, 公开

返回 (集_每页显示数)

.子程序 取总页数, 整数型, 公开

返回 (集_总页数)

.子程序 取当前页码, 整数型, 公开

返回 (集_当前页码 + 1)

.子程序 取分页记录, zySqlite记录集, 公开
.参数 筛选条件, 文本型, 可空
.局部变量 sql, 文本型
.局部变量 当前位置, 整数型
.局部变量 i, 整数型
.局部变量 id, 整数型
.局部变量 记录集1, zySqlite记录集

当前位置 = 集_当前页码 × 集_每页显示数
调试输出 (当前位置)
sql = “SELECT * FROM (SELECT * FROM ” + 集_表名 + “ ” + 筛选条件 + “ LIMIT ” + 到文本 (当前位置) + “,” + 到文本 (集_每页显示数) + “)”
调试输出 (sql)
' 记录集1 = sqlit.取记录集 (sql, )
记录集1.置SQL语句 (sql, sqlit)
记录集1.执行 ()
.如果 (集_当前页码 ≥ 集_总页数)
集_是否超限 = 真
.否则
集_是否超限 = 假
.如果结束
调试输出 (记录集1.取行数 ())
返回 (记录集1)

.子程序 到上一页, , 公开

集_当前页码 = 集_当前页码 - 1
.如果真 (集_当前页码 < 0)
集_当前页码 = 0
.如果真结束


.子程序 到下一页, , 公开

.如果真 (集_是否超限 = 假)
.如果真 (集_当前页码 < 集_总页数 - 1)
集_当前页码 = 集_当前页码 + 1
.如果真结束

.如果真结束


.子程序 到首页, , 公开

集_当前页码 = 0

.子程序 到尾页, , 公开

集_当前页码 = 集_总页数 - 1

.子程序 跳转, , 公开
.参数 页码, 整数型

.判断开始 (页码 ≤ 集_总页数 且 页码 > 0)
集_当前页码 = 页码 - 1
.默认
信息框 (“超出范围!”, 48, “出错啦”, )
.判断结束
回复

使用道具 举报

结帖率:100% (9/9)

签到天数: 10 天

发表于 6 小时前 | 显示全部楼层   山东省济南市
回复

使用道具 举报

结帖率:86% (6/7)

签到天数: 8 天

发表于 2 小时前 | 显示全部楼层   广东省广州市
SELECT *  FROM 表名 LIMIT 每页数量 OFFSET 第几条开始;
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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