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空间。 可能需要进行良好的查询分析才能解决此问题,但是请检查执行计划,并尽一切可能删除排序或哈希联接,如果可能的话,可以通过创建索引或有时强制联接类型来实现(但通常情况下,如果统计数据很好,您可以仅应将其作为最后一种可能性)。 祝好运     

要回复问题请先登录注册