首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

MySQL中的case when中对于NULL值判断的小坑

今天在开发程序中,从MySQL中提取数据的时候,使用到了case when的语法用来做判断,在使用过程中在判断NULL值的时候遇到个小问题; 具体的现象测试如下: 表结构如下: CREATE TABLE...:如果name为空字符或NULL,输出不同的值,用TEST替换空字符,用PROD替换NULL SQL语句如下: mysql>>SELECT -> id, -> CASE...那么针对上面的查询需求,我们就可以调整成语法2的语法格式: mysql>SELECT -> id, -> CASE -> WHEN name...语句无法满足需求,下面我们再来看下面一个SQL语句,同样也存在问题,无法满足我的查询需求,大家在使用中要注意; mysql>SELECT -> id, -> CASE...主要是将第一种语法与第二种语法混用导致的,case 后面的case_value 的值有两种:真实值或者为null,而 when 后面的条件也有两个值:true或者false,所以出现查询结果和实际不匹配的情况

3.1K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySQL递归查询_函数语法检查_GROUP_CONCAT组合结果集的使用

    1-前言: 在MySL使用递归查询是很不方便的,不像SQL Server可以直接使用声明变量,使用虚拟表等等。如:DECLARE,BEGIN ...  END   ,WHILE ,IF 等等。...在MySQL可以通过创建函数,来使用上面的流程控制语句,Mysql对函数的语法检查也是很苛刻的,可以说很烦人,不熟悉的人估计会哭。。。...2-递归查询关键部分:   a-我的表结构:   b-我的递归脚本:   用于查询:当前类目ID及所有的父级元素的ID使用逗号分割开的一个字符串:   下面脚本里使用了组合结果集的一个函数:GROUP_CONCAT..., ',', pathID);     END IF; END WHILE; RETURN pathID; END;   查询结果展示: 3-一些需要注意的点,函数的一些特殊语法检查:  a-脚本结束标记检查...INTO 给pid赋值,NULL   我们这里是想在查不到的结果的时候,通过WHILE的判断结束循环,如果不通过GROUP_CONCAT函数将结果传给pid,那么将会进入无线循环当中,是很坑的!!

    2.5K30

    基于 MySQL 的数据库实践(基本查询)

    首先根据准备工作中的操作导入大学模式,打开数据库连接后进入到 MySQL 的交互界面,再使用命令 use db-book; 切换到 db-book 数据库。...,如上所示,返回一个与 instructor 一样的关系,除了属性 salary 的值是原来的 1.1 倍,查询的语义是为每位教师增长 10% 的工资的结果,注意这并不修改 instructor 关系,...多关系查询 上面的查询都是基于单个关系的,但是通常我们的查询需要从多个关系中获取信息。  考虑查询,找出所有教师的姓名,以及他们所在的系的名称和系所在的建筑物的名称。...这种命名惯例的使用,要求出现在 from 子句中的关系具有可区分的名字,在某些情况下这样的要求达不到,例如当需要组合来自同一个关系的两个不同元组的信息的时候,对于这种情况,在后面我们会提到可以用更名(rename...再考虑一个查询,找出 Computer Science 系的教师名字和教授的课程标识 mysql> select name, course_id     -> from instructor, teaches

    1.1K10

    解锁MySQL group_concat的无限可能性:解决长度限制并实现高效查询

    第一部分:MySQL的GROUP_CONCAT函数 1.1 GROUP_CONCAT简介 MySQL的GROUP_CONCAT函数是一种强大的聚合函数,通常用于将多个行合并为一个字符串。...2.1 修改GROUP_CONCAT的长度限制 MySQL允许我们通过修改group_concat_max_len系统变量来更改GROUP_CONCAT的长度限制。...2.2 全局修改GROUP_CONCAT的长度限制 如果你希望对整个MySQL服务器进行全局的修改,可以修改MySQL配置文件(通常是my.cnf或my.ini)。...来修改长度限制,然后执行GROUP_CONCAT查询。...结论 GROUP_CONCAT是一个非常有用的MySQL函数,可以用于合并多个行的值。然而,长度限制可能会在处理大量数据时成为问题。

    5.7K30

    mysql学习—查询数据库中特定的值对应的表

    遇到一个问题,我将问题抽象简单描述如下: 循环查询数据库所有表,查出字段中包含tes值的表,并且将test修改为hello?...因为自己不才找了很久也没有找到很好的方法,又对mysql的游标等用法不是很了解,在时间有限的情况下,发现了下面的方法,分享给大家: 1:查找 (1)使用工具 我使用的mysql的Navicat...for MySQL的工具 (2)使用sql的语法 这个方式暂时我还是不会,等我熟悉语法之后在补充。...(pic, '/attached', 'http://www.tcl.com'); 正则替换法: 下面这段的意思是:df_templates_pages 表的字段为enerateHtml中包含有.../toProduct', '/product') WHERE generateHtml REGEXP ('\/front\/product\/toProduct[Kyu]{0,4}\/'); 3.单表的全字段查询某个值

    7.5K10

    mysql查询字段中带空格的值的sql语句,并替换

    (自己写的这四行)查询带有空格值的数据:SELECT * FROM 表名 WHERE 字段名 like ‘% %’; 去掉左边空格 update tb set col=ltrim(col); 去掉右边空格...TRIM(TRAILING ‘xyz’ FROM ‘phpernotexxyz’); -> ‘phpernotex’ 当我们在使用sql查询的时候,如果数据库中的这个字段的值含有空格(字符串内部...,非首尾),或者我们查询的字符串中间有空格,而字段中没有空格。...补充:MySQL中关于查询条件中的字符串空格问题 https://blog.csdn.net/alibert/article/details/40981185 假设当前mysql数据库中有个表:sysuser...官方文档上说是MySQL校对规则属于PADSPACE,对CHAR和VARCHAR值进行比较都忽略尾部空格,和服务器配置以及MySQL版本都没关系。

    9.4K20

    PQ获取TABLE的单一值作为条件查询MySQL返回数据

    为简化模型,我们采用下面的数据来讲解: 比如我们要查询的人是moon,那么首先在powerquery编辑器中右键moon然后深化: 这样就得到了显示的值:moon。...注意这里的值是一个单纯的值,而不是一个一行一列的表。...当然,如果你关闭并上载,的确会得到一张一行一列的表: 由于我们并不想要这张表,而是想得到这个值,所以直接在这个查询后,将查询结果作为下一步查询的输入值。...得到了这个值,我们就可以调用MySQL去查询了: let 源 = Excel.CurrentWorkbook(){[Name="表2"]}[Content], 更改的类型 = Table.TransformColumnTypes...我们到查询编辑器中看看: 注意第三行: NAME = 更改的类型{1}[NAME], M语言允许我们通过坐标的方式获取表中单一的值,[NAME]代表NAME列,而{1}代表第2行,因为表都是从标号为0的行开始的

    3.5K51

    MySQL用了函数到底会不会导致索引失效

    一旦创建了功能索引,MySQL 在执行涉及该表达式的查询时能够使用这个索引,从而提升查询效率。...注意事项 函数索引虽然能够显著提高涉及索引表达式的查询性能,但其创建可能增加数据插入、更新和删除的成本,因为数据库需要维护更多的索引数据。因此,在创建函数索引时需要谨慎,不能盲目使用。...; 使用 JSON 函数 如果在 MySQL 中使用 JSON 数据类型,并且需要基于 JSON 属性进行查询,可以创建基于 JSON 函数的索引。...(JSON_EXTRACT(order_info, '$.status')))); 这样,您可以高效地查询具有特定状态的订单: SELECT * FROM orders WHERE JSON_UNQUOTE...虽然函数索引可以显著提升特定查询的性能,但它们也会增加插入、更新和删除操作的成本,因为数据库需要维护更多的索引数据。因此,在实际应用中,建议仅对那些经常作为查询条件的列和表达式创建函数索引。

    55810

    如何基于Python实现MySQL查询的API设计,附上完整脚本

    我们在平时的工作中不可避免会有连接到数据库的操作,通常来说我们会使用基于Shell的方式,或者基于数据库驱动的连接方式,比如JDBC,ODBC,PyMySQL,MySQLdb等。...,但是基于数据库版本的差异,有些低版本是不支持输出一些格式的,所以使用Shell来输出SQL查询的结果显然不是一个通用而且优雅的实现方式。...大概的设计方式如下: ? 我们因为版本的选型在这里使用的是基于MySQLdb的实现方式,我们来逐个分析一下。...首先对于SQL查询来说,输出结果,执行时长,结果集行数等这些是我们关注的一些数据,要实现这个功能,实际上要实现一揽子细小的功能。...1)使用MySQLdb或者其他驱动的默认情况下,输出的结果都是只有数据,而没有相应的列名等信息,我们需要做一些补充操作,输出为字段名和字段值的映射,比如{"id":100,"name":"aaa"}这样的形式

    1.4K30

    MySQL 虚拟列详解

    这将不起作用)ALTER TABLE your_table_name DROP COLUMN virtual_column_name; -- 然后添加新的虚拟列ALTER TABLE your_table_nameADD...这意味着生成的列值会被存储在磁盘上,类似于普通列。但是,它们仍然只在查询时计算。VIRTUAL:虚拟生成的列。这类列不会在磁盘上存储其值,而是在查询时根据基础列动态计算得出。...创建虚拟列的示例(使用 VIRTUAL)ALTERTABLE employees ADD full_name VARCHAR(101) AS (CONCAT(first_name, ' ', last_name...对于频繁更新的数据,这可能会导致性能问题。索引:你可以为生成的列创建索引,这在某些情况下可以提高查询性能。...但是,对于 VIRTUAL 类型的生成列,索引实际上是基于其基础列的,而不是直接基于生成列本身。这意味着查询优化器可能会选择不同的执行计划。

    6410

    MySQL笔记之常用用法整理手册

    《Oracle学习笔记整理手册》之后,我再写一篇Mysql版本的 PS:本博客收录自己工作中遇到学到的一些mysql技能,有时间就更新整理一下 (1) str_to_date oracle有to_date...不过迁到Mysql的话,mysql并没有提供类似函数,所以要怎么实现?下面给出解决方法: null值排在最后,用Mysql的IF和ISNULL函数。.../u014427391/article/details/87297068 (4) 条件函数 条件函数比如case…when在mysql、Oracle都是有的,除了case…when这最基本之外,Oracle...(5) 列转行函数 Oracle列转行函数可以用vm_comcat函数,mysql的用concat_ws函数 使用方法: CONCAT_WS(separator,str1,str2,…) eg:...,查询字符串是否在strlist序列里,like查询只是广泛的模糊匹配 (7) 类型转换函数 mysql的类型转换函数为cast(字段 as 类型), mysql支持的类型有 CHAR[(N)] 字符型

    90230

    Mysql学习笔记整理手册

    继上一篇博客《Oracle学习笔记整理手册》之后,我再写一篇Mysql版本的 PS:本博客收录自己工作中遇到学到的一些mysql技能,有时间就更新整理一下 (1) str_to_date oracle有...to_date函数,Mysql的格式是str_to_date(‘2019-02-12 11:34:32’, ‘%Y-%m-%d %H:%i:%s’) (2) 递归查询 oracle实现递归查询的话,就可以使用...不过迁到Mysql的话,mysql并没有提供类似函数,所以要怎么实现?下面给出解决方法: null值排在最后,用Mysql的IF和ISNULL函数。.../developer/article/1398048 (4) 条件函数 条件函数比如case…when在mysql、Oracle都是有的,除了case…when这最基本之外,Oracle有nvl、nvl2...(5) 列转行函数 Oracle列转行函数可以用vm_comcat函数,mysql的用concat_ws函数 使用方法: CONCAT_WS(separator,str1,str2,…) eg:

    1.5K20
    领券