SQL查询结果中的NULL代表啥意思

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了SQL查询结果中的NULL代表啥意思相关的知识,希望对你有一定的参考价值。

Null是在计算中具有保留的值。

Null用于指示指针不引用有效对象。程序通常使用空指针来表示条件,例如未知长度列表的结尾或未执行某些操作; 这种空指针的使用可以与可空类型和选项类型中的Nothing值进行比较。

空指针不应与未初始化的指针混淆,保证空指针与指向有效对象的任何指针进行比较。但是,根据语言和实现,未初始化的指针可能没有任何此类保证。它可能与其他有效指针相等; 或者它可能比较等于空指针。它可能在不同的时间做两件事。

扩展资料:

空字符通常表示为源代码字符串字符或字符常量中的转义序列。在许多语言,这不是一个单独的转义序列,而是八进制转义序列,单个八进制数字为0。

因此,‘\\0’不能跟随任何数字0通过7;否则它被解释为更长的八进制转义序列的开始。被在使用中发现各种语言的其他转义序列\\000,\\x00,\\z,或的Unicode表示\\u0000。

表示空字符的能力并不总是意味着生成的字符串将被正确解释,因为许多程序将认为null作为字符串的结尾。因此,键入它的能力会创建一个称为空字节注入的漏洞,并可能导致安全漏洞。

参考资料来源:百度百科—Null

参考技术A null事实上代表的意思是“不知道”,和“空”(empty)还是有细微的区别的:
创建数据表的时候某列(假设为title)的约束条件为不允许为“不知道”,写为not null;即不允许不为该列赋值;
此后你在使用SQL将其赋值为null(update …… set titile=null或者insert into……values (null,))等时,会报错。但是如果将其赋值为空('')时,则不会报错。
另外在select查询时,where子句中如果查询为null的应该为 where title is null,不为null的是where title is not null;
而查询为空的则是where title='' 不为空的是 where title<>'',简单描述,希望能帮到你。本回答被提问者采纳
参考技术B 该字段为空 参考技术C 空值 你理解为 没有 就可以了

sql查询中的“%()s”是啥意思?

【中文标题】sql查询中的“%()s”是啥意思?【英文标题】:What does "%()s" means in sql query?sql查询中的“%()s”是什么意思? 【发布时间】:2018-02-15 16:20:55 【问题描述】:

有人可以帮我解决这个问题吗?我对 SQL 没有深入的了解。这两行在查询中是什么意思?

HIT_DAY = TO_DATE(%(date)s,'MM-DD-YYYY')
ss.weblab_name = %(experiment)s

日期和实验是我应该传递给查询的某种参数吗?为什么他们以“s”结尾?这个参数怎么传?

这是整个查询:

SELECT 
    session_count,
    treatment
FROM 
    SESSIONS ss
WHERE 
    HIT_DAY = TO_DATE(%(date)s,'MM-DD-YYYY')
AND
    ss.weblab_name = %(experiment)s
GROUP BY
    ss.treatment_name
;

【问题讨论】:

【参考方案1】:

一些 SQL IDE,如 Datagrip 和 Redash 使用这些类型的东西来指示可以输入用户参数。 看 https://www.jetbrains.com/help/datagrip/user-parameters.html http://help.redash.io/article/44-query-parameters

某些应用程序使用这种格式来指示在动态创建查询时应将数据放置在何处(因此这将是一个查询模板)

它们很可能只是字符串替换,因此 %(experiment) 可能会解析为小部件,但列名可能是小部件。或者可能还有其他东西,但它完全取决于使用这些的应用程序。不是红移。

【讨论】:

以上是关于SQL查询结果中的NULL代表啥意思的主要内容,如果未能解决你的问题,请参考以下文章

sql查询里面xtype='u'是啥意思?

sql查询里面xtype='u'是啥意思?

plsql查询语句中的not in啥意思

问号在 SQL 查询中代表啥? [复制]

sql查询中的“%()s”是啥意思?

mysql的查询语句union是啥意思