SQL是结构化查询语⾔,是⼀种⽤来操作RDBMS(关系型数据库管理系统)的数据库语⾔,当前关系型数据库都⽀持使⽤SQL语⾔进⾏操作,也就是说可以通过SQL操作oracle,sqlserver,mysql等关系型数据库。

SQL语句主要分为
DDL语句:数据定义语⾔,这些语句定义了不同的数据段、数据库、表、列、索引等数据库对象。
DML语句:数据操纵语句,⽤于添加、删除、更新、和查询数据库记录,并检查数据完整性
DCL语句:数据控制语句,⽤于控制不同数据段直接许可和访问级别的语句。

数据完整性
在表中为了更加准确的存储数据,保证数据的正确有效,可以在创建表的时候,为表添加⼀些强制性的验证,包括数据字段的类型、约束。

数据类型

常⽤数据类型

数值类型

⽇期时间类型

字符串类型

数值类型

sql server检查数据类型 sql查看数据类型语句_字段

sql server检查数据类型 sql查看数据类型语句_SQL_02

 字符串类型

sql server检查数据类型 sql查看数据类型语句_SQL_03

 

 枚举类型

枚举类型英⽂为ENUM,对1~255个成员的枚举需要1个字节存储;对于255~65535个成员,需要2个字节存储。最多允许65535个成员。创建⽅式:enum("M","F");

⽇期类型

sql server检查数据类型 sql查看数据类型语句_字符串_04

注意
decimal表示定点⼩数,如decimal(5,2)表示共存5位数,⼩数占2位。不写则默认为decimal(10,0)
char表示固定⻓度的字符串,如char(3),如果填充'ab'时会补⼀个空格为'ab '
varchar表示可变⻓度的字符串,如varchar(3),填充'ab'时就会存储'ab'
对于图⽚、⾳频、视频等⽂件,不存储在数据库中,⽽是上传到某个服务器上,然后在表中存储这个⽂件的保存路径
枚举类型不区分⼤⼩写

详细数据类型可参考:

约束
主键primary key:物理上存储的顺序
⾮空not null:此字段不允许填写空值
惟⼀unique:此字段的值不允许重复(身份证号,银⾏卡号等)
默认default:当不填写此值时会使⽤默认值,如果填写时以填写为准
外键foreign key:对关系字段进⾏约束,当为关系字段填写值时,会到关联的表中查询此值是否存在,如果存在则填写成功,如果不存在则填写失败并抛出异常