首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >为什么ALTER触发器对其他会话/连接没有影响?

为什么ALTER触发器对其他会话/连接没有影响?
EN

Stack Overflow用户
提问于 2014-05-14 15:20:57
回答 2查看 466关注 0票数 2

当我使用FlameRobin SQL编辑器修改触发器时,这些更改对其他会话/连接没有影响:触发器仍在执行旧版本。

这怎麽可能?如何强制更改影响所有连接?

我确实在ALTER TRIGGER之后调用了ALTER TRIGGER,而且在另一个连接中也没有打开的事务。这不是与事务相关的,而是与会话/连接相关的。

“其他连接”是Delphi-应用程序(使用InterBase组件),但完全相同的行为可以使用两个FlameRobin实例来再现。

我在用:

  • 火鸟2.5.2 (SuperClassic)
  • FlameRobin 0.9.3
  • 德尔菲XE5 update2
EN

回答 2

Stack Overflow用户

发布于 2014-05-15 08:09:42

在Firebird中,事务是事务性的,因此在事务更改数据库之前启动的事务将看到数据库的状态,就像事务完成其工作之前一样,只有在提交了数据库的事务之后,它才能看到您的更改。

除此之外,还有一个元数据缓存。在经典和SuperClassic模型中,每个连接都有自己的缓存(而不是共享缓存),并且这个每个连接缓存不会立即失效(但我不知道确切的细节)。这意味着在更改之前在事务中准备的语句将像数据库没有更改一样工作(除非更改根本改变了一个表),而新准备的语句将处理这些更改。

尽管在使用数据库时DDL是可能的,但我建议对数据库脱机/单用户执行DDL,或者强制用户在执行DDL后重新连接,以确保所有连接都看到并使用新的更改。

票数 3
EN

Stack Overflow用户

发布于 2015-09-25 03:47:54

正如Mark所建议的那样,每次更改之后,您都必须重新启动所有内容。或者你有更好的选择:切换到SuperServer,它还有比SuperClassic更少的bug和内存泄漏。SuperClassic是垃圾。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23658823

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档