• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

<=> operator in MySQL_MySQL

mysql 搞代码 4年前 (2022-01-09) 28次浏览 已收录 0个评论

Opera

Have you ever seen “” in a SQL query while using MySQL? Does it mean less and equals to and greater than? Actually if you consider it as the union of , great, you are close to it. This is one form of equal operator in MySQL, it has the similar meaning to the = operator with some subtle difference.

According toMySQL documentation, isNULL-safe equal. This operator performs an equality comparison like the=operator, but returnsrather thanNULLif both operands areNULL, andrather thanNULLif one operand isNULL.

For example:

mysql> SELECT 1  1, NULL  NULL, 1  NULL;-> 1, 1, 0mysql> SELECT 1 = 1, NULL = NULL, 1 = NULL;-> 1, NULL, NULL

Next let’s get to know more details about operator in MySQL. To be noted this operator is not standard SQL operator, it’s only available in MySQL.

Similarity with=operator

Like the regular=operator, two values are compared and the result is either(not equal) or(equal); in other words:'a' 'b'yieldsand'a' 'a'yields.

Difference with=operator

Unlike the regular=operator, values ofNULLdon’t have a special meaning and so it never yieldsNULLas a possible outcome; so:'a' NULLyieldsandNULL NULLyields.

Contrary to=, whereby'a' = NULLyieldsNULLand evenNULL = NULLyieldsNULL; BTW, almost all operators and functions in MySQL work in this manner, because comparing againstNULLis basically undefined.

Usefulness

This is very useful for when both operands may containNULLand you need a consistent comparison result between two columns.

Another use-case is with prepared statements, for example:

<code>...WHERE col_a ?...</code>

Here, the placeholder can be either a scalar value orNULLwithout having to change anything about the query.

Related operators

Besidesthere are also two other operators that can be used to compare againstNULL, namelyIS NULLandIS NOT NULL; they’re part of the ANSI standard and therefore supported on other databases, unlike, which is MySQL-specific.

You can think of them as specializations of MySQL’s:

<code>'a'ISNULL==>'a'NULL'a'ISNOTNULL==>NOT('a'NULL)</code>

Based on this, your particular query (fragment) can be converted to the more portable:

<code>WHERE<em>本文来源gao.dai.ma.com搞@代*码(网$</em> p.name ISNULL</code>

搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:&amp;lt;=&amp;gt; operator in MySQL_MySQL

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址