当前位置:   article > 正文

国产数据库-达梦数据库sql语句中if、case when条件的使用,国产数据库(达梦数据库)case when sql语法和mysql有点不一样的地方,看了你也会_达梦 case when

达梦 case when

1. if表达式的使用,在mysql中使用if 表达式

1.1  在where条件中使用if表达式

if (字段 = 1, {条件为true执行的结果}, {添加为false执行的结果})

  1. -- 1. success!! mysql if 表达式的使用,在where条件中使用if表达式
  2. SELECT
  3. count(*)
  4. FROM
  5. noti_notification n
  6. WHERE
  7. 1 = 1
  8. AND (n.creator_id = '856187440439296' OR (n.id IN ( 11, 22)))
  9. AND
  10. IF(response_type = 1,
  11. actual_total_user != (SELECT count(*) FROM noti_visit_log WHERE notification_id = n.id),
  12. actual_total_user != (SELECT count(*) FROM noti_reply WHERE notification_id = n.id)
  13. )
  14. AND n.tenant_id = 810192326787072
  15. AND n.type = 1;

1.2. 在where条件中使用if表达式,以及在查询结果中使用if表达式 

if (字段 = 1, {条件为true执行的结果}, {添加为false执行的结果})

  1. -- 2. success!! mysql if 表达式的使用,在where条件中使用if表达式,以及在 查询结果中使用if表达式
  2. select if(pi.type_key ='1', 'a', 'b') as type_key, pi.* from BUS_DATA_CENTER.tc_project_info pi;
  3. select if(pi.type_key ='1', 'a', 'b') as type_key, pi.* from BUS_DATA_CENTER.tc_project_info pi where 1=1
  4. and if (pi.TYPE_KEY = '1', pi.JURISDICTION_KEY = '1', pi.JURISDICTION_KEY = '0');

上面的两种 if表达式的使用在mysql数据库,以及国产达梦数据库都是能正常执行的,没有报错。

这也不是我们今天说的关键点。继续往下看。

2. case表达式的使用,在mysql中使用case when 表达式

2.1. 在where条件查询中使用case when 表达式
  1. -- 2.1. success!! mysql case when 表达式的使用
  2. SELECT
  3. count(*)
  4. FROM
  5. noti_notification n
  6. WHERE
  7. 1 = 1
  8. AND (n.creator_id = '856187440439296' OR (n.id IN ( 11, 22)))
  9. AND
  10. CASE WHEN response_type = 1
  11. THEN actual_total_user != (SELECT count(*) FROM noti_visit_log WHERE notification_id = n.id)
  12. ELSE actual_total_user != (SELECT count(*) FROM noti_reply WHERE notification_id = n.id )
  13. END
  14. AND n.tenant_id = 810192326787072
  15. AND n.type = 1;
2.2. 在where条件查询中使用case when 表达式

2.2 和上面的 2.1 还是有些区别的。请注意观察  actual_total_user  != 是写在外面。

  1. -- 2.2. success!! mysql case when 表达式的使用
  2. SELECT
  3. count(*)
  4. FROM
  5. noti_notification n
  6. WHERE
  7. 1 = 1
  8. AND (n.creator_id = '856187440439296' OR (n.id IN ( 11, 22)))
  9. AND actual_total_user != (
  10. select CASE WHEN response_type = 1 THEN ( SELECT count(*) FROM noti_visit_log WHERE notification_id = n.id)
  11. ELSE (SELECT count(*) FROM noti_reply WHERE notification_id = n.id) END
  12. )
  13. AND n.tenant_id = 810192326787072
  14. AND n.type = 1;

上面的两种 case when 表达式的使用在mysql数据库 都成功了。

但是问题就出现在  国产达梦数据库 上执行就有问题了,2.1 是成功的, 2.2 失败了。

我们直接看2.2 执行失败的错误提示信息:

刚开始,我以为是 != 使用报错导致,后来就改成  <> 替换 !=, 但是还是发现有报错。

看来还是这种case when的写法 国产数据库不支持吧。

问题来了,那怎么修改呢 ?!

问题来了,那怎么修改呢 ?!

问题来了,那怎么修改呢 ?!

... ...

那就换一种写法,改用上面的 2.1的写法就可以了。

总结下:

在国产达梦数据库中,使用下面的 case when语句的时候出现报错的问题。sql语法不支持的问题。 参看下表的不同写法:

sql语句 mysql数据库国产-达梦数据库

 

  1. select * from DCM_DB.noti_notification n
  2. where 1=1
  3. and IF(response_type = 2,
  4. n.actual_total_user = (SELECT count(*) FROM DCM_DB.noti_visit_log WHERE notification_id = n.id),
  5. n.actual_total_user = (SELECT count(*) FROM DCM_DB.noti_reply WHERE notification_id = n.id)
  6. )
  7. and 2=2;

成功成功

 

  1. select * from DCM_DB.noti_notification n
  2. where 1=1
  3. and
  4. case
  5. when n.response_type = 2 then actual_total_user = (SELECT count(*) FROM DCM_DB.noti_visit_log WHERE notification_id = n.id)
  6. else actual_total_user = (SELECT count(*) FROM DCM_DB.noti_reply WHERE notification_id = n.id)
  7. end
  8. and 2=2;

 

达梦数据库下执行失败的错误提示:

成功

失败

国产数据库下执行识别,改用下面的写法就可以了

 

  1. select * from table_a  t
  2. where 1=1 
  3. and
  4. IF(response_type = 1,
  5. actual_total_user != (SELECT count(*) FROM noti_visit_log WHERE notification_id = n.id),
  6. actual_total_user != (SELECT count(*) FROM noti_reply WHERE notification_id = n.id)
  7. )
  8. and 2=2
  9. ;

成功成功

这就是今天想说的,国产数据库执行sql,sql语法不支持的问题,如何修改。

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop】
推荐阅读
相关标签
  

闽ICP备14008679号