最近公司项目需要从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 selectfrom,需要使用更新多表的语法

  • 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 拼接字符串+字符集

  1. (MainCommodityName + ifnull(MainCommodityName_Postfix, ''))拼接得不到想要的结果

  2. [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遇到的语法差异及解决方案的更多相关文章

  1. SQLServer、MySQL、Oracle语法差异小集锦

    一.差异集锦 在建表的时候,只有自增的语法不同. 下面给出3种数据库通用的建表与初始化测试语句: CREATE TABLE Country( Id int PRIMARY KEY, Name ) ); ...

  2. mybatis中mysql和oracle的差异

    1.applicationContext.xml中的配置差异: 在applicationContext.xml的数据源dataSource的配置中,mysql数据库需要心跳包的配置,而oracle中不 ...

  3. Kotlin VS Java:基本语法差异

    Kotlin比Java更年轻,但它是一个非常有前途的编程语言,它的社区不断增长. 每个人都在谈论它,并说它很酷. 但为什么这么特别? 我们准备了一系列文章,分享我们在Kotlin开发Android应用 ...

  4. 【优化】MySQL千万级大表优化解决方案

    问题概述 使用阿里云rds for MySQL数据库(就是MySQL5.6版本),有个用户上网记录表6个月的数据量近2000万,保留最近一年的数据量达到4000万,查询速度极慢,日常卡死.严重影响业务 ...

  5. MySQL创建索引语法

    1.介绍: 所有mysql索引列类型都可以被索引,对来相关类使用索引可以提高select查询性能,根据mysql索引数,可以是最大索引与最小索引,每种存储引擎对每个表的至少支持16的索引.总索引长度为 ...

  6. MYSQL整理的语法

    MYSQL整理的语法 http://www.cnblogs.com/suoning/p/5744849.html

  7. Sqlite基础及其与SQLServer语法差异

    1 TOP 这是一个大家经常问到的问题,例如在SQLSERVER中可以使用如下语句来取得记录集中的前十条记录: SELECT TOP 10 * FROM [index] ORDER BY indexi ...

  8. MySQL的一些语法总结

    初学MySQL,今天遇到了一个问题,然后汇总了一下MySQL的一些语法 1. date和datetime类型是不同的 date只记录日期(包括年月日),datetime记录日期和时间(包括年月日时分秒 ...

  9. sql点滴41—mysql常见sql语法

    原文:sql点滴41-mysql常见sql语法 ALTER TABLE:添加,修改,删除表的列,约束等表的定义. 查看列:desc 表名; 修改表名:alter table t_book rename ...

随机推荐

  1. nginx 动静分离 以及 负载均衡配置

    测试环境 系统版本:win7 Nginx版本:nginx-1.8.1 Tomcat版本:tomcat-6.0.14 1动静分离配置 Nginx.conf 中 server中 server { list ...

  2. js实现环形菜单效果

    点击中间的圆点,会弹出环形菜单,效果图: 代码: <!DOCTYPE html> <html> <head> <meta charset="UTF- ...

  3. android Run模式也会出现"Waiting for debugger"的解决方法

    android Run模式也会出现"Waiting for debugger"的解决方法 出现“waiting for debugger”窗口是在debug模式下运行出现的.但是, ...

  4. 三大框架中各种xml的存放位置

      web.xml中classpath:和classpath*:  有什么区别? classpath:只会到你的class路径中查找找文件; classpath*:不仅包含class路径,还包括jar ...

  5. SpringBoot中文乱码解决方案

    转载:https://blog.csdn.net/wangshuang1631/article/details/70753801 方法一,修改application.properties文件 增加如下 ...

  6. mybatis学习六 parameterType 属性

    1. 在 XXXMapper.xml 中<select><delete>等标签的 parameterType 可以控制参数类型2. SqlSession 的 selectLis ...

  7. sqlserver中如何将mdf文件还原到数据库

  8. Linux关机操作

    正确的关机流程为:sync > shutdown > reboot > halt 关机指令为:shutdown ,你可以man shutdown 来看一下帮助文档. 例如你可以运行如 ...

  9. WEB应用支持RESTFUL风格方法

    REST概念 Restful就是一个资源定位及资源操作的风格.不是标准也不是协议,只是一种风格.基于这个风格设计的软件可以更简洁,更有层次,更易于实现缓存等机制. REST风格 资源:互联网所有的事物 ...

  10. s7-200 PID控位

    只有加热模块,没有风扇,所以温度上冲达到5度左右 TITLE=程序注释 Network // 网络标题 // 初始化 LD SM0. LPS MOVW , VW500 MOVW , VW502 MOV ...