sqlserver 和MySQL的一些函数的区别

相同的表数据在sqlserver和MySQL中使用各自的函数得到相同的结果,如下表

drop table tb;
create table tb(id int, value1 varchar(10), value2 varchar(20));
insert into tb values(1,'aa','11');
insert into tb values(1,'bb','22');
insert into tb values(2,'aaa','111');
insert into tb values(2,'bbb','222');
insert into tb values(2,'ccc','333');

要想查询出如下结果

在sqlserver中需要以下语句查询

复制代码
 1 SELECT
    id,stuff(
        (
            SELECT ',' + VALUE1 FROM tb AS t WHERE t.id = tb.id FOR xml path ('')
        ), 1, 1, ''
    ) as VALUE1,
stuff(
        (
            SELECT ',' + VALUE2 FROM tb AS t WHERE t.id = tb.id FOR xml path ('')
        ), 1, 1, ''
    ) as VALUE2
FROM tb GROUP BY id
复制代码

在MySQL中需要以下代码查询

1 select id, group_concat(value1)value1,group_concat(value2)value2 from tb group by id;  

这里不是说MySQL比sqlserver好用,只是总结相同的数据在两个数据库中使用不同的方法函数得到相同的结果。

例如如下sql

-- 得到两个日期之间相差的月份数,也可以得到相差天数,只需要替换函数中第一个参数,注意各函数参数的取值范围,有兴趣的试下其他的。
1
select DATEDIFF(M,'20160506','20170606');-- sqlserver 2 select TIMESTAMPDIFF(MONTH,'20160506','20170606');-- mysql
-- 第二个参数是否包含第一个参数,如果包含返回1,不包含返回0
1
select charindex('a','abcd');-- sqlserver 2 select LOCATE('a','abcd');-- mysql

还有sqlserver 的SUBSTRING和mysql的SUBSTR

1 create table test2 as select * from test1;-- mysql
2 select * into test2 from test1;-- sqlserver

 

posted @   silentmuh  阅读(764)  评论(0编辑  收藏  举报
编辑推荐:
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
Live2D
欢迎阅读『sqlserver 和MySQL的一些函数的区别』
  1. 1 Walk Thru Fire Vicetone
  2. 2 爱你 王心凌
  3. 3 Inspire Capo Productions - Serenity
  4. 4 Welcome Home Radical Face
  5. 5 粉红色的回忆 李玲玉
Inspire - Capo Productions - Serenity
00:00 / 00:00
An audio error has occurred, player will skip forward in 2 seconds.

纯音乐,请欣赏

点击右上角即可分享
微信分享提示