电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

SQL Server 7.0 入門(八)

瀏覽:130日期:2023-10-28 10:01:42
存儲過程中返回結果;;;;;;;從存儲過程中返回結果有三種方式:1、;;返回結果集這是客戶端應用程序返回結果的最通用的方法。結果集是通過使用SELECT語句選擇數據產生的。結果集可以從永久表、臨時表或局部變量中產生。將結果返回到另一個存儲過程不是一種有效的方法。存儲過程不能訪問另一個存儲過程建立的結果集。例如從永久表中返回結果集:USE pubsGOCREATE PROCEDURE ap_CreateResultFromPermtableASSELECT au_iname FROM authorsGO例如從局部變量中創建結果集:USE pubsGOCREATE PROCEDURE ap_CreateResultFromVariableASDECLARE @au_iname char(20)SELECT @au_iname = au_iname FROM authorsWHERE au_id = ‘172-32-1176’SELECT @au_idGO2、;;設置OUTPUT參數的值輸出參數經常用來從存儲過程中檢索出結果。如果某個參數在傳輸到存儲過程中時被定義成OUTPUT,則對該參數的任何修改在退出存儲之后仍然有效。例如:USE pubsGOCREATE PROCEDURE ap_SetOutputVar @count integer OUTPUTASSELECT @count = count(*) FROM authorsGO從輸出參數中檢索出值:USE pubsGOCREATE PROCEDURE ap_GetOutputVarASDECLARE @num integerEXECUTE ap_SetOutputVar @num OUTPUTPRINT “the count is”+convert(char,@num)GO· 將游標使用成OUTPUT參數。游標可以使用OUTPUT(輸出)參數,但不能使用成輸入參數。也就是說,游標可以作為結果返回,但卻不能傳輸到過程中去。當游標被用作參數時,需要限定其為OUTPUT和VARYING。VARYING關鍵字指出該結果集要用來支持輸出參數。這樣就提供了將結果集返回到調用過程的能力。例如:USE pubsGOCREATE PROCEDURE GetTitleCount @count_cursor CURSOR VARYING OUTPUTASSET @count_cursor = CURSORFORSELECT au_id,count(*)FROM titleauthorsGROUP BY au_idOPEN @count_cursorGO3、;;通過RETURN參數返回狀態這是一種從存儲過程返回錯誤碼的方法。存儲過程總是返回一個狀態值,用戶也可以使用RETURN語句返回自己的狀態。例如:USE pubsGOCREATE PROCEDURE ap_SetReturnStatusASDECLARE @count integerSELECT @count = count(*) FROM authorsIF @count = 0RETURN(1)ELSERETURN (0)GO例如檢索出返回的狀態:USE pubsGOCREATE PROCEDURE ap_GetReturnStatusASDECLARE @status integerEXECUTE @status = ap_SetReturnStatusIF @status = 1PRINT “No rows found”ELSEPRINT “successful”GO在存儲過程中進行錯誤處理;;;;;;;如同其它程序一樣,在存儲過程中進行錯誤處理是非常重要的。系統變更@@error在執行每一個Transact SQL語句之后都會得到一個值。對于成功的執行,@@error的值為0,如果出現錯誤,則@@error中將包含錯誤信息。@@error系統變量對存儲過程的錯誤處理是非常重要的。;;;;;;;注意:為了防止錯誤,@@error所能設置的值在sysmessages表的“error”中反映了出來。在存儲過程中的錯誤有兩種類型:1、;;;;數據庫相關的錯誤這些錯誤是由數據庫的不一致性引起的,系統使用非0的@@error值表示特定的數據庫問題。在Transact SQL執行之后,可以通過@@error獲得所出現的錯誤。如果發現@@error不為0,則必須采取必要的行動,大多數情況下,存儲將不再繼續進行處理而返回。下面的示例展示了典型的獲取數據庫錯誤的方法。該過程將錯誤代碼放置到輸出變量中,這樣,調用程序就能夠訪問到。USE pubsGOCREATE PROCEDURE ap_TrapDatabaseError @return_code integer OUTPUTASUPDATE authors SET au_iname = “Jackson”WHERE au_iname = “Smith”IF @@error <> 0BEGIN;;;;;;;SELECT @return_code = @@error;;;;;;;RETURNENDELSE;;;;;;;@return_code = 0GO2、;;;;業務邏輯錯誤這些錯誤是由于違反了業務規則而引起的。要獲取這些錯誤,首先需要定義業務規則,基于這些規則,需要在存儲過程中增加必要的錯誤檢測代碼。人們經常使用RAISERROR語句通報這些錯誤。RAISERROR提供了返回用戶定義錯誤及將@@error變量設置成用戶定義錯誤號的能力。錯誤消息可以被動態地建立,或者基于錯誤號從“sysmessages”表中檢索到。一旦出現了錯誤,錯誤就會以一種服務器錯誤消息的方式返回到客戶機。下面是RAISERROR命令的語法:RAISERROR (msg_id | msg_str, severity, state[, argument ][,…n]])[WITH options]Msg_id指明用戶定義消息的id,該消息存儲在“sysmessages”系統表中。Msg_str用于動態創建消息的消息字符串。這與C語言中的“printf”非常相似。Severity定義用戶賦值的錯誤消息嚴重程度。State是從1到127的任意整數值,它表示錯誤的調用狀態信息。負數的state值將缺省為1。OPTIONS指明錯誤的定制選項。OPTIONS的有效值如下:1);;LOG。將錯誤記錄到服務器錯誤日志和NT事件日志中。該選項需要消息帶有從19到25的嚴重程度。而只有系統管理員才能發出這種消息。2);;NOWAIT。將消息立即發送到客戶端服務器。3);;SETERROR。不管其嚴重級別如何,將@@error的值設置為msg_id或5000。遠程過程調用;;;;;;;SQL Server提供了調用駐留在不同服務器上的存儲過程的能力。調用這樣的存儲過程稱謂遠程存儲過程調用。為了使得調用能從一個SQL Server轉移到另一個服務器,兩個服務器應該相互定義成對方的有效遠程服務器。;;;;;;;設置遠程服務器的配置:;;;;;;;· 擴展某個服務器的組。;;;;;;;· 右擊該服務器并點擊“Properties”。;;;;;;;· 設置選項“Allow other SQL Servers to connect remotely to this SQL server via RPC”。;;;;;;;· 設置“Query time out”選項的值,該值指定從一個查詢處理返回所能等待的秒數。缺省值為0,表示允許無限的等待時間。;;;;;;;· 設置完成配置選項之后,點擊“OK”。;;;;;;;· 重新啟動服務器之后,修改將會生效。;;;;;;;· 在另一臺遠程服務器上重復相同的步驟。;;;;;;;調用遠程存儲過程需要指明服務器的名稱,后帶數據庫的名稱和擁有者的名稱。下面是在不同的服務器(Server2)上調用一個存儲過程的示例。Exec server2.pubs.dbo.myproc豆豆的后話:;;;;;;;這里只是粗淺的介紹了SQL Server常用的知識,對象也是基于SQL Server數據庫編寫應用程序的編程人員,而非數據庫管理者。但對于應用程序編程者,了解數據庫的管理也是非常有用的。建議在以后的時間自行去了解數據庫的管理,這對于優化程序也是相當有用的。————————全文完—————————
標簽: Sql Server 數據庫
主站蜘蛛池模板: 智能气瓶柜(大型气瓶储存柜)百科 | 线材成型机,线材折弯机,线材成型机厂家,贝朗自动化设备有限公司1 | 纯水设备_苏州皙全超纯水设备水处理设备生产厂家 | 全自动烧卖机厂家_饺子机_烧麦机价格_小笼汤包机_宁波江北阜欣食品机械有限公司 | 智能汉显全自动量热仪_微机全自动胶质层指数测定仪-鹤壁市科达仪器仪表有限公司 | 润东方环保空调,冷风机,厂房车间降温设备-20年深圳环保空调生产厂家 | 一体化污水处理设备-一体化净水设备-「山东梦之洁水处理」 | 澳门精准正版免费大全,2025新澳门全年免费,新澳天天开奖免费资料大全最新,新澳2025今晚开奖资料,新澳马今天最快最新图库 | sus630/303cu不锈钢棒,440C/430F/17-4ph不锈钢研磨棒-江苏德镍金属科技有限公司 | 深圳侦探联系方式_深圳小三调查取证公司_深圳小三分离机构 | 有机肥设备生产制造厂家,BB掺混肥搅拌机、复合肥设备生产线,有机肥料全部加工设备多少钱,对辊挤压造粒机,有机肥造粒设备 -- 郑州程翔重工机械有限公司 | 吸污车_吸粪车_抽粪车_电动三轮吸粪车_真空吸污车_高压清洗吸污车-远大汽车制造有限公司 | 深圳宣传片制作_产品视频制作_深圳3D动画制作公司_深圳短视频拍摄-深圳市西典映画传媒有限公司 | 工业制氮机_psa制氮机厂家-宏骁智能装备科技江苏有限公司 | 空气能暖气片,暖气片厂家,山东暖气片,临沂暖气片-临沂永超暖通设备有限公司 | 合肥花魁情感婚姻咨询中心_挽回爱情_修复婚姻_恋爱指南 | 课件导航网_ppt课件_课件模板_课件下载_最新课件资源分享发布平台 | 合肥礼品公司-合肥礼品定制-商务礼品定制公司-安徽柏榽商贸有限公司 | ph计,实验室ph计,台式ph计,实验室酸度计,台式酸度计 | 烟台螺纹,烟台H型钢,烟台钢材,烟台角钢-烟台市正丰金属材料有限公司 | 注塑_注塑加工_注塑模具_塑胶模具_注塑加工厂家_深圳环科 | 步进_伺服_行星减速机,微型直流电机,大功率直流电机-淄博冠意传动机械 | 瓶盖扭矩测试仪-瓶盖扭力仪-全自动扭矩仪-济南三泉中石单品站 | 防爆正压柜厂家_防爆配电箱_防爆控制箱_防爆空调_-盛通防爆 | 南京办公用品网-办公文具用品批发-打印机耗材采购 | 广州工业氧气-工业氩气-工业氮气-二氧化碳-广州市番禺区得力气体经营部 | 离子色谱自动进样器-青岛艾力析实验科技有限公司 | 上海地磅秤|电子地上衡|防爆地磅_上海地磅秤厂家–越衡称重 | 深圳办公室装修-写字楼装修设计-深圳标榜装饰公司 | 岸电电源-60HZ变频电源-大功率变频电源-济南诚雅电子科技有限公司 | 重庆网站建设,重庆网站设计,重庆网站制作,重庆seo,重庆做网站,重庆seo,重庆公众号运营,重庆小程序开发 | 挖掘机挖斗和铲斗生产厂家选择徐州崛起机械制造有限公司 | 搪玻璃冷凝器_厂家-越宏化工设备| 利浦顿蒸汽发生器厂家-电蒸汽发生器/燃气蒸汽发生器_湖北利浦顿热能科技有限公司官网 | 喷砂机厂家_自动喷砂机生产_新瑞自动化喷砂除锈设备 | 安徽千住锡膏_安徽阿尔法锡膏锡条_安徽唯特偶锡膏_卡夫特胶水-芜湖荣亮电子科技有限公司 | 骨密度检测仪_骨密度分析仪_骨密度仪_动脉硬化检测仪专业生产厂家【品源医疗】 | ptc_浴霸_大巴_干衣机_呼吸机_毛巾架_电动车加热器-上海帕克 | 杜康白酒加盟_杜康酒代理_杜康酒招商加盟官网_杜康酒厂加盟总代理—杜康酒神全国运营中心 | 背压阀|减压器|不锈钢减压器|减压阀|卫生级背压阀|单向阀|背压阀厂家-上海沃原自控阀门有限公司 本安接线盒-本安电路用接线盒-本安分线盒-矿用电话接线盒-JHH生产厂家-宁波龙亿电子科技有限公司 | 特种阀门-调节阀门-高温熔盐阀-镍合金截止阀-钛阀门-高温阀门-高性能蝶阀-蒙乃尔合金阀门-福建捷斯特阀门制造有限公司 |