SQL Server 2008:有没有一种方法可以避免写入事务日志?

如何解决SQL Server 2008:有没有一种方法可以避免写入事务日志?

| 尽管我的查询是正确的,但我会间歇性地收到此错误。有没有办法避免写入事务日志? 当我检查指定的列时,每列的文本都显示为:\“ nothing \” 错误:   数据库的事务日志   \'tempdb \'已满。找出原因   日志中的空间无法重用,请参阅   中的log_reuse_wait_desc列   sys.databases \”。 谢谢,非常感谢,有点紧急。     

解决方法

您需要使用事务日志。这是在发生错误或查询部分完成时SQL回滚的方式。 根本原因不是事务日志,而是查询。您要么: 1-查询优化效果不佳(很多排序或哈希联接可能会导致这种情况) 2-在查询中过度使用了#temp表 3-出现驱动器空间问题 您可以发布正在运行的查询吗? 编辑: 为了澄清可能导致问题的原因... 如果您有多个“ 0”表,它们都将占用tempdb中的空间。查询引擎必须执行的任何排序 (没有索引的ѭ1,、不使用索引的复杂
JOIN
条件,很多
GROUP BY
或聚合函数等) 向事务日志中写入“ 4”,因为所有排序均在此完成。 查询本身可以正常运行,但可能需要优化以避免这些问题。     ,不,每笔交易都会记录下来。但是,这不是日志记录的问题。 它指出tempdb已满,而不是您的日志文件。您正在处理很多记录吗?使用临时表? 您需要从某种意义上管理增长,因为您可能需要进行批处理并更频繁地进行提交。     ,SQL Server使用事务日志来跟踪其操作,没有办法避免这种情况(出于多种原因,您也不想这样做)。问题是这样的: temdb是sql server中的系统DB,sql server使用它来写入临时数据,例如用于很长的查询的缓存数据和临时表(以#,##为前缀创建的任何表)。 当您首次安装sql server时,它在驱动器上创建了tempdb,所有数据均处于打开状态。 当您运行执行临时表或长时间运行的查询时,高速缓存的数据将写入tempdb中-当这样做时,它也固有地使用tempdb的事务日志。 在您的情况下,数据库的日志文件可能被填满,可能是因为有太多数据要缓存/写入tempdb,并且驱动器中tempdb日志文件可能已满。您的tempdb应该具有“自动缩小”选项“ on”,并且要轻松解决此问题,可以重新启动sql服务,它将自动消除tempdb日志文件中的多余数据。 您可以尝试稍微调整一下查询,这样就不必向tempdb中写入太多数据(消除长结果集。避免使用#temptables等)     ,只是为了验证tempdb问题,在您的JOINS中,强制LOOP加入ex: 从测试中选择* 内部LOOP加入 测试2 在x = y上 AND删除所有ORDER BY子句。 如果查询运行时没有填充您的tempdb(但可能会慢很多),则您知道需要哈希(或排序)并且使用了过多的tempdb空间。 可能需要进行良好的查询分析才能解决此问题,但是请检查执行计划,并尽一切可能删除排序或哈希联接,如果可能的话,可以通过创建索引或有时强制联接类型来实现(但通常情况下,如果统计数据很好,您可以仅应将其作为最后一种可能性)。 祝好运     

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?