gpt4 book ai didi

mysql - 为什么 column_name = (select column_name) 起作用而不是 column_name=null

转载 作者:太空宇宙 更新时间:2023-11-03 12:25:22 26 4
gpt4 key购买 nike

我正在为我的模型获取一些行,但是 View 有太多的标准,我厌倦了编写许多模型。为了让工作更轻松,我不想为每个选择的标准编写新的选择语句,所以一开始我尝试了尝试并仍然从选择中返回某些内容,即使用户提供/未提供多个可用条件之一也是如此。

SELECT * FROM members WHERE member_id = null AND member_club_id = 1 AND membership_year = null;

什么都不返回

我终于试过了

SELECT * FROM members WHERE member_id = (select member_id) AND member_club_id = (select member_club_id=1) AND membership_year = (select membership_year);

这可以正常工作。

我对 mysql 还是个新手,我想知道为什么第二种方法有效。

例如,感兴趣的是 select member_club_id=1member_id = (select member_id)

member_id = (select member_id) 中,我认为这将被读作 member_id=member_id,因为我没有名为 member id 的变量因此失败。

select member_club_id=1 中,我认为我会在 member_club_id 中得到 unknown column 错误,因此失败。

有人帮忙。

最佳答案

您不能将 =NULL 一起使用。使用 IS NULLIS NOT NULL

参见:http://dev.mysql.com/doc/refman/5.0/en/working-with-null.html

关于mysql - 为什么 column_name = (select column_name) 起作用而不是 column_name=null,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17970566/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com