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

您的位置:首頁技術(shù)文章
文章詳情頁

SQL Server的怪辟:異常與孤立事務(wù)

瀏覽:120日期:2023-11-02 19:13:27

一、首先從SQLServer中Error講起,SQL中錯誤處理有些怪辟 錯誤級別同是16但結(jié)果都不同。

以下是引用片段:select * from 一個不在的表 if @@error<>0 print '這個沒有輸出' go raiserror('',16,3) if @@error<>0 print '這個輸出了' go

exec('select * from 一個不在的表') if @@error<>0 print '這個輸出了' go

exec sp_executesql N'select * from 一個不在的表' if @@error<>0 print '這個輸出了'

這樣你可以發(fā)現(xiàn)通過exec或sp_executesql執(zhí)行可疑的sql,這樣就可以在后面捕捉到被異常終止的錯誤。

二、引出孤立事務(wù):

1、孤立事務(wù)的產(chǎn)生

以下是引用片段:select @@trancount 當(dāng)前連接的活動事務(wù)數(shù) --當(dāng)前連接的活動事務(wù)數(shù)為0 begin tran

select * from 一個不在的表 if @@error<>0 begin print '沒有執(zhí)行到這里來!' if @@trancount<>0 rollback tran end

commit tran

select @@trancount 當(dāng)前連接的活動事務(wù)數(shù) --執(zhí)行后你看看 當(dāng)前連接的活動事務(wù)數(shù)為1,且重復(fù)執(zhí)行會每次累加,這是很耗資源的。

應(yīng)為rollback根本就沒有被回滾。2、使用現(xiàn)有手段解決孤立事務(wù)

以下是引用片段:print @@trancount print '當(dāng)前連接的活動事務(wù)數(shù)' --當(dāng)前連接的活動事務(wù)數(shù)為0 if @@trancount<>0 rollback tran --在這里寫可以讓孤立事務(wù)只保持到下次你的過程被調(diào)用 begin tran

select * from 一個不在的表 if @@error<>0 begin print '沒有執(zhí)行到這里來!' if @@trancount<>0 rollback tran end

commit tran

---執(zhí)行后你看看 當(dāng)前連接的活動事務(wù)數(shù)為1,但重復(fù)執(zhí)行不會累加

print @@trancount print '當(dāng)前連接的活動事務(wù)數(shù)'

三、使用 set xact_abort 來控制部分違反約束的錯誤的執(zhí)行過程

以下是引用片段:create table Table1 (a int check(a>100)) go set xact_abort on begin tran insert table1 values(10) print '這里沒有被執(zhí)行' commit tran go print '' print '==============================================' print '' set xact_abort off begin tran insert table1 values(10) print '這里被執(zhí)行' commit tran

go drop table table1

但 set xact_abort 對于編譯產(chǎn)生的錯誤確沒有起作用,且同樣會產(chǎn)生孤立事務(wù)

set xact_abort on begin tran insert; 一個不在的表 values(10) print '這里沒有被執(zhí)行' commit tran go

print '' print '==============================================' print ''

set xact_abort off begin tran insert; 一個不在的表 values(10) print '這里沒有被執(zhí)行' commit tran go

select @@trancount 當(dāng)前連接的活動事務(wù)數(shù) ---有兩個孤立事務(wù) if @@trancount<>0 rollback tran

對于sql中怪辟的各種錯誤,和孤立事務(wù)在t-sql編程中一定要注意,小心孤立事務(wù)的陷阱,盡量避免浪費或孤立資源,Microsoft公開宣布過SQLServe下一版本Yukon將有內(nèi)置異常處理語法。那時可以通過代碼對無法預(yù)料的錯誤有更好的控制。

標(biāo)簽: Sql Server 數(shù)據(jù)庫
主站蜘蛛池模板: 超声骨密度仪-动脉硬化检测仪器-人体成分分析仪厂家/品牌/价格_南京科力悦 | 臻知网大型互动问答社区-你的问题将在这里得到解答!-无锡据风网络科技有限公司 | 高尔夫球杆_高尔夫果岭_高尔夫用品-深圳市新高品体育用品有限公司 | 置顶式搅拌器-优莱博化学防爆冰箱-磁驱搅拌器-天津市布鲁克科技有限公司 | 药品/药物稳定性试验考察箱-埃里森仪器设备(上海)有限公司 | 手机存放柜,超市储物柜,电子储物柜,自动寄存柜,行李寄存柜,自动存包柜,条码存包柜-上海天琪实业有限公司 | H型钢切割机,相贯线切割机,数控钻床,数控平面钻,钢结构设备,槽钢切割机,角钢切割机,翻转机,拼焊矫一体机 | 智能终端_RTU_dcm_北斗星空自动化科技| 上海诺狮景观规划设计有限公司| 细沙回收机-尾矿干排脱水筛设备-泥石分离机-建筑垃圾分拣机厂家-青州冠诚重工机械有限公司 | 盐水蒸发器,水洗盐设备,冷凝结晶切片机,转鼓切片机,絮凝剂加药系统-无锡瑞司恩机械有限公司 | 飞扬动力官网-广告公司管理软件,广告公司管理系统,喷绘写真条幅制作管理软件,广告公司ERP系统 | 交联度测试仪-湿漏电流测试仪-双85恒温恒湿试验箱-常州市科迈实验仪器有限公司 | 塑料薄膜_PP薄膜_聚乙烯薄膜-常州市鑫美新材料包装厂 | 衬氟止回阀_衬氟闸阀_衬氟三通球阀_衬四氟阀门_衬氟阀门厂-浙江利尔多阀门有限公司 | 踏板力计,制动仪,非接触多功能速度仪,逆反射系数测试仪-创宇 | 一体化隔油提升设备-餐饮油水分离器-餐厨垃圾处理设备-隔油池-盐城金球环保产业发展有限公司 | 工业铝型材生产厂家_铝合金型材配件批发精加工定制厂商 - 上海岐易铝业 | 高通量组织研磨仪-多样品组织研磨仪-全自动组织研磨仪-研磨者科技(广州)有限公司 | 皮带输送机-大倾角皮带输送机-皮带输送机厂家-河南坤威机械 | 无菌实验室规划装修设计-一体化实验室承包-北京洁净净化工程建设施工-北京航天科恩实验室装备工程技术有限公司 | 自动配料系统_称重配料控制系统厂家 | 软文推广发布平台_新闻稿件自助发布_媒体邀约-澜媒宝 | 上海小程序开发-小程序制作-上海小程序定制开发公司-微信商城小程序-上海咏熠 | 爱德华真空泵油/罗茨泵维修,爱发科-比其尔产品供应东莞/杭州/上海等全国各地 | 太空舱_民宿太空舱厂家_移动房屋太空舱价格-豪品建筑 | 青岛美佳乐清洁工程有限公司|青岛油烟管道清洗|酒店|企事业单位|学校工厂厨房|青岛油烟管道清洗 插针变压器-家用电器变压器-工业空调变压器-CD型电抗器-余姚市中驰电器有限公司 | TPU薄膜_TPU薄膜生产厂家_TPU热熔胶膜厂家定制_鑫亘环保科技(深圳)有限公司 | 闪蒸干燥机-喷雾干燥机-带式干燥机-桨叶干燥机-[常州佳一干燥设备] | 杭州月嫂技术培训服务公司-催乳师培训中心报名费用-产后康复师培训机构-杭州优贝姆健康管理有限公司 | 中山市派格家具有限公司【官网】 | 拼装地板,悬浮地板厂家,悬浮式拼装运动地板-石家庄博超地板科技有限公司 | 台湾阳明固态继电器-奥托尼克斯光电传感器-接近开关-温控器-光纤传感器-编码器一级代理商江苏用之宜电气 | 浙江红酒库-冰雕库-气调库-茶叶库安装-医药疫苗冷库-食品物流恒温恒湿车间-杭州领顺实业有限公司 | 英语词典_成语词典_日语词典_法语词典_在线词典网 | 健康管理师报考条件,考试时间,报名入口—首页 | 密封圈_泛塞封_格莱圈-[东莞市国昊密封圈科技有限公司]专注密封圈定制生产厂家 | 橡胶接头_橡胶软接头_套管伸缩器_管道伸缩器厂家-巩义市远大供水材料有限公司 | 罗茨真空机组,立式无油往复真空泵,2BV水环真空泵-力侨真空科技 | 粉末包装机-给袋式包装机-全自动包装机-颗粒-液体-食品-酱腌菜包装机生产线【润立机械】 | 我爱古诗词_古诗词名句赏析学习平台 |