mysql和sql server有什么区别

38次阅读
没有评论

共计 15536 个字符,预计需要花费 39 分钟才能阅读完成。

自动写代码机器人,免费开通

这篇文章给大家分享的是有关 mysql 和 sql server 有什么区别的内容。丸趣 TV 小编觉得挺实用的,因此分享给大家做个参考。一起跟随丸趣 TV 小编过来看看吧。

区别:1、mysql 支持 enum 和 set 类型,sql server 不支持;2、mysql 的递增语句是“AUTO_INCREMENT”,而 sql server 是“identity(1,1)”;3、sql server 不支持 limit 语句。

区别一

mysql 支持 enum, 和 set 类型,sql server 不支持

mysql 不支持 nchar,nvarchar,ntext 类型

mysql 的递增语句是 AUTO_INCREMENT,而 sql server 是 identity(1,1)

sql server 默认到处表创建语句的默认值表示是((0)), 而在 mysql 里面是不允许带两括号的

mysql 需要为表指定存储类型

sql server 识别符是 [],[type] 表示他区别于关键字,但是 mysql 却是 `,也就是按键 1 左边的那个符号

sql server 支持 getdate()方法获取当前时间日期,但是 mysql 里面可以分日期类型和时间类型,获取当前日期是 cur_date(),当前完整时间是 now()函数

mysql 支持 insert into table1 set t1 =‘’, t2 =‘’, 但是 sql server 不支持这样写

mysql 支持 insert into tabl1 values (1,1), (1,1), (1,1), (1,1), (1,1), (1,1), (1,1)

sql server 不支持 limit 语句,是非常遗憾的,只能用 top 取代 limt 0,N,row_number() over()函数取代 limit N,M

mysql 在创建表时要为每个表指定一个存储引擎类型,而 sql server 只支持一种存储引擎

mysql 不支持默认值为当前时间的 datetime 类型(mssql 很容易做到),在 mysql 里面是用 timestamp 类型

sql server 里面检查是否有这个表再删除,需要这样:

if exists (select * from dbo.sysobjects where id = object_id(N’uc_newpm’) and OBJECTPROPERTY(id, N’IsUserTable’) = 1)

但是在 mysql 里面只需要 DROP TABLE IF EXISTS cdb_forums;

mysql 支持无符号型的整数,那么比不支持无符号型的 mssql 就能多出一倍的最大数存储

mysql 不支持在 mssql 里面使用非常方便的 varchar(max)类型,这个类型在 mssql 里面既可做一般数据存储,也可以做 blob 数据存储

mysql 创建非聚集索引只需要在创建表的时候指定为 key 就行,比如:KEY displayorder (fid,displayorder) 在 mssql 里面必须要:create unique nonclustered index index_uc_protectedmembers_username_appid on dbo.uc_protectedmembers

(username asc,appid asc)

mysql text 字段类型不允许有默认值

mysql 的一个表的总共字段长度不超过 65XXX。

一个很表面的区别就是 mysql 的安装特别简单,而且文件大小才 110M(非安装版),相比微软这个庞然大物,安装进度来说简直就是…

mysql 的管理工具有几个比较好的,mysql_front, 和官方那个套件,不过都没有 SSMS 的使用方便,这是 mysql 很大的一个缺点。

mysql 的存储过程只是出现在最新的版本中,稳定性和性能可能不如 mssql。
同样的负载压力,mysql 要消耗更少的 CPU 和内存,mssql 的确是很耗资源。

php 连接 mysql 和 mssql 的方式都差不多,只需要将函数的 mysql 替换成 mssql 即可。

mysql 支持 date,time,year 类型,mssql 到 2008 才支持 date 和 time。

区别二

一、数据定义

数据库操作基本命令

Mysql:

create database name; 创建数据库

use databasename; 选择数据库

drop database name 直接删除数据库,不提醒 –

CREATE TABLE – 创建一个数据库表

2.1 PRIMARY KEY 约束(主键)区别解析:

Mysql: 
2.1.1  创建 primary key
 CREATE TABLE Persons
 Id_P int NOT NULL,
 LastName varchar(255) NOT NULL,
 FirstName varchar(255),
 Address varchar(255),
 City varchar(255),
 PRIMARY KEY (Id_P) // 声明主健写在最后
 SqlServer:CREATE TABLE Persons
 Id_P int NOT NULL PRIMARY KEY, // 声明主健   紧跟列后
 LastName varchar(255) NOT NULL,
 FirstName varchar(255),
 Address varchar(255),
 City varchar(255)
 但是如果表存在,之后给表加主健时:Mysql  和 SqlServer
 ALTER TABLE Persons ADD PRIMARY KEY (Id_P)
2.1.2 撤销  PRIMARY KEY  约束
 MySQL:
 ALTER TABLE Persons DROP PRIMARY KEY
 SQL Server
 ALTER TABLE Persons DROP CONSTRAINT pk_PersonID
2.1.3  创建外健约束
 MySQL:
 CREATE TABLE Orders
 O_Id int NOT NULL,
 OrderNo int NOT NULL,
 Id_P int,
 PRIMARY KEY (O_Id),
 FOREIGN KEY (Id_P) REFERENCES Persons(Id_P) // 写在最后
 )
SQL Server :CREATE TABLE Orders
 O_Id int NOT NULL PRIMARY KEY,
 OrderNo int NOT NULL,
 Id_P int FOREIGN KEY REFERENCES Persons(Id_P) // 顺序不同
 如果在   Orders   表已存在的情况下为   Id_P   列创建  FOREIGN KEY  约束,请使用下面的  SQL:MySQL / SQL Server 
 ALTER TABLE Orders ADD FOREIGN KEY (Id_P) REFERENCES Persons(Id_P)
2.1.4  撤销外健约束
 MySQL:
 ALTER TABLE Orders DROP FOREIGN KEY f k_PerOrders
 SQL Server 
 ALTER TABLE Orders DROP CONSTRAINT fk_PerOrders

2.2 UNIQUE 约束(唯一的,独一无二的)区别解析

UNIQUE 约束唯一标识数据库表中的每条记录。

UNIQUE 和 PRIMARY KEY 约束均为列或列集合提供了唯一性的保证。

PRIMARY KEY 拥有自动定义的 UNIQUE 约束。

请注意,每个表可以有多个 UNIQUE 约束,但是每个表只能有一个 PRIMARY KEY 约束。

2.2.1 创建 UNIQUE 约束

MySQL:

CREATE TABLE Persons
(
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
UNIQUE (Id_P) // 写在最后
)

SQL Server
CREATE TABLE Persons
(
Id_P int NOT NULL UNIQUE, // 紧跟列后
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
)

2.2.2 撤销 UNIQUE 约束

MySQL:

ALTER TABLE Persons DROP INDEX uc_PersonID

SQL Server

ALTER TABLE Persons DROP CONSTRAINT uc_PersonID

2.3 CHECK 约束

CHECK 约束用于限制列中的值的范围。

如果对单个列定义 CHECK 约束,那么该列只允许特定的值。

如果对一个表定义 CHECK 约束,那么此约束会在特定的列中对值进行限制。

2.3.1 创建 CHECK 约束

下面的  SQL  在   Persons   表创建时为   Id_P   列创建  CHECK  约束。CHECK  约束规定   Id_P   列必须只包含大于  0  的整数。My SQL:
CREATE TABLE Persons
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CHECK (Id_P 0) // 写在最后
)
SQL Server 
CREATE TABLE Persons
Id_P int NOT NULL CHECK (Id_P 0), // 紧跟列后
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
)

如果需要命名 CHECK 约束,以及为多个列定义 CHECK 约束,请使用下面的 SQL 语法:

MySQL / SQL Server:
CREATE TABLE Persons
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
CONSTRAINT chk_Person CHECK (Id_P 0 AND City= Sandnes) // 多个条件
)

如果在表已存在的情况下为“Id_P”列创建 CHECK 约束,请使用下面的 SQL:

MySQL / SQL Server:
ALTER TABLE Persons ADD CHECK (Id_P 0)

2.3.2 撤销 CHECK 约束

Sqlserver:
ALTER TABLE Persons DROP CONSTRAINT chk_Person
Mysql 我没有找到怎么删除。

2.4 DEFAULT 约束(系统默认值)

DEFAULT 约束用于向列中插入默认值。

如果没有规定其他的值,那么会将默认值添加到所有的新纪录。

2.4.1 创建 DEFAULT 约束

下面的  SQL  在   Persons   表创建时为   City   列创建  DEFAULT  约束:My SQL / SQL Server:
CREATE TABLE Persons
Id_P int NOT NULL,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255) DEFAULT  Sandnes  // 紧跟列后,默认值字符串 Sandnes
)

通过使用类似 GETDATE() 这样的函数,DEFAULT 约束也可以用于插入系统值:

CREATE TABLE Orders
Id_O int NOT NULL,
OrderNo int NOT NULL,
Id_P int,
OrderDate date DEFAULT GETDATE() // 紧跟列后,函数)

如果在表已存在的情况下为“City”列创建 DEFAULT 约束,请使用下面的 SQL:

MySQL:
ALTER TABLE Persons ALTER City SET DEFAULT  SANDNES 
SQL Server:
ALTER TABLE Persons ALTER COLUMN City SET DEFAULT  SANDNES

2.4 .2 撤消 DEFAULT 约束

MySQL:
ALTER TABLE Persons ALTER City DROP DEFAULT
SQL Server:
ALTER TABLE Persons ALTER COLUMN City DROP DEFAULT

2.5 索引区别

CREATE INDEX 语句

CREATE INDEX 语句用于在表中创建索引。

在不读取整个表的情况下,索引使数据库应用程序可以更快地查找数据。

在表上创建一个简单的索引。允许使用重复的值:

CREATE INDEX index_name ON table_name (column_name) //“column_name”规定需要索引的列。

在表上创建一个唯一的索引。唯一的索引意味着两个行不能拥有相同的索引值。

CREATE UNIQUE INDEX index_name ON table_name (column_name)

Mysql 和 SqlServer 的创建索引都是一致的,但是在删除索引方面却有区别:

SqlServer: DROP INDEX table_name.index_name
Mysql: ALTER TABLE table_name DROP INDEX index_name

2.6 主键自动增加的区别

mySql 的主键自动增加是用 auto_increment 字段,sqlServer 的自动增加则是 identity 字段.

Auto-increment 会在新纪录插入表中时生成一个唯一的数字。

我们通常希望在每次插入新纪录时,自动地创建主键字段的值。

我们可以在表中创建一个 auto-increment 字段。

关于  MySQL  的语法
下列  SQL  语句把   Persons   表中的   P_Id   列定义为  auto-increment  主键:CREATE TABLE Persons
P_Id int NOT NULL AUTO_INCREMENT,
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255),
PRIMARY KEY (P_Id)
MySQL  使用  AUTO_INCREMENT  关键字来执行  auto-increment  任务。默认地,AUTO_INCREMENT  的开始值是  1,每条新纪录递增  1。要让  AUTO_INCREMENT  序列以其他的值起始,请使用下列  SQL  语法:ALTER TABLE Persons AUTO_INCREMENT=100
关于  SQL Server  的语法
下列  SQL  语句把   Persons   表中的   P_Id   列定义为  auto-increment  主键:CREATE TABLE Persons
P_Id int PRIMARY KEY IDENTITY, 或则是写成 P_id int primary key identity (1,1),
LastName varchar(255) NOT NULL,
FirstName varchar(255),
Address varchar(255),
City varchar(255)
MS SQL  使用  IDENTITY  关键字来执行  auto-increment  任务。默认地,IDENTITY  的开始值是  1,每条新纪录递增  1。要规定   P_Id   列以  20  起始且递增  10,请把  identity  改为  IDENTITY(20,10)

2.7 MySQL 支持 enum, 和 set 类型,SQL Server 不支持
2.8 MySQL 不支持 nchar,nvarchar,ntext 类型

二、数据操作

2.1 limit 和 top

SQL SERVER : select top 8 * from table1 
MYSQL: select * from table1 limit 5 或则是  limit 0,5; 
注意,在 MySQL 中的 limit 不能放在子查询内,limit 不同与 top, 它可以规定范围  limit a,b——范围 a -b

2.2 ISNULL()函数

SqlServer:
select * from test where isnull(no,0)=0;
MySQL
MySQL  可以使用  ISNULL()  函数。不过它的工作方式与微软的  ISNULL()  函数有点不同。在  MySQL  中,我们可以使用  IFNULL()  函数,就像这样:mysql  select * from test where ifnull(no,0)=0;
row in set (0.03 sec)

2.3 select 查询

SELECT * FROM tablename

2.4 insert 插入

INSERT INTO table(col1,col2) values(value1,value2);

MySQL 支持 insert into table1 set t1 =‘’, t2=‘’, 但是 MSSQL 不支持这样写

2.5 update 修改

Update tablename set col=”value”;

2.6 delete 删除

Delete from tablename;

三、语法定义

3.1 注释符区别

SqlServer 的注释符为 – 和 /**/

MySql 的注释符为 – 和 /**/ 和 #

3.2 识别符的区别

MS SQL 识别符是 [],[type] 表示他区别于关键字,但是 MySQL 却是 `,也就是按键 1 左边的那个符号

3.3 存储过程的区别(未经验证,从网上找的)

(1) mysql 的存储过程中变量的定义去掉 @;

(2) SQLServer 存储过程的 AS 在 MySql 中需要用 begin …end 替换

(3) Mysql 的 Execute 对应 SqlServer 的 exec;

(注意:必须想下面这样调用)

Set @cnt=’select * from 表名’;

Prepare str from @cnt;

Execute str;

(4) MySql 存储过程调用其他存储过程用 call

Call 函数名(即 SQLServer 的存储过程名)(’参数 1’,’参数 2’,……)

(5) select @a=count() from VW_Action 在 mySql 中修改为:select count() from VW_Action into @a;

(6) MySQL 视图的 FROM 子句不允许存在子查询,因此对于 SQL Server 中 FROM 子句带有子查询的视图,需要手工进行迁移。可通过消除 FROM 子句中的子查询,或将 FROM 子句中的子查询重构为一个新的视图来进行迁移。

(7) )MySql 存储过程中没有 return 函数,在 MySql 中可以用循环和 out 参数代替

 If EXISTS(SELECT * FROM T_Chance WHERE FCustID=CostomerID) return 0(在参数中定义一个 out 变量:out temp varchar(100);) BEGIN
 Loop1:loop
 SELECT count(*) FROM T_Chance WHERE FCustID=CostomerID int @cnt
 If @cnt 0 then
 begin
 set temp=0;
 leave loop1;
 end;
 end if
 end loop loop1;

(8) mysql 的 uuid()对应 sql 的 GUID();

(9) MySql 的 out 对应 SQLServer 的 output, 且 mysql 的 out 要放在变量的前面,SQLServer 的 output 放在变量后面:
MySql out,in,inout 的区别——
MySQL 存储过程“in”参数:跟 C 语言的函数参数的值传递类似,MySQL 存储过程内部可能会修改此参数,但对 in 类型参数的修改,对调用者(caller)来说是不可见的(not visible)。
MySQL 存储过程“out”参数:从存储过程内部传值给调用者。在存储过程内部,该参数初始值为 null,无论调用者是否给存储过程参数设置值。
MySQL 存储过程 inout 参数跟 out 类似,都可以从存储过程内部传值给调用者。不同的是:调用者还可以通过 inout 参数传递值给存储过程。

3.4 字符串连接

SQLServer: Temp=’select * from’+’tablename’+…+…
MySql:Temp=concat(’select * from’,’tablecname’,…,…)

四、函数和数据类型的区别

4.1 Date 函数

MySQL Date 函数

NOW() 返回当前的日期和时间

CURDATE() 返回当前的日期

CURTIME() 返回当前的时间、

DATE() 提取日期或日期 / 时间表达式的日期部分

EXTRACT() 返回日期 / 时间按的单独部分

DATE_ADD() 给日期添加指定的时间间隔

DATE_SUB() 从日期减去指定的时间间隔

DATEDIFF() 返回两个日期之间的天数

DATE_FORMAT() 用不同的格式显示日期 / 时间

SQL Server Date 函数

GETDATE() 返回当前日期和时间

DATEPART() 返回日期 / 时间的单独部分

DATEADD() 在日期中添加或减去指定的时间间隔

DATEDIFF() 返回两个日期之间的时间

CONVERT() 用不同的格式显示日期 / 时间

4.2 Date 数据类型

MySQL  使用下列数据类型在数据库中存储日期或日期 / 时间值:DATE -  格式  YYYY-MM-DD 
DATETIME -  格式: YYYY-MM-DD HH:MM:SS 
TIMESTAMP -  格式: YYYY-MM-DD HH:MM:SS 
YEAR -  格式  YYYY  或  YY
SQL Server  使用下列数据类型在数据库中存储日期或日期 / 时间值:DATE -  格式  YYYY-MM-DD 
DATETIME -  格式: YYYY-MM-DD HH:MM:SS 
SMALLDATETIME -  格式: YYYY-MM-DD HH:MM:SS 
TIMESTAMP -  格式:  唯一的数字

五、性能比较
(1)一个很表面的区别就是 MySQL 的安装特别简单,而且文件大小才 110M(非安装版),相比微软这个庞然大物,安装进度来说简直就是…
(2)MySQL 的管理工具有几个比较好的,MySQL_front, 和官方那个套件,不过都没有 SSMS 的使用方便,这是 MySQL 很大的一个缺点。
(3)MySQL 的存储过程只是出现在最新的版本中,稳定性和性能可能不如 MS SQL。
(4)同样的负载压力,MySQL 要消耗更少的 CPU 和内存,MS SQL 的确是很耗资源。

1、把主键定义为自动增长标识符类型
MySql
在 mysql 中,如果把表的主键设为 auto_increment 类型,数据库就会自动为主键赋值。例如:
create table customers(id int auto_increment primary key not null, name varchar(15));

最近在做 mssql 转换成 mysql 的工作,总结了点经验,跟大家分享一下。
同时这些也会在不断更新。也希望大家补充。
mysql 支持 enum, 和 set 类型,sql server 不支持
mysql 不支持 nchar,nvarchar,ntext 类型
mysql 的递增语句是 AUTO_INCREMENT,而 mssql 是 identity(1,1)
msms 默认到处表创建语句的默认值表示是((0)), 而在 mysql 里面是不允许带两括号的
mysql 需要为表指定存储类型
mssql 识别符是[],[type] 表示他区别于关键字,但是 mysql 却是 `,也就是按键 1 左边的那个符号
mssql 支持 getdate() 方法获取当前时间日期,但是 mysql 里面可以分日期类型和时间类型,获取当前日期是 cur_date(),当前完整时间是 now()函数
mssql 不支持 replace into 语句,但是在最新的 sql20008 里面,也支持 merge 语法
mysql 支持 insert into table1 set t1 =‘’, t2 =‘’, 但是 mssql 不支持这样写
mysql 支持 insert into tabl1 values (1,1), (1,1), (1,1), (1,1), (1,1), (1,1), (1,1)
mssql 不支持 limit 语句,是非常遗憾的,只能用 top 取代 limt 0,N,row_number() over() 函数取代 limit N,M
mysql 在创建表时要为每个表指定一个存储引擎类型,而 mssql 只支持一种存储引擎
mysql 不支持默认值为当前时间的 datetime 类型(mssql 很容易做到),在 mysql 里面是用 timestamp 类型
mssql 里面检查是否有这个表再删除,需要这样:
if exists (select * from dbo.sysobjects where id = object_id(N’uc_newpm’) and OBJECTPROPERTY(id, N’IsUserTable’) = 1)
但是在 mysql 里面只需要 DROP TABLE IF EXISTS cdb_forums;
mysql 支持无符号型的整数,那么比不支持无符号型的 mssql 就能多出一倍的最大数存储
mysql 不支持在 mssql 里面使用非常方便的 varchar(max) 类型,这个类型在 mssql 里面既可做一般数据存储,也可以做 blob 数据存储
mysql 创建非聚集索引只需要在创建表的时候指定为 key 就行,比如:KEY displayorder (fid,displayorder) 在 mssql 里面必须要:create unique nonclustered index index_uc_protectedmembers_username_appid on dbo.uc_protectedmembers
(username asc,appid asc)
mysql text 字段类型不允许有默认值
19mysql 的一个表的总共字段长度不超过 65XXX。
20 一个很表面的区别就是 mysql 的安装特别简单,而且文件大小才 110M(非安装版),相比微软这个庞然大物,安装进度来说简直就是…
21mysql 的管理工具有几个比较好的,mysql_front, 和官方那个套件,不过都没有 SSMS 的使用方便,这是 mysql 很大的一个缺点。
22mysql 的存储过程只是出现在最新的版本中,稳定性和性能可能不如 mssql。
同样的负载压力,mysql 要消耗更少的 CPU 和内存,mssql 的确是很耗资源。
24php 连接 mysql 和 mssql 的方式都差不多,只需要将函数的 mysql 替换成 mssql 即可。
25mysql 支持 date,time,year 类型,mssql 到 2008 才支持 date 和 time。

MySQL 的数值数据类型可以大致划分为两个类别,一个是整数,另一个是浮点数或小数。
许多不同的子类型对这些类别中的每一个都是可用的,每个子类型支持不同大小的数据,并且 MySQL 允许我们指定数值字段中的值是否有正负之分或者用零填补。
下表列出了各种数值类型以及它们的允许范围和占用的内存空间。

整数:

类型大小范围(有符号)范围(无符号)用途 TINYINT1 字节 (-128,127)(0,255) 小整数值 SMALLINT2 字节 (-32 768,32 767)(0,65 535) 大整数值 MEDIUMINT3 字节 (-8 388 608,8 388 607)(0,16 777 215) 大整数值 INT/INTEGER4 字节 (-2 147 483 648,2 147 483 647)(0,4 294 967 295) 大整数值 BIGINT8 字节 (-9 233 372 036 854 775 808,9 223 372 036 854 775 807)(0,18 446 744 073 709 551 615) 极大整数值 FLOAT4 字节 (-3.402 823 466 E+38,1.175 494 351 E-38),(1.175 494 351 E-38,3.402 823 466 351 E+38) 单精度

浮点数值

类型大小范围(有符号)范围(无符号)用途 DOUBLE8 字节(1.797 693 134 862 315 7 E+308,2.225 073 858 507 201 4 E-308),0(2.225 073 858 507 201 4 E-308,1.797 693 134 862 315 7 E+308),0 双精度

浮点数值
DECIMAL 对 DECIMAL(M,D),如果 M D,为 M + 2 否则为 D +2 依赖于 M 和 D 的值 依赖于 M 和 D 的值 小数值

INT 类型
在 MySQL 中支持的 5 个主要整数类型是 TINYINT,SMALLINT,MEDIUMINT,INT 和 BIGINT。这些类型在很大程度上是相同的,只有它们存储的值的大小是不相同的。
MySQL 以一个可选的显示宽度指示器的形式对 SQL 标准进行扩展,这样当从数据库检索一个值时,可以把这个值加长到指定的长度。例如,指定一个字段的类型为 INT(6),就可以保证所包含数字少于 6 个的值从数据库中检索出来时能够自动地用空格填充。需要注意的是,使用一个宽度指示器不会影响字段的大小和它可以存储的值的范围。
万一我们需要对一个字段存储一个超出许可范围的数字,MySQL 会根据允许范围最接近它的一端截短后再进行存储。还有一个比较特别的地方是,MySQL 会在不合规定的值插入表前自动修改为 0。
UNSIGNED 修饰符规定字段只保存正值。因为不需要保存数字的正、负符号,可以在储时节约一个“位”的空间。从而增大这个字段可以存储的值的范围。
ZEROFILL 修饰符规定 0(不是空格)可以用来真补输出的值。使用这个修饰符可以阻止 MySQL 数据库存储负值。

MySQL 支持的三个浮点类型是 FLOAT、DOUBLE 和 DECIMAL 类型。FLOAT 数值类型用于表示单精度浮点数值,而 DOUBLE 数值类型用于表示双精度浮点数值。
与整数一样,这些类型也带有附加参数:一个显示宽度指示器和一个小数点指示器。比如语句 FLOAT(7,3) 规定显示的值不会超过 7 位数字,小数点后面带有 3 位数字。
对于小数点后面的位数超过允许范围的值,MySQL 会自动将它四舍五入为最接近它的值,再插入它。
DECIMAL 数据类型用于精度要求非常高的计算中,这种类型允许指定数值的精度和计数方法作为选择参数。精度在这里指为这个值保存的有效数字的总个数,而计数方法表示小数点后数字的位数。比如语句 DECIMAL(7,3) 规定了存储的值不会超过 7 位数字,并且小数点后不超过 3 位。
忽略 DECIMAL 数据类型的精度和计数方法修饰符将会使 MySQL 数据库把所有标识为这个数据类型的字段精度设置为 10,计算方法设置为 0。
UNSIGNED 和 ZEROFILL 修饰符也可以被 FLOAT、DOUBLE 和 DECIMAL 数据类型使用。并且效果与 INT 数据类型相同。
字符串类型
MySQL 提供了 8 个基本的字符串类型,可以存储的范围从简单的一个字符到巨大的文本块或二进制字符串数据。

类型大小用途 CHAR0-255 字节定长字符串 VARCHAR0-255 字节变长字符串 TINYBLOB0-255 字节不超过 255 个字符的二进制字符串 TINYTEXT0-255 字节短文本字符串 BLOB0-65 535 字节二进制形式的长文本数据 TEXT0-65 535 字节长文本数据 MEDIUMBLOB0-16 777 215 字节二进制形式的中等长度文本数据 MEDIUMTEXT0-16 777 215 字节中等长度文本数据 LOGNGBLOB0-4 294 967 295 字节二进制形式的极大文本数据 LONGTEXT0-4 294 967 295 字节极大文本数据

CHAR 和 VARCHAR 类型

CHAR 类型用于定长字符串,并且必须在圆括号内用一个大小修饰符来定义。这个大小修饰符的范围从
0-255。比指定长度大的值将被截短,而比指定长度小的值将会用空格作填补。

CHAR 类型可以使用 BINARY 修饰符。当用于比较运算时,这个修饰符使 CHAR
以二进制方式参于运算,而不是以传统的区分大小写的方式。

CHAR 类型的一个变体是 VARCHAR 类型。它是一种可变长度的字符串类型,并且也必须带有一个范围在 0-255 之间的指示器。CHAR 和 VARCHGAR 不同之处在于 MuSQL 数据库处理这个指示器的方式:CHAR 把这个大小视为值的大小,不长度不足的情况下就用空格补足。

而 VARCHAR 类型把它视为最大值并且只使用存储字符串实际需要的长度(增加一个额外字节来存储字符串本身的长度)来存储值。所以短于指示器长度。

VARCHAR 类型不会被空格填补,但长于指示器的值仍然会被截短。

VARCHAR 类型可以根据实际内容动态改变存储值的长度,所以在不能确定字段需要多少字符时使用 VARCHAR 类型可以大大地节约磁盘空间、提高存储效率。

VARCHAR 类型在使用 BINARY 修饰符时与 CHAR 类型完全相同。

TEXT 和 BLOB 类型
对于字段长度要求超过 255 个的情况下,MySQL 提供了 TEXT 和 BLOB 两种类型。根据存储数据的大小,它们都有不同的子类型。这些大型的数据用于存储文本块或图像、声音文件等二进制数据类型。
TEXT 和 BLOB 类型在分类和比较上存在区别。BLOB 类型区分大小写,而 TEXT 不区分大小写。大小修饰符不用于各种 BLOB 和 TEXT 子类型。比指定类型支持的最大范围大的值将被自动截短。
日期和时间类型
在处理日期和时间类型的值时,MySQL 带有 5 个不同的数据类型可供选择。它们可以被分成简单的日期、时间类型,和混合日期、时间类型。根据要求的精度,子类型在每个分类型中都可以使用,并且 MySQL 带有内置功能可以把多样化的输入格式变为一个标准格式。
类型 大小
(字节) 范围 格式 用途
DATE 3 1000-01-01/9999-12-31 YYYY-MM-DD 日期值
TIME 3‘-838:59:59’/‘838:59:59’HH:MM:SS 时间值或持续时间
YEAR 1 1901/2155 YYYY 年份值
DATETIME 8 1000-01-01 00:00:00/9999-12-31 23:59:59 YYYY-MM-DD HH:MM:SS 混合日期和时间值
TIMESTAMP 8 1970-01-01 00:00:00/2037 年某时 YYYYMMDD HHMMSS 混合日期和时间值,时间戳

DATE、TIME 和 TEAR 类型
MySQL 用 DATE 和 TEAR 类型存储简单的日期值,使用 TIME 类型存储时间值。这些类型可以描述为字符串或不带分隔符的整数序列。如果描述为字符串,DATE 类型的值应该使用连字号作为分隔符分开,而 TIME 类型的值应该使用冒号作为分隔符分开。
需要注意的是,没有冒号分隔符的 TIME 类型值,将会被 MySQL 理解为持续的时间,而不是时间戳。
MySQL 还对日期的年份中的两个数字的值,或是 SQL 语句中为 TEAR 类型输入的两个数字进行最大限度的通译。因为所有 TEAR 类型的值必须用 4 个数字存储。MySQL 试图将 2 个数字的年份转换为 4 个数字的值。把在 00-69 范围内的值转换到 2000-2069 范围内。把 70-99 范围内的值转换到 1970-1979 之内。如果 MySQL 自动转换后的值并不符合我们的需要,请输入 4 个数字表示的年份。
DATEYIME 和 TIMESTAMP 类型
除了日期和时间数据类型,MySQL 还支持 DATEYIME 和 TIMESTAMP 这两种混合类型。它们可以把日期和时间作为单个的值进行存储。这两种类型通常用于自动存储包含当前日期和时间的时间戳,并可在需要执行大量数据库事务和需要建立一个调试和审查用途的审计跟踪的应用程序中发挥良好作用。
如果我们对 TIMESTAMP 类型的字段没有明确赋值,或是被赋与了 null 值。MySQL 会自动使用系统当前的日期和时间来填充它。
复合类型
MySQL 还支持两种复合数据类型 ENUM 和 SET,它们扩展了 SQL 规范。虽然这些类型在技术上是字符串类型,但是可以被视为不同的数据类型。一个 ENUM 类型只允许从一个集合中取得一个值;而 SET 类型允许从一个集合中取得任意多个值。
ENUM 类型
ENUM 类型因为只允许在集合中取得一个值,有点类似于单选项。在处理相互排拆的数据时容易让人理解,比如人类的性别。ENUM 类型字段可以从集合中取得一个值或使用 null 值,除此之外的输入将会使 MySQL 在这个字段中插入一个空字符串。另外如果插入值的大小写与集合中值的大小写不匹配,MySQL 会自动使用插入值的大小写转换成与集合中大小写一致的值。
ENUM 类型在系统内部可以存储为数字,并且从 1 开始用数字做索引。一个 ENUM 类型最多可以包含 65536 个元素,其中一个元素被 MySQL 保留,用来存储错误信息,这个错误值用索引 0 或者一个空字符串表示。
MySQL 认为 ENUM 类型集合中出现的值是合法输入,除此之外其它任何输入都将失败。这说明通过搜索包含空字符串或对应数字索引为 0 的行就可以很容易地找到错误记录的位置。
SET 类型
SET 类型与 ENUM 类型相似但不相同。SET 类型可以从预定义的集合中取得任意数量的值。并且与 ENUM 类型相同的是任何试图在 SET 类型字段中插入非预定义的值都会使 MySQL 插入一个空字符串。如果插入一个即有合法的元素又有非法的元素的记录,MySQL 将会保留合法的元素,除去非法的元素。
一个 SET 类型最多可以包含 64 项元素。在 SET 元素中值被存储为一个分离的“位”序列,这些“位”表示与它相对应的元素。“位”是创建有序元素集合的一种简单而有效的方式。并且它还去除了重复的元素,所以 SET 类型中不可能包含两个相同的元素。
希望从 SET 类型字段中找出非法的记录只需查找包含空字符串或二进制值为 0 的行。

感谢各位的阅读!关于 mysql 和 sql server 有什么区别就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到吧!

向 AI 问一下细节

丸趣 TV 网 – 提供最优质的资源集合!

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-12-18发表,共计15536字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)