1、自增长列的插入:
SQLServer中可以不为自动增长列插入值,
MySQL中需要为自动增长列插入值。

2、获取当前时间函数
SQLServer写法:getdate()
MySQL写法:now()

3、从数据库定位到表。
Sqlserver写法:库名.dbo.表名 ;或者:库名..表名
 (注:中间使用两个点)
select password from Info.dbo.users where userName='boss'
或者
select password from Info..users where userName='boss'
mysql写法:库名.表名
select password from Info.users where userName='boss'

4、判断是否存在某个数据库,若存在,则删除
Sqlserver写法:
IF DB_ID('users') IS NOT NULL
DROP DATABASE users
Mysql写法:
Drop DATABASEif exists
 users

拓展:若sqlserver数据库正在使用中,删除之前,先要把数据库变成“单一用户”,再删除
ALTER DATABASE users SET SINGLE_USER with ROLLBACK IMMEDIATE IF DB_ID('users') IS NOT NULL DROP DATABASE users

另附:判断某数据库中是否存在某张表,若存在,则删除
Sqlserver写法:
if exists(select * from sysobjects where name ='Users_test')
drop table Users_test
Mysql写法:
DROP TABLE IF EXISTS
 Users_test

5、主键存在,则更新,不存在,则插入
Mysql写法:   
INSERT into users (userID,userName,password) VALUES (1,’jmj’,’123’) ON DUPLICATE KEY UPDATE  userName
 ='jmj', password =123

Sqlserver没有mysql这样的关键字,只能组合sql语句来实现操作:
if not exists (select userID from users where userID= 1)insert into users (userID,userName,password) values(1,’jmj’,’123’) else update users set userName
 = ’jmj’, password=’123’ where userID = 1

(关于On duplicate key update的两篇文章,推荐给大家!
可遇不可求的Question之SQLServer的INSERT ON DUPLICATE KEY UPDATE语法篇
MySql避免重复插入记录方法(ignore,Replace,ON DUPLICATE KEY UPDATE)

6、符号的使用
mysql对参数可以使用单引号,也可以使用双引号,对字段名和表明可以使用反引号。
sqlserver只能使用单引号,且不能使用反引号。
Mysql写法:
Select
`password` from Users where userName='boss' or username=”jmj”
Sqlserver写法:
Select
password from Users where userName='boss' or username=’jmj’
 
7、取出查询结果中的第一条数据或者前几条记录(取前几条记录只需要修改对应的数字即可),分页也是使用这个关键字:
SQLServer写法:
select top 1 password from users where userName='boss' 
MySQL写法:
select password from users where userName='111'limit 0,1
 它可以规定范围 limit a,b——范围a-b
8、查询所有库
SQLServer写法:
select * from [master]..[SysDatabases];
MySQL写法:
SHOW DATABASES;

9、查询指定库中的所有表
SQLServer写法:
select *from 库名.dbo.[SysObjects]
 where[type]='U';
(注:若想知道[type]='U'代表什么意思,请点击http://blog.csdn.net/winddai/article/details/5815138)
MySQL写法:
SHOW TABLES

10、某些关键词的使用
10.1截取字符串
SQLServer只能使用SUBSTRING关键词来截取字符串。
MySQL可以使用SUBSTRING和SUBSTR截取字符串
10.2取得字符串的长度

SQLServer只能使用Len关键词取得字符串的长度。
MySQL可以使用Length取得字符串的长度。

11、相同点

delete,select,insert,drop(删除数据库:drop database 库名),update,create(创建数据库:create
 database 库名)语句一样。
---------------------

https://blog.csdn.net/shiqijiamengjie/article/details/50396793

MySQL和Sql Server的sql语句区别的更多相关文章

  1. SQL Server经典sql语句大全(转)

    一.基础1.说明:创建数据库CREATE DATABASE database-name2.说明:删除数据库drop database dbname3.说明:备份sql server--- 创建 备份数 ...

  2. Oracle与SQL Server等数据库的区别

    Oracle与SQL Server等数据库的区别 在Oracle中提倡使用一个连接 Oracle处理多个并发语句使用一个连接,大大提升系统能支持的并发量 Oracle运行在32为单进程平台上SGA和P ...

  3. PowerDesigner反向数据库时遇到[Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句。SQLSTATE = 37错误解决方法

    逆向工程中,有时会出现如下错误 ... [Microsoft][ODBC SQL Server Driver][SQL Server]无法预定义语句 SQLSTATE = 37000 解决方案: 1. ...

  4. 【转】SQL Server与Oracle的区别

    转自:http://soft.chinabyte.com/database/255/12258255.shtml SQL Server与Oracle的区别 2012-02-10 00:00 中国IT实 ...

  5. 【转载】SQL Server - 使用 Merge 语句实现表数据之间的对比同步

    原文地址:SQL Server - 使用 Merge 语句实现表数据之间的对比同步 表数据之间的同步有很多种实现方式,比如删除然后重新 INSERT,或者写一些其它的分支条件判断再加以 INSERT ...

  6. Sql server的Merge语句,源表中如果有重复数据会导致执行报错

    用过sql server的Merge语句的开发人员都应该很清楚Merge用来做表数据的插入/更新是非常方便的,但是其中有一个问题值得关注,那就是Merge语句中的源表中不能出现重复的数据,我们举例来说 ...

  7. SQL Server参数化SQL语句中的like和in查询的语法(C#)

    sql语句进行 like和in 参数化,按照正常的方式是无法实现的 我们一般的思维是: Like参数化查询:string sqlstmt = "select * from users whe ...

  8. Linux下用freetds执行SQL Server的sql语句和存储过程

    Linux下用freetds执行SQL Server的sql语句和存储过程 http://www.linuxidc.com/Linux/2012-06/61617.htm freetds相关 http ...

  9. sql server的sql 语句中的列名包含[]时候,把]替换成]]就可以

    sql server的sql 语句中的列名包含[]时候,把]替换成]]就可以eg: create table p.e_LOG_WebServer ( [BSCFlg] int, ), ) ); sel ...

  10. SQL Server查看Sql语句执行的耗时和IO消耗

    原文:SQL Server查看Sql语句执行的耗时和IO消耗 在做系统过程中,经常需要针对某些场景进行性能优化,那么如何判定性能优化的效果呢?肯定需要知道优化之前Sql语句的耗时和优化之后Sql语句的 ...

随机推荐

  1. SpringBoot整合EHcache学习笔记

    为了提高系统的运行效率,引入缓存机制,减少数据库访问和磁盘IO.下面说明一下ehcache和SpringBoot整合配置 前言介绍 EhCache 是一个纯Java的进程内缓存框架,具有快速.精干等特 ...

  2. Nginx安装负载均衡配置 fair check扩展

    前言 本文主要是针对Nginx安装.负载均衡配置,以及fair智能选举.check后端节点检查扩展功能如何扩展,进行讲解说明. fair模块: upstream-fair,“公平的”Nginx 负载均 ...

  3. eclipse中设置项目的编码方式

    1.windows->Preferences...打开"首选项"对话框,左侧导航树,导航到general->Workspace,右侧Text file encoding ...

  4. CentOS-7.x Yum Repo Mirror

    一. 环境 1.1 主机信息 主机 OS Storage 备注 100.64.140.101 centos 7.6 /dev/sdb > 100GB 1.selinux disable; 2.放 ...

  5. [转载]JVM 垃圾回收机制(Garbage Collection)

    相关算法: 引用计数法 引用可达法 尚学堂 参考:http://www.sxt.cn/Java_jQuery_in_action/Principle_and_algorithm_of_garbage_ ...

  6. Fragment 使用总结

    1. 要深刻理解Fragment 的生命周期 2. Fragment.getActivity()并不能保证非空. 3.如果在Fragment中有异步的回调, 特别要注意此时Fragment 是否还at ...

  7. 1094. The Largest Generation (25)-(dfs,树的遍历,统计每层的节点数)

    题目很简单,就是统计一下每层的节点数,输出节点数最多的个数和对应的层数即可. #include <iostream> #include <cstdio> #include &l ...

  8. 2-Fourteenth Scrum Meeting-20151214

    任务安排 成员 今日完成 明日任务 闫昊 用本地数据库记录课程结构和学习进度  修复bug 唐彬 请假(编译……)  编写与服务器交互的代码 史烨轩  请假(编译……)  获取视频url 余帆 请假( ...

  9. 《Linux内核分析》 第四周

    [李行之 原创作品转载请注明出处 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000] <Linux内 ...

  10. POI操作Excel(xls、xlsx)

    阿帕奇官网:http://poi.apache.org/ POI3.17下载:http://poi.apache.org/download.html#POI-3.17 POI操作Excel教程(易百教 ...