基于游标技术的复杂信息发布数据库解决方案
(交通部管理干部学院计算机系,北京 101601)
摘 要:讨论了在tsql编程环境下,如何有效的通过游标 技术,在一个存储过程中封装复杂的软件业务逻辑,并在对具体问题提出的同时,有针对性 的提出并实现解决方案。
关键词:游标;存储过程;数据库编程
中图分类号:tp311.1 文献标识码:a 文章编号:1007—6921(2008)18—0040—02
1 t-sql游标使用
使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式。用sql语言 从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集 合。游标机制允许用户在sql server内逐行地访问这些记录,按照用户自己的意愿来显示和 处理这些记录。
一般使用游标都遵循下列的常规步骤: 首先声明游标,把游标与t-sql语句的结果集联 系起来;其次打开游标;然后使用游标操作数据;最后关闭游标。
2 用户信息发布问题提出
在《交通培训网网上办公系统》项目(为交通部2006年度西部培训项目指定研究子课题)实施 过程中,各个培训机构在执行行业部委年度培 训任务时候已经获取了项目任务书的批准,并成为该部委本年度培训执行计划的一部分。接 下来的任务是给各个省交通厅发送消息,告知具体的培训开班时间和地点。但是由于每个培 训班可能会开设多期,每期虽然内容相同但是时间地点迥异。而各个省厅收到消息后,在通 知本省行业员工参加培训时候,由于人数众多,班次复杂,往往口头通知的时候在时间和地 点上易产生差错。因此省厅希望给这些未来培训的学员随机的密码和用户名,通知他们自己 登录系统获取具体的培训资讯,而在开班后这些信息自动消失。其基本流程见图1所示。
740)this.width=740" border=undefined>
该数据库局部模式关系是:oa_message(用户消息表)与oa_user(用户表)存 在参照完整 性联系(users_id,userf_id),oa_jtbzxplan(交通部执行计划表)与oa_user(用户表)存在 参照完整性联系(user_id),oa_jtbzxplan(交通部执行计划表)与oa_itemwork(培训计划任 务书表)存在参照完整性联系(plan_id),oa_kbnotify(开班通知表)与oa_itemwork(培训计 划任务书表)存在参照完整性联系(work_id),oa_kbnotify(开班通知表)与oa_kbqs(开班期 数表)存在参照完整性联系(kbtz_id)。
程序在执行过程中,如果培训单位发布了一条开班通知和该开班通知的期数信息(已经同通 过存储过程实现),程序在获取插入信息成功的前提下,应该自动执行短消息发布系统,通 知各个省厅培训学员的登录密码和账号。由于培训学员仅仅关系自己想培训的项目时间地点 费用等信息,因此其登录时候系统仅需知道具体的项目任务书编号和该任务书所对应的第几 期信息就可以了。因为当培训任务书编号一旦确定,则开班的各个期项目的集合就可以为已 锁定,而这些集合中唯一不同的点就是培训时间,所以在培训学员登录报名时候,系统最终 获得项目任务书编号(登陆用户名称)和开班期数中的开班报到时间(密码)就可以唯一确定该 学员是具体哪个培训项目第几期的学员了。
问题是,由于培训单位发布的每个培训项目其培训期数都不相同,决定每条短消息所告知的 登陆用户名称和密码也完全不同,这就导致了无法通过传统的面向集合的查询方式进行数据 的显示,而必须通过动态的游标形式将数据有针对性的显示出来。
3 用户信息发布问题数据库编程方案
该复杂问题可以完全在存储过程中实现封装。该存储过程执行时刻是在程序刚刚插入一条开 班通知和该开班通知的期数信息之后,故而首先需要获取已知的外部数据接口信息为(项目 任务书编号)@work_id int和(用户编号)@user_id int。
3.1 第一步:根据这两个基本信息,就可以获得与输入的work_id有关的kbtz_id,以及与k btz_id相关联的kbqs_id。
create proc oaproc_kbtz_shortmessage
@work_id int,@user_id int,@plan_code varchar(40) output
as
declare @plan_name varchar(40),@q int,@kbtz_topic varchar(120),
@short_mess varchar(5000),@kbtz_id int,@password varchar(3000),
@semi bit,@i int,@eventdata varchar(1024),@user_name varchar(40)
select top 1 @plan_name=plan_name,@kbtz_topic=kbtz_topic,@q=wo
基于游标技术的复杂信息发布数据库解决方案
本文2010-04-27 23:06:58发表“财经金融”栏目。
本文链接:https://www.wenmi123.com/article/161228.html
- 2025 年《建设工程项目管理》模考卷一.pdf
- 座谈会发言:体系抓好思政课教育做好贯彻落实下篇文章(02-19).docx
- 组织部机关支部书记2024年度抓基层党建工作述职报告(02-19).docx
- 在县委理论中心组暨2024年度民主生活会学习研讨会上的发言(02-19).docx
- 在2025年市人代会分组讨论会上的发言(02-19).docx
- 医院党委选人用人工作自查报告(02-19).docx
- 宣传部2024年民主生活会个人对照检查发言(02-19).docx
- 行政服务中心民族团结进步创建工作经验材料(02-19).docx
- 校长在中学2025春季开学典礼上的讲话:撷一抹祈望春风掬一程锦绣花开(02-19).docx
- 乡镇领导班子2024年民主生活会对照检查发言材料(五个带头+典型案例)(02-19).docx