SQLServer执行大脚本文件时,提示“无法执行脚本没有足够的内存继续执行程序 (mscorlib)”

SQLServer执行大脚本文件时,提示“无法执行脚本没有足够的内存继续执行程序 (mscorlib)”

问题描述:

 

有时候服务器操作导入数据.sql,或者

当需求不可以直接备份整库还原时,往往通过导出数据库脚本的方式来部署-还原数据库表

但是当数据库导出脚本很大,用Microsoft SQL Server Management Studio执行脚本时,往往会遇到“内存不足”的提示。

 

解决办法:

用微软自带的sqlcmd工具,可以导入执行。以SQL Server 2012版本为例:

 

 

第一步:Win+R 键入:cmd 命令,开启命令行工具;

第二步:输入:(具体目录路径跟你安装的SQL位置有关)

cd C:\Program Files\Microsoft SQL Server\110\Tools\Binn 

第三步:输入:

sqlcmd -S . -U sa -P pwd123 -d mgdata -i D:\DBBackup\data.sql

参数说明:-S 服务器地址 -U 用户名 -P 密码  -d 数据库名称 -i 脚本文件路径 

(建议将数据脚本文件拷到此目录,就只用写文件名,而不用写全路径了),注意参数大小写和空格符号。

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
"System.AccessViolationException"类型的异常通常表示在VB.NET程序中尝试访问受保护的内存出现了问题。这可能是由以下几个原因导致的: 1. 未正确分配或释放内存:如果您在代码中使用了不正确的内存分配或释放操作,可能会导致内存损坏,从而引发此异常。 2. 使用了已释放的对象或指针:当您尝试访问已释放的对象或已释放的内存,就会发生此异常。确保在使用对象或指针之前检查其是否为null,并且不要在其已释放的状态下使用它们。 3. 调用了非托管代码:如果您的VB.NET程序调用了非托管代码(如使用DllImport特性导入的DLL函数),并且在与非托管代码的交互过程中发生了内存损坏,就有可能引发此异常。 4. 缓冲区溢出:如果您在VB.NET程序中使用了不安全的代码,例如使用指针或数组操作,并且操作导致写入超出缓冲区边界的内存位置,就可能导致内存损坏和此异常的发生。 要解决此问题,您可以尝试以下几个步骤: 1. 检查代码中是否存在任何未正确处理的内存分配和释放操作,并确保正确地分配和释放内存。 2. 确保在使用任何对象或指针之前进行空引用检查,以避免使用已释放的对象或内存。 3. 如果您的代码涉及非托管代码的调用,请确保与非托管代码的交互正确且安全,避免内存损坏。 4. 避免使用不安全的代码,特别是涉及指针或数组操作的代码。如果必须使用不安全的代码,请确保操作不会超出缓冲区边界。 如果您无法确定导致异常的确切原因,可以尝试使用调试器来跟踪异常的发生位置,并检查相关代码以找出问题所在。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值