国产数据库-达梦数据库sql语句中if、case when条件的使用,国产数据库(达梦数据库)case when sql语法和mysql有点不一样的地方,看了你也会
创始人
2025-01-15 19:08:32
0

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

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

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

-- 1. success!!  mysql if 表达式的使用,在where条件中使用if表达式 SELECT 	count(*) FROM 	noti_notification n WHERE 	1 = 1 	AND (n.creator_id = '856187440439296' OR (n.id IN ( 11, 22))) 	AND  		IF(response_type = 1, 			actual_total_user != (SELECT count(*) FROM noti_visit_log WHERE notification_id = n.id), 			actual_total_user != (SELECT count(*) FROM noti_reply WHERE notification_id = n.id) 		) 	AND n.tenant_id = 810192326787072 	AND n.type = 1;    

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

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

  -- 2. success!!  mysql if 表达式的使用,在where条件中使用if表达式,以及在 查询结果中使用if表达式    select if(pi.type_key ='1', 'a', 'b') as type_key, pi.* from BUS_DATA_CENTER.tc_project_info pi;                select if(pi.type_key ='1', 'a', 'b') as type_key, pi.* from BUS_DATA_CENTER.tc_project_info pi where 1=1       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 表达式
 -- 2.1. success!!  mysql case when 表达式的使用 SELECT 	count(*) FROM 	noti_notification n WHERE 	1 = 1 	AND (n.creator_id = '856187440439296' OR (n.id IN ( 11, 22))) 	AND  		CASE WHEN response_type = 1  			THEN actual_total_user != (SELECT count(*) FROM noti_visit_log WHERE notification_id = n.id) 			ELSE actual_total_user != (SELECT count(*) FROM noti_reply WHERE notification_id = n.id ) 		END 	AND n.tenant_id = 810192326787072 	AND n.type = 1;  
2.2. 在where条件查询中使用case when 表达式

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

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

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

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

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

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

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

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

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

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

... ...

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

总结下:

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

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

 

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

成功成功

 

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

 

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

成功

失败

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

 

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

成功成功

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

相关内容

热门资讯

第九分钟辅助!天天爱柳州辅助器... 天天爱柳州辅助器是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加我微...
热门推荐!微信小程序蜀山辅助器... 热门推荐!微信小程序蜀山辅助器免费下载(辅助)外挂辅助开挂插件(有挂秘诀)-哔哩哔哩;最新版2026...
第4分钟普及!奇迹陕西辅助器(... 第4分钟普及!奇迹陕西辅助器(透视)原来真的是有挂脚本(推荐开挂软件);奇迹陕西辅助器免费下载原版,...
第八分钟讲解!越乡游金花辅助,... 第八分钟讲解!越乡游金花辅助,九酷众游辅助,细节方法(有挂实锤)-哔哩哔哩1、下载安装好越乡游金花辅...
透视软件!浙江宝宝游戏辅助工具... 透视软件!浙江宝宝游戏辅助工具(辅助)外挂开挂辅助插件(了解有挂)-哔哩哔哩;是一款可以让一直输的玩...
第5分钟发现!桃乐甘肃麻将下载... 《第5分钟发现!桃乐甘肃麻将下载辅助器(辅助)原来有挂软件(必看开挂工具)》 桃乐甘肃麻将下载辅助器...
第8分钟了解!河洛刚次辅助,温... 第8分钟了解!河洛刚次辅助,温州茶苑辅助软件,详细教程(有挂攻略)-哔哩哔哩;无需打开直接搜索加薇1...
热点讨论!新二号辅助软件下载(... 热点讨论!新二号辅助软件下载(辅助)外挂辅助开挂软件(有挂教程)-哔哩哔哩;是一款可以让一直输的玩家...
8分钟解说!网易亲友圈辅助(开... 8分钟解说!网易亲友圈辅助(开挂)原来有挂平台(必看开挂安装);小薇(透视辅助)致您一封信;亲爱网易...
第5分钟开挂!如何在哈灵上辅助... 第5分钟开挂!如何在哈灵上辅助,决战卡五星辅助看牌器,解说技巧(有挂方略)-哔哩哔哩 了解更多开挂安...