转MySQL遇到的语法差异及解决方案
最近公司项目需要从SQL Server转到MySQL, 在转的过程中遇到两者语法之间的一些差异,在网上找了解决方案后,特记录在此。由于解决方案可能有很多种,我只记录了自己使用过的,仅作参考。
1. 拼接字符串
使用
group_concat方法
MSSQL
( SELECT LEFT(dal.DeliveryAreaList,
LEN(dal.DeliveryAreaList) - 1)
FROM ( SELECT ( SELECT CAST(DeliveryArea AS VARCHAR)
+ '|'
FROM Rel_MainCommodityDeliveryArea
WHERE MainCommodityId = a.MainCommodityId
AND DeliveryArea <> 0
AND Disabled = 0
ORDER BY DeliveryArea ASC
FOR
XML PATH('')
) AS DeliveryAreaList
) dal
) AS DeliveryAreasList
MySQL
(select
group_concat(rmcda.DeliveryArea order by rmcda.DeliveryArea desc separator '|')
from Rel_MainCommodityDeliveryArea rmcda
where rmcda.MainCommodityId = a.MainCommodityId and rmcda.DeliveryArea <> 0 and rmcda.Disabled = 0) as DeliveryAreasList
2. MySQL中和update set select语法
MySQL中
update set select无from,需要使用更新多表的语法
MSSQL
update fc
set fc.UseScenarios = (ISNULL(fc.InheritName, '')
+ ISNULL(fmc.MainCommodityName_Postfix, '')
+ '-' + ISNULL(cn.ChannelAlias, '')
+ ISNULL(fc.CommodityName_Postfix, '')),
fc.UseScenariosEn = (ISNULL(fc.CommodityName_Prefix, '')
+ ISNULL(fc.InheritName, '')
+ ISNULL(fmc.MainCommodityName_Postfix,
'')
+ ISNULL(fc.CommodityName_Postfix, '')),
fc.[Rec_ModifyBy] = '{updateUser}',
fc.[Rec_ModifyTime] = now(3)
from Fct_Commodity as fc
inner join Fct_MainCommodity as fmc on fc.MainCommodityId = fmc.MainCommodityId
inner join Dim_Channel as cn on fc.ChannelId = cn.ChannelId
where fc.Disabled = 0
and fmc.Disabled = 0
and fc.InheritName is not null
and fc.InheritName <> ''
and fmc.[MainCommodityCode] in ({codeList})
MySQL
update Fct_Commodity fc, Fct_MainCommodity fmc, Dim_Channel cn
set fc.UseScenarios = (ifnull(fc.InheritName, '')
+ ifnull(fmc.MainCommodityName_Postfix, '')
+ '-' + ifnull(cn.ChannelAlias, '')
+ ifnull(fc.CommodityName_Postfix, '')),
fc.UseScenariosEn = (ifnull(fc.CommodityName_Prefix, '')
+ ifnull(fc.InheritName, '')
+ ifnull(fmc.MainCommodityName_Postfix,
'')
+ ifnull(fc.CommodityName_Postfix, '')),
fc.Rec_ModifyBy = '{updateUser}',
fc.Rec_ModifyTime = now(3)
where
fc.MainCommodityId = fmc.MainCommodityId
and fc.ChannelId = cn.ChannelId
and fc.Disabled = 0
and fmc.Disabled = 0
and fc.InheritName is not null
and fc.InheritName <> ''
and fmc.MainCommodityCode in ({codeList})
3. MySQL子查询中使用limit
MySQL中子某些子查询不允许
limit, 如需要使用,需要用select再包一层
MSSQL
SELECT UnitId,UnitName
FROM Dim_Unit
WHERE UnitName IN (
SELECT TOP 6 fmc.Unit
FROM Fct_MainCommodity fmc INNER JOIN Dim_Unit du ON fmc.Unit=du.UnitName
WHERE fmc.Disabled=0 AND du.Disabled=0
GROUP BY fmc.Unit
ORDER BY COUNT(fmc.Unit) DESC
)
MySQL
select
UnitId,
UnitName
from Dim_Unit
where UnitName in (
select temp.Unit
from
(select fmc.Unit
from Fct_MainCommodity fmc inner join Dim_Unit du on fmc.Unit = du.UnitName
where fmc.Disabled = 0 and du.Disabled = 0
group by fmc.Unit
order by COUNT(fmc.Unit) desc
limit 6) temp)
4. Parameter '@Rec_CreateTime' must be defined
参数化拼sql, 不要用
now(3), 直接在代码里面获取当前时间
MSSQL
public static Hashtable CreateByCheck(Hashtable htValue,string userID)
{
if (!htValue.Contains("Rec_CreateTime"))
{
htValue.Add("Rec_CreateTime", "now(3)");
}
if (!htValue.Contains("Rec_CreateBy"))
{
htValue.Add("Rec_CreateBy", HttpContext.Current == null ? "admin" : userID);
}
return htValue;
}
MySQL
public static Hashtable CreateByCheck(Hashtable htValue,string userID)
{
if (!htValue.Contains("Rec_CreateTime"))
{
htValue.Add("Rec_CreateTime", DateTime.Now);
}
if (!htValue.Contains("Rec_CreateBy"))
{
htValue.Add("Rec_CreateBy", HttpContext.Current == null ? "admin" : userID);
}
return htValue;
}
5 拼接字符串+字符集
(MainCommodityName + ifnull(MainCommodityName_Postfix, ''))拼接得不到想要的结果[HY000][1267] Illegal mix of collations (utf8_bin,NONE) and (utf8_general_ci,COERCIBLE) for operation '=': 需要加
collate utf8_general_ci统一字符集
MSSQL
select MainCommodityName
from Fct_MainCommodity
where (MainCommodityName + ifnull(MainCommodityName_Postfix, '')) = '附件上传原料A进A出1003' and Disabled = 0 and
ifnull(IsAutoHide, 0) != 1 and MainCommodityId != '27135417-a42b-453f-a1cc-1617d6fc471e';
MySQL
select MainCommodityName
from Fct_MainCommodity
where CONCAT(MainCommodityName, cast(ifnull(MainCommodityName_Postfix, '') as nchar(50))) collate utf8_general_ci =
'附件上传原料A进A出1003'
and Disabled = 0 and ifnull(IsAutoHide, 0) != 1 and MainCommodityId != '27135417-a42b-453f-a1cc-1617d6fc471e';
6 SQL中使用正则
MSSQL中LIKE后面可以使用正则,但是MYSQL需要使用REGEXP
- MSSQL
select isnull( MAX(BrandCode),99999)+1 as BrandCode from Fct_Brand
where BrandCode like '[0-9][0-9][0-9][0-9][0-9][0-9]'
- MySQL
select ifnull( MAX(BrandCode),99999)+1 as BrandCode from Fct_Brand
where BrandCode regexp '[0-9][0-9][0-9][0-9][0-9][0-9]'
转MySQL遇到的语法差异及解决方案的更多相关文章
- SQLServer、MySQL、Oracle语法差异小集锦
一.差异集锦 在建表的时候,只有自增的语法不同. 下面给出3种数据库通用的建表与初始化测试语句: CREATE TABLE Country( Id int PRIMARY KEY, Name ) ); ...
- mybatis中mysql和oracle的差异
1.applicationContext.xml中的配置差异: 在applicationContext.xml的数据源dataSource的配置中,mysql数据库需要心跳包的配置,而oracle中不 ...
- Kotlin VS Java:基本语法差异
Kotlin比Java更年轻,但它是一个非常有前途的编程语言,它的社区不断增长. 每个人都在谈论它,并说它很酷. 但为什么这么特别? 我们准备了一系列文章,分享我们在Kotlin开发Android应用 ...
- 【优化】MySQL千万级大表优化解决方案
问题概述 使用阿里云rds for MySQL数据库(就是MySQL5.6版本),有个用户上网记录表6个月的数据量近2000万,保留最近一年的数据量达到4000万,查询速度极慢,日常卡死.严重影响业务 ...
- MySQL创建索引语法
1.介绍: 所有mysql索引列类型都可以被索引,对来相关类使用索引可以提高select查询性能,根据mysql索引数,可以是最大索引与最小索引,每种存储引擎对每个表的至少支持16的索引.总索引长度为 ...
- MYSQL整理的语法
MYSQL整理的语法 http://www.cnblogs.com/suoning/p/5744849.html
- Sqlite基础及其与SQLServer语法差异
1 TOP 这是一个大家经常问到的问题,例如在SQLSERVER中可以使用如下语句来取得记录集中的前十条记录: SELECT TOP 10 * FROM [index] ORDER BY indexi ...
- MySQL的一些语法总结
初学MySQL,今天遇到了一个问题,然后汇总了一下MySQL的一些语法 1. date和datetime类型是不同的 date只记录日期(包括年月日),datetime记录日期和时间(包括年月日时分秒 ...
- sql点滴41—mysql常见sql语法
原文:sql点滴41-mysql常见sql语法 ALTER TABLE:添加,修改,删除表的列,约束等表的定义. 查看列:desc 表名; 修改表名:alter table t_book rename ...
随机推荐
- [Robot Framework] 通过RemoteWhiteLibrary启动程序并登录初尝试
启动remote whitelibrary之后,在robot framework中配置好library,就可以调用whitelibrary的关键字了 启动APP White.LAUNCHAPP ...
- Python编程笔记(第三篇)【补充】三元运算、文件处理、检测文件编码、递归、斐波那契数列、名称空间、作用域、生成器
一.三元运算 三元运算又称三目运算,是对简单的条件语句的简写,如: 简单条件处理: if 条件成立: val = 1 else: val = 2 改成三元运算 val = 1 if 条件成立 else ...
- python正则表达式获取两段标记内的字符串
比如获取绿色字符串 ModelData.PayTableData =[{"}, {"}, {"}]; ModelData.PayTableData1 =[{"} ...
- Python中sys和os模块的区别
sys: This module provides access to some variables used or maintained by the interpreter and to func ...
- http://itellyou.cn/
http://itellyou.cn/ 这里提供了微软MSDN上所有能下载的软件. 下载完记得检验. 这是更详细的介绍:http://wenku.baidu.com/link?url=_dZ0mYvl ...
- java:static详解
1.static修饰的变量习惯称为静态变量,static修饰的方法称为静态方法,static修饰的代码块叫做静态代码块. 1)static变量 static变量也称作静态变量,静态变量和非静态变量的区 ...
- Jvm(jdk8)源码分析1-java命令启动流程详解
JDK8加载源码分析 1.概述 现在大多数互联网公司都是使用java技术体系搭建自己的系统,所以对java开发工程师以及java系统架构师的需求非常的多,虽然普遍的要求都是需要熟悉各种java开发框架 ...
- 使用Ant发布web应用到tomcat
使用Ant发布web应用到tomcat 来自:http://blog.csdn.net/hbcui1984/article/details/1954537 今天在公司用ant写了个部署web应用的脚本 ...
- mongodb知识积累
1: 安装mongodb https://www.cnblogs.com/zhangdaicong/p/7492494.html 2:配置文件 vi /etc/mongodb.conf https:/ ...
- springboot aop+@interface实现日志记录
一.基本概念 1.自定义注解 自定义注解我们必须了解四个元注解,什么是元注解?元注解指作用于注解之上的元数据或者元信息,简单通俗的讲,元注解就是注解的注解 . Documented与Inherited ...