位置: 编程技术 - 正文

SQL Server中避免触发镜像SUSPEND的N种方法(sql防御)

编辑:rootadmin

推荐整理分享SQL Server中避免触发镜像SUSPEND的N种方法(sql防御),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:sqlserver防止sql注入,如何防止sql注入及数据安全问题,一个有效防止sql注入的方法,数据库如何防止sql注入,如何防止sql,一个有效防止sql注入的方法,sqlserver防止sql注入,sqlserver防止sql注入,内容如对您有帮助,希望把文章链接给更多的朋友!

背景:我们在使用数据库的过程中,很多时候要追求性能,特别在处理大批量数据的时候更希望快速处理。那么对SQL SERVER而言,数据库实现大批量插入的优化方案,这里特别介绍通过大容量插入的一种方式。基本原理:简单恢复模式按最小方式记录大多数大容量操作,对于完整恢复模式下的数据库,大容量导入期间执行的所有行插入操作被完整地记录到事务日志中。如果数据导入量较大,会导致迅速填满事务日志。对于大容量导入操作,按最小方式记录比完整记录更有效,并减少了大容量导入操作填满日志空间的可能性,所以性能会得到极大的提升。 但是,大容量导入中按最小方式记录日志的前提条件需要满足:1. 当前没有复制表2. 指定了表锁定: 注意:锁定是 SQL Server 数据库引擎用来对多个用户同时访问同一数据块的操作进行同步。当事务修改某个数据块时,它将持有保护所做修改的锁,直到事务结束。指定大容量导入操作的表锁定后,该表将在大容量导入操作期间采取大容量更新 (BU) 锁定。大容量更新 (BU) 锁允许多个线程将数据并发地大容量导入到同一表中,同时阻止其他不进行大容量导入数据的进程访问该表。表锁定可以通过减少表的锁争用来提高大容量导入操作的性能。基本的理论信息还很多,这里不再累述。

在阿里云SQL SERVER的主备架构中,使用大容量插入时,使用时需要特别留意一个特性需要明确指定,如果不指定,会触发微软尚未在SQL Server R2中未修复的BUG,会导致镜像SUSPEND,那么如何来避免各种情况呢? 下面列举了一些常见的场景: 1、通过ado.net sqlbulkcopy 方式:只需要将SqlBulkCopy 指定SqlBulkCopyOptions.CheckConstraints就好,数据库指定AdventureWorksR2的Person表。举个例子:

2、通过jdbc sqlbulkcopy 方式:只需要在初始化对象时指定setCheckConstraints属性为TRUE,例如:QLServerBulkCopyOptions copyOptions = new SQLServerBulkCopyOptions();copyOptions.setCheckConstraints(true);3、通过DTS/SSIS方式:1. import/export data方式需要先保存SSIS包,然后修改Connection Manager的属性

SQL Server中避免触发镜像SUSPEND的N种方法(sql防御)

2. 直接使用SQL Server Business Intelligence Development Stuidio新建 SSIS包

3、通过BCP方式1. 先将数据BCP出来 BCP ...OUTBCP testdb.dbo.person Out "bcp_data" /t /N /U **** /P *** /S "****.sqlserver.rds.aliyuncs.com,"2. 然后将数据BCP进去 BCP...IN ,但需要指定提示:/h "CHECK_CONSTRAINTS"BCP testdb.dbo.person In "bcp_data" /C /N /q /k /h "CHECK_CONSTRAINTS" /U *** /P *** /b /S "***.sqlserver.rds.aliyuncs.com," 4、通过bulk insert方式(在RDS不可是实现,因为不允许上传文件)

四种方式教你在SQL Server中避免触发镜像SUSPEND,希望对大家的学习有所帮助。

SqlServer Mysql数据库修改自增列的值及相应问题的解决方案 SQLServer平台修改自增列值由于之前处理过sqlserver数据库的迁移工作,尝试过其自增列值的变更,但是通过SQL语句修改自增列值,是严格不允许的,直接

SQL SERVER修改函数名容易引发的问题分析 1.问题今天遇到一个奇怪的问题:使用sp_helptextXXX查询出来的函数定义名竟然跟函数名不同,而sp_helptext实际是查询sys.all_sql_modules这个系统视图的。直接

SQL中print、sp_helptext的限制与扩展 在SQL中,使用动态SQL是很常见的。有些复杂的计算,或是存储过程,代码很长,中间可能有多次执行SQL语句。而调试拼串的SQL语句却是件痛苦的事,很

标签: sql防御

本文链接地址:https://www.jiuchutong.com/biancheng/312879.html 转载请保留说明!

上一篇:浅谈SQL Server 2016里TempDb的进步(浅谈建筑地基基础加固施工技术亲)

下一篇:SqlServer Mysql数据库修改自增列的值及相应问题的解决方案(数据库my sql)

  • 汇算清缴所得税退回做账
  • 预收账款什么时候确认收入
  • 企业所得税的纳税人有哪些简答题
  • 工程施工的间接费用怎么结转
  • 当月销售次月开票怎么申报
  • 民办非企业不注销的法律后果
  • 网络贷款需要缴纳保证金吗
  • 发票号码不一致可以报销吗
  • 计提工会经费的贷方账户为
  • 房地产开发企业土地增值税清算
  • 企业债务重组的案例
  • 城市生活垃圾处理与资源化利用工艺设计
  • 进项票没开过来可以先开销项票吗
  • 短期借款的明细科目是什么
  • 鸿蒙的usb调试
  • win10检测系统
  • 给员工小孩买礼物合适吗
  • Google Bard VS ChatGPT:哪个是更好的AI聊天机器人?
  • 怎么批量给指定条件加入批注
  • 监事会职权口诀
  • 销售返点怎么做分录
  • 包装物租金怎么计算增值税
  • win10电脑输入法不见了怎么恢复
  • 为什么电脑连上蓝牙耳机却是外放
  • linux系列
  • 公司多缴税款超过3年怎么办
  • win10桌面图标怎么随意摆放
  • jetcar.exe - jetcar是什么进程 有什么作用
  • 房地产开发企业增值税怎么算
  • nodejs怎么更新版本
  • php23种设计模式
  • 跨年度退货
  • 跨的基本功有哪些
  • php判断字符串是否为ip地址
  • 手机话费怎么打发票
  • 销售不动产预征率是多少
  • 免税进项抵扣要做账吗
  • 工商年报资产状况纳税总额怎么填
  • 银行承兑汇票到期怎么兑现
  • 罚款记入其他应收款科目
  • 高新企业做账有什么不同
  • 什么是累积优先股
  • 企业被吊销后能当被告嘛
  • python time. time
  • centos5.7
  • 什么是服务型
  • 计税工资什么意思2019
  • 拯救你的方法
  • 增值税延期滞纳金计算
  • 采购人员差旅费为什么不计入成本
  • 捐赠 税收
  • 应付账款借方余额负数表示什么
  • 收到银行承兑汇票
  • 管理不善造成的存货盘亏损失计入什么科目
  • 固定资产折旧方法一经确定不得随意变更
  • 一般性企业
  • 发货单票据格式
  • 出售房产收入属于转让财产收入吗
  • 一个会计每个月平均有多少钱
  • sqlserver 字符串包含
  • vidaa 破解
  • win7系统怎样设置
  • ubuntu 无法正常启动
  • windows where命令
  • win8.1应用
  • glsl fract
  • vs2010配置opengl
  • javascript 操作css
  • 从零基础到入门
  • android studio入门项目
  • Python读取Excel文件需要什么
  • bat批量创建文件夹及子文件夹
  • insmod: init_module 'hello.ko' failed (Exec format error)
  • Linux 中常用的几种压缩工具?
  • eclipse出现an error has occurred
  • Unity64 AStarPath 寻路失效 Bug解决 IOS64 IL2CPP - Bad date/time format in the zip file
  • 在网上如何查询车辆违章
  • 购买税控盘怎么抵扣
  • 车辆购置税查询官网
  • 两税法的历史解释
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设