- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我有一个触发器,它是 AFTER UPDATE
。我有一个条件不起作用,我该如何解决?
$$
BEGIN
IF NEW.colname <> OLD.colname THEN
DELETE FROM tableX WHERE id = OLD.id;
END IF;
END
$$
应该注意的是,如果我编写此 IF 1 THEN
,则 DELETE
查询有效。所以问题是那个条件。有什么问题吗?
正如 @Darwin von Corax 在评论中所说,当其中一个 NEW.colname
、OLD.colname
为 null 时
,则所有该条件都返回 false
。所以我想知道如何创建这样的条件?
Null <> 10 -- true
Null <> Null -- false
10 <> 12 -- true
32 <> Null -- true
3 <> 3 -- false
最佳答案
如果 NEW.colname
或 OLD.colname
是 null
,然后 <>
将返回 null
if
将与 false
相同.
幸运的是,有一个解决方案:<=>
(NULL 安全相等)运算符,返回 1
如果两个操作数都是 null
和 0
如果只有一个。表达式
IF NOT (NEW.colname <=> OLD.colname) THEN
应该做你需要的。
关于mysql - 为什么相反的操作 <> 对触发器不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36143519/
今天有小伙伴给我留言问到,try{...}catch(){...}是什么意思?它用来干什么? 简单的说 他们是用来捕获异常的 下面我们通过一个例子来详细讲解下
我正在努力提高网站的可访问性,但我不知道如何在页脚中标记社交媒体链接列表。这些链接指向我在 facecook、twitter 等上的帐户。我不想用 role="navigation" 标记这些链接,因
说现在是 6 点,我有一个 Timer 并在 10 点安排了一个 TimerTask。之后,System DateTime 被其他服务(例如 ntp)调整为 9 点钟。我仍然希望我的 TimerTas
就目前而言,这个问题不适合我们的问答形式。我们希望答案得到事实、引用资料或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我就废话不多说了,大家还是直接看代码吧~ ? 1
Maven系列1 1.什么是Maven? Maven是一个项目管理工具,它包含了一个对象模型。一组标准集合,一个依赖管理系统。和用来运行定义在生命周期阶段中插件目标和逻辑。 核心功能 Mav
我是一名优秀的程序员,十分优秀!