收藏 分享(赏)

基于游标技术的复杂信息发布数据库解决方案.docx.docx

上传人:微传9988 文档编号:1917954 上传时间:2018-08-29 格式:DOCX 页数:9 大小:29.22KB
下载 相关 举报
基于游标技术的复杂信息发布数据库解决方案.docx.docx_第1页
第1页 / 共9页
基于游标技术的复杂信息发布数据库解决方案.docx.docx_第2页
第2页 / 共9页
基于游标技术的复杂信息发布数据库解决方案.docx.docx_第3页
第3页 / 共9页
基于游标技术的复杂信息发布数据库解决方案.docx.docx_第4页
第4页 / 共9页
基于游标技术的复杂信息发布数据库解决方案.docx.docx_第5页
第5页 / 共9页
点击查看更多>>
资源描述

1、基于游标技术的复杂信息发布数据库解决方案(交通部管理干部学院计算机系,XX 101601)摘 要:讨论了在 TSQL编程环境下,如何有效的通过游标 技术,在一个存储过程中封装复杂的软件业务逻辑,并在对具体问题提出的同时,有针对性 的提出并实现解决方案。关键词:游标;存储过程;数据库编程中图分类号:TP311.1 文献标识码:A 文章编号:10076921(XX)180040021 T-SQL 游标使用使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式。用 SQL语言 从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集 合。游标机制允许用户

2、在 SQL server内逐行地访问这些记录,按照用户自己的意愿来显示和 处理这些记录。一般使用游标都遵循下列的常规步骤: 首先声明游标,把游标与 T-SQL语句的结果集联 系起来;其次打开游标;然后使用游标操作数据;最后关闭游标。2 用户信息发布问题提出在交通培训网网上办公系统项目(为交通部 XX年度西部培训项目指定研究子课题)实施 过程中,各个培训机构在执行行业部委年度培 训任务时候已经获取了项目任务书的批准,并成为该部委本年度培训执行计划的一部分。接 下来的任务是给各个省交通厅发送消息,告知具体的培训开班时间和地点。但是由于每个培 训班可能会开设多期,每期虽然内容相同但是时间地点迥异。而

3、各个省厅收到消息后,在通 知本省行业员工参加培训时候,由于人数众多,班次复杂,往往口头通知的时候在时间和地 点上易产生差错。因此省厅希望给这些未来培训的学员随机的密码和用户名,通知他们自己 登录系统获取具体的培训资讯,而在开班后这些信息自动消失。其基本流程见图 1所示。740)this.width=740“ border=undefined该数据库局部模式关系是:OA_message(用户消息表)与 OA_user(用户表)存 在参照完整 性联系(users_id,userf_id),OA_jtbzxplan(交通部执行计划表)与OA_user(用户表)存在 参照完整性联系(user_id),

4、OA_jtbzxplan(交通部执行计划表)与 OA_itemwork(培训计划任 务书表)存在参照完整性联系(plan_id),OA_kbnotify(开班通知表)与 OA_itemwork(培训计 划任务书表)存在参照完整性联系(work_id),OA_kbnotify(开班通知表)与 OA_kbqs(开班期 数表)存在参照完整性联系(kbtz_id)。程序在执行过程中,如果培训单位发布了一条开班通知和该开班通知的期数信息(已经同通 过存储过程实现),程序在获取插入信息成功的前提下,应该自动执行短消息发布系统,通 知各个省厅培训学员的登录密码和账号。由于培训学员仅仅关系自己想培训的项目时间

5、地点 费用等信息,因此其登录时候系统仅需知道具体的项目任务书编号和该任务书所对应的第几 期信息就可以了。因为当培训任务书编号一旦确定,则开班的各个期项目的集合就可以为已 锁定,而这些集合中唯一不同的点就是培训时间,所以在培训学员登录报名时候,系统最终 获得项目任务书编号(登陆用户名称)和开班期数中的开班报到时间(密码)就可以唯一确定该 学员是具体哪个培训项目第几期的学员了。问题是,由于培训单位发布的每个培训项目其培训期数都不相同,决定每条短消息所告知的 登陆用户名称和密码也完全不同,这就导致了无法通过传统的面向集合的查询方式进行数据 的显示,而必须通过动态的游标形式将数据有针对性的显示出来。3

6、 用户信息发布问题数据库编程方案该复杂问题可以完全在存储过程中实现封装。该存储过程执行时刻是在程序刚刚插入一条开 班通知和该开班通知的期数信息之后,故而首先需要获取已知的外部数据接口信息为(项目 任务书编号)work_id int和(用户编号)user_id int。3.1 第一步:根据这两个基本信息,就可以获得与输入的 work_id有关的 kbtz_id,以及与 k btz_id相关联的kbqs_id。CREATE proc OAproc_kbtz_shortmessagework_id int,user_id int,plan_code varchar(40) outputasdecla

7、re 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=work_times,plan_code=oa_jtbzxplan.plan_codefrom oa_kbnotify,oa_itemw

8、ork,oa_jtbzxplanwhere oa_kbnotify.work_id=oa_itemwork.work_id and oa_itemwork.plan_id=oa_jtbzxplan.plan_id and oa_kbnotify.work_id=work_idorder by kbtz_time desc3.2 第二步:获得与输入的 work_id有关的 kbtz_id;获得培训单位的名称。select kbtz_id=kbtz_id from oa_kbnotify where work_id=work_idselect user_name=user_name from oa

9、_userwhere oa_user.user_id=user_id3.3 第三步:获得 kbtz_id相关的每一期的开班报道时间,并且形成一个字符串备用。-首先,初始化一些变量。set password=set semi=0set i=0-接着开始定义游标DECLARE CEVENT CURSOR FAST_FORWARDFOR select cast(year(kbqs_bdtime) as varchar(4)+-+ cast(month(kbqs_bdtime) as var char(4)+-+cast(day(kbqs_bdtime) as varchar(4)from oa_kb

10、qs where kbtz_id=kbtz_idOPEN CEVENTFETCH CEVENT INTO EVENTDATA -获得基本日期的信息字符串while fetch_status=0beginif semi=1 beginset i=i+1set password=password+;+第+cast(i as varchar(5)+期开班的密码是 :+CAST ( EVENTDATA AS varchar(20) ) insert into oa_user (user_name,user_code,user_degree) values(plan_code,CAST ( EVENTD

11、ATA AS varchar(20) ),5)endelsebeginset i=i+1set password=第+cast(i as varchar(5)+期开班的密码是:+CAST ( E VENTDATA AS varchar(20) ) set semi=1 insert into oa_user (user_name,user_code,user_degree) values(plan_code,CAST ( EVENTDATA AS varchar(20) ),5)endfetch CEVENT into EVENTDATA -游标向下移动endclose CEVENTdeall

12、ocate CEVENT3.4 第四步:将以上信息进行拼接,形成短消息字符串,并嵌入标准的 css格式。set short_mess= +plan_name+培训项目现在已经开班,共拟开办+CAST (q AS varchar(4) +期。本次通知的详细内容已经在您的公告新闻中 可以查询到。本次开班的用户名称是:+plan_code+本次开班的用户密码是:+password+收到本消息后,请尽快通知相关单位培训的同志,登陆网址:http:/ 进行网上报名工作。+再次感谢您对我们工作的支持。+user_n ame+cast(year(getdate() as varchar(4) +年+cast

13、(month(getdate() as va rchar(4)+月+cast(day(getdate() as varchar(4)+日insert into oa_messa ge(Users_id,Userf_id,mess_topic,mess_content)select user_id ,user_id,kbtz_topi c,+user_name+: 您好!+short_messfrom oa_userwhere user_degree=4GO参考文献1 项目任务书Z.中国交通教育培训网.2 用户需求说明书Z.中国交通教育培训网.3 用户说明书Z.中国交通教育培训网.4 软件设计说明书Z.中国交通教育培训网.

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑环境 > 设计及方案

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报