位置: 编程技术 - 正文

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)

  • 拆迁补偿款如何做账务处理
  • 小型微利企业的从业人数和资产总额
  • 费用报销怎么做账务处理
  • 合作社需要办什么证件
  • 发票号码代码不合法
  • 企业接收捐赠的会计分录
  • 企业所得税按月还是按季度申报
  • 净资产利润率等于净资产收益率吗
  • 注册资本金应该编入政府性基金预算吗
  • 进项税额转出是不可以抵扣吗
  • 申报退税金额是0是怎么回事
  • 一般纳税人有按季申报的吗
  • 计提生产经营
  • 水电费没有发票怎么报销
  • 机票退票费能抵扣旅客进项税吗
  • 通讯费发票抬头为个人能否报销
  • 残疾人保障金什么时候发放
  • 怎么确认权益性投资收益收入?
  • 收到员工补缴的公积金怎么入账
  • 加权平均数是什么意思的权
  • 技术合同 免税
  • window如何打开控制台
  • 公司主要开支是指什么
  • 取得普通发票与专票区别
  • windows未能正常启动
  • 销售过程的主要内容
  • PHP:file_get_contents()的用法_Filesystem函数
  • 收益类账户借增贷减
  • 外贸企业退运后的进项税如何处理
  • 什么情况下可以赔偿n+1
  • canvas软件教程
  • web自动化测试平台
  • 命令行激活profile命令的格式
  • print函数php
  • 帝国cms建站实例教程
  • 完美破费是什么意思
  • 所得税费用当月计提吗
  • 现代服务业主要功能
  • 如何做进项税额转出处理
  • 其他应付款贷方表示什么意思
  • 蔬菜开发票到哪里开呢?
  • 职工短期薪酬包括哪些
  • sqlserver避免死锁
  • 一般纳税人登记 核算地址
  • 进口原料需要交哪些税
  • 冲减以前年度管理费用需要更正报表吗
  • 银行承兑汇票怎么开
  • 出口退税的范围是多少
  • 非正常损失进项税额转出怎么计算
  • 通讯费计入哪个科目
  • 预收账款转收入的条件
  • 工会经费的列支范围有哪些
  • 流动资产周转天数下降说明什么
  • js操作剪切板
  • windows性能监视器横坐标
  • win7系统怎么把桌面文件放到d盘
  • 微软每月补丁更新一般于什么时间发布
  • win10声音突然变得很沉闷
  • windowsxp停止服务的时间
  • 图片缩略图是什么意思
  • securecrt输入中文乱码
  • win10教育系统
  • win10怎么添加游戏手柄
  • win10系统忘记电脑密码
  • win7系统笔记本无线网络找不到
  • win8怎么开启蓝牙
  • linux批量处理
  • jquery点击切换div
  • 安卓游戏模拟游戏制作
  • Unity3D事件函数的执行顺序
  • jquery渐变效果
  • 重写runnable
  • Landroid/support/v7/internal/widget/ActionBarOverlayLayout;.stopNestedScroll
  • 安卓手机管家
  • 增值税纳税申报表附列资料(三)
  • 国家税务总局安徽省税务局公告
  • 广东电子税务局财务报表在哪里查询
  • 电子税务局打印发票提示本机未检测到
  • 浙江职称评审网站官网
  • 免税发票可以抵多少税
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设