版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
基于游标技术的复杂信息发布数据库解决方案
摘要:讨论了在TSQL编程环境下,如何有效的通过游标技术,在一个存储过程中封装复杂的软件业务逻辑,并在对具体问题提出的同时,有针对性的提出并实现解决方案。
关键词:游标;存储过程;数据库编程
中图分类号:TP311.1
文献标识码:A
文章编号:1007—6921(2008)18—0040—02
1T-SQL游标使用使用游标(cursor)的一个主要的原因就是把集合操作转换成单个记录处理方式。用SQL语言从数据库中检索数据后,结果放在内存的一块区域中,且结果往往是一个含有多个记录的集合。游标机制允许用户在SQLserver内逐行地访问这些记录,按照用户自己的意愿来显示和处理这些记录。一般使用游标都遵循下列的常规步骤:首先声明游标,把游标与T-SQL语句的结果集联系起来;其次打开游标;然后使用游标操作数据;最后关闭游标。
2用户信息发布问题提出在《交通培训网网上办公系统》项目(为交通部2006年度西部培训项目指定研究子课题)实施过程中,各个培训机构在执行行业部委年度培训任务时候已经获取了项目任务书的批准,并成为该部委本年度培训执行计划的一部分。接下来的任务是给各个省交通厅发送消息,告知具体的培训开班时间和地点。但是由于每个培训班可能会开设多期,每期虽然内容相同但是时间地点迥异。而各个省厅收到消息后,在通知本省行业员工参加培训时候,由于人数众多,班次复杂,往往口头通知的时候在时间和地点上易产生差错。因此省厅希望给这些未来培训的学员随机的密码和用户名,通知他们自己登录系统获取具体的培训资讯,而在开班后这些信息自动消失。其基本流程见图1所示。
该数据库局部模式关系是: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_idint和(用户编号)@user_idint。
3.1第一步:根据这两个基本信息,就可以获得与输入的work_id有关的kbtz_id,以及与kbtz_id相关联的kbqs_id。
CREATEprocOAproc_kbtz_shortmessage
@work_idint,@user_idint,@plan_codevarchar(40)output
as
declare@plan_namevarchar(40),@qint,@kbtz_topicvarchar(120),
@short_messvarchar(5000),@kbtz_idint,@passwordvarchar(3000),
@semibit,@iint,@EVENTDATAVARCHAR(1024),@user_namevarchar(40)
selecttop1@plan_name=plan_name,@kbtz_topic=kbtz_topic,@q=work_times,
@plan_code=oa_jtbzxplan.plan_code
from
oa_kbnotify,oa_itemwork,oa_jtbzxplan
whereoa_kbnotify.work_id=oa_itemwork.work_idand
oa_itemwork.plan_id=oa_jtbzxplan.plan_idand
oa_kbnotify.work_id=@work_id
orderbykbtz_timedesc
3.2第二步:获得与输入的work_id有关的kbtz_id;获得培训单位的名称。
select@kbtz_id=kbtz_idfromoa_kbnotifywherework_id=@work_id
select@user_name=user_namefromoa_user
whereoa_user.user_id=@user_id
3.3第三步:获得kbtz_id相关的每一期的开班报道时间,并且形成一个字符串备用。
--首先,初始化一些变量。
set@password=""
set@semi=0
set@i=0
--接着开始定义游标
DECLARECEVENTCURSORFAST_FORWARD
FOR
selectcast(year(kbqs_bdtime)asvarchar(4))+"-"+cast(month(kbqs_bdtime)asvarchar(4))+"-"+cast(day(kbqs_bdtime)asvarchar(4))
fromoa_kbqswherekbtz_id=@kbtz_id
OPENCEVENTFETCHCEVENTINTO@EVENTDATA--获得基本日期的信息字符串
while@@fetch_status=0
begin
if@semi=1
begin
set@i=@i+1
set@password=@password+";"+"第"+cast(@iasvarchar(5))+"期开班的密码是:"+CAST(@EVENTDATAASvarchar(20))
insertintooa_user(user_name,user_code,user_degree)
values(@plan_code,CAST(@EVENTDATAASvarchar(20)),5)
end
else
begin
set@i=@i+1
set@password="第"+cast(@iasvarchar(5))+"期开班的密码是:"+CAST(@EVENTDATAASvarchar(20))
set@semi=1
insertintooa_user(user_name,user_code,user_degree)
values(@plan_code,CAST(@EVENTDATAASvarchar(20)),5)
end
fetchCEVENTinto@EVENTDATA--游标向下移动
end
closeCEVENT
deallocateCEVENT
3.4第四步:将以上信息进行拼接,形成短消息字符串,并嵌入标准的css格式。set@short_mess="<p>"+@plan_name+"培训项目现在已经开班,共拟开办"+"<spanclass=ts>"+CAST(@qASvarchar(4))+"</span>期。本次通知的详细内容已经在您的公告新闻中可以查询到。<br>
<spanclass=ts>本次开班的用户名称是:"+@plan_code+"<br>
本次开班的用户密码是:<br"style="font-size:14px;">"+@password+"</span><br>
收到本消息后,请尽快通知相关单位培训的同志,登陆网址:
进行网上报名工作。"+"再次感谢您对我们工作的支持。</p></div><div
id=lk>"+@user_name+"<br>"+cast(year(getdate())asvarchar(4))+"年"+cast(month(getdate())asvarchar(4))+"月"+cast(day(getdate())asvarchar(4))+"日</div>"insertintooa_message(Users_id,Userf_id,mess_topic,mess_content)selectuser_id,@user_id,@kbtz_topic,"<divid=ch>"+user_name+":</di
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024各类设备采购协议总览
- 2024年新公司聘用劳动协议样式
- 2024年场地调查委托协议模板
- 2024届安徽江南十校高三数学试题毕业班4月质量检查试题
- 2024年劳务合作及就业保障协议
- 化信息技术硬件采购协议范本
- 2024年智能设备部署与维护协议
- 2024年蔬菜产业链战略合作协议
- DB11∕T 1603-2018 睡莲栽培技术规程
- 2024专业新风系统安装服务协议模板
- 分析化学期中考试试题
- 新外研版高二英语选择性必修二Unit3-A-new-chapter课件(精编)
- 浙江省杭州市余杭区树兰中学2023--2024学年上学期九年级期中数学试卷
- 领导考察谈话怎么评价领导
- 叶片气动特性快速计算桨距角的改进算法
- 幼儿园优质公开课:小班科学《奇妙的声音》课件
- 2023非心脏外科手术围手术期心血管疾病管理中国专家共识(完整版)
- 山东省淄博市张店区2022-2023学年七年级上学期期中英语试卷
- 04.第四讲 坚持以人民为中心
- jgd280同步控制器使用说明
- 传染病首诊医生负责制度传染病首诊负责制
评论
0/150
提交评论