数据库大师成长日记:SQL Server和MySQL常用SQL区别

栏目: 数据库 · 发布时间: 7年前

内容简介:SQLServer和MySQL都是大家常用的数据库,她们基本兼容SQL-92标准,但语法风格还是有一些不同,下面列举一部分两者常用SQL片段的差异,权当抛砖引云,其实两者之间的细微差异多着呢。使用单行GO分号;

SQLServer和 MySQL 都是大家常用的数据库,她们基本兼容SQL-92标准,但语法风格还是有一些不同,下面列举一部分两者常用 SQL 片段的差异,权当抛砖引云,其实两者之间的细微差异多着呢。

数据库大师成长日记:SQL Server和MySQL常用SQL区别

查看表结构的方式

SQLServer方式:

-- 查看系统内所有数据库  
SELECT  name, database_id, create_date  FROM sys.databases ;  
-- 查询数据库内所有表  
select *  from sysobjects  where xtype= 'U' ;  
-- 显示表结构  
sp_help/sp_columns 表名;  

MySQL方式:

-- 查看系统内所有数据库  
show databases;  
-- 查询数据库内所有表  
show tables;  
-- 显示表结构desc 表名;  

语句结束符号

SQLServer的结束符号:

使用单行GO

分号;

什么都不写

MySQL的结束符号:

似乎一直都是用分号;。

返回前几条记录

SQL Server的写法是:

select top n条 from 表;  
select top n percent from 表; 

MySQL的写法是:

select * from 表 limit n; 

获取当前的日期时间

SQL Server的写法是:

getdate(); 

MySQL的写法是:

  1. now(); 

循环支持

以1到100求和为例,我们看看两者实现的不同方式

SQL Server只有一个while循环,语法如下:

DECLARE @I  INT = 1;  
DECLARE @K  INT = 0;  
WHILE @IBEGIN SET @K = @K + @I;  
SET @I = @I + 1;  
ENDSELECT @K;  

MySQL支持好几种,先看看While循环:

DECLARE I,K INTDEFAULT 0 ;  
WHILE I SET K=I + K;  
SET I=I + 1;  
END WHILE;  
SELECT K;  

再看看MySQL的REPEAT UNTIL 循环循环:

DECLARE I,K INTDEFAULT 0 ;  
REPEATSET K=I + K;  
SET I=I + 1;  
NTIL I>100END REPEAT;  
SELECT K;  

再看看MySQL的LOOP循环

DECLARE I,K INTDEFAULT 0 ;  
LABEL: LOOPSET K=I + K;  
SET I=I + 1;  
IF I>100 THENLEAVE LABEL;  
END IF;  
END LOOP;  
SELECT K;  

细微区别太多,这里就不一一列举了。


以上所述就是小编给大家介绍的《数据库大师成长日记:SQL Server和MySQL常用SQL区别》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

数据库索引设计与优化

数据库索引设计与优化

【美】Tapio Lahdenmaki、【美】Michael Leach / 曹怡倩、赵建伟 / 电子工业出版社 / 2015-6 / 79.00元

《数据库索引设计与优化》提供了一种简单、高效、通用的关系型数据库索引设计方法。作者通过系统的讲解及大量的案例清晰地阐释了关系型数据库的访问路径选择原理,以及表和索引的扫描方式,详尽地讲解了如何快速地估算SQL 运行的CPU 时间及执行时间,帮助读者从原理上理解SQL、表及索引结构、访问方式等对关系型数据库造成的影响,并能够运用量化的方法进行判断和优化,指导关系型数据库的索引设计。 《数据库索......一起来看看 《数据库索引设计与优化》 这本书的介绍吧!

URL 编码/解码
URL 编码/解码

URL 编码/解码

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

正则表达式在线测试
正则表达式在线测试

正则表达式在线测试