什么是表
表是用于存储数据的逻辑结构;也是用于组织和存储有行列结构的数据对象;行是组织数据的单位,列是用于描述数据的属性;一个表是由行和列组成; 行值在同一个表中具有唯一性;是主键约束所决定的; 列名在同一个表中具有唯一性;
系统表和临时表
创建的sqlserver数据库中,系统会自动添加一个系统表,该表存储了与系统有关的各种信息如:服务器配置,数据库设置等;
临时表:不能永久保存的表;有两种本地临时表#和全局临时表##;本地临时表只对当前用户可见;
表中数据类型
我们创建一个表,在这个表中的每一列能存储什么值,有些列需要存储文字,而有些列又需要存储数值,那么就必须记住下边这些数据类型了。在创建表时进行使用
1、bit 整型
bit数据类型是整型,其值只能是0、1或空值。这种数据类型用于存储只有两种可能值的数据,如Yes 或No、True 或False 、On 或Off.
注意:很省空间的一种数据类型,如果能够满足需求应该尽量多用。
2、tinyint 整型
tinyint 数据类型能存储从0到255 之间的整数。它在你只打算存储有限数目的数值时很有用。这种数据类型在数据库中占用1 个字节.
注意:如果bit类型太单调不能满足您的需求,您可以考虑用tinyint类型,因为这个类型相对也是比较安全的,不接受恶意脚本内容的嵌入。
3、smallint 整型
smallint 数据类型可以存储从- 2的15次幂(-32768)到2的15次幂(32767)之间的整数。这种数据类型对存储一些常限定在特定范围内的数值型数据非常有用。这种数据类型在数据库里占用2 字节空间.
注意:如果tinyint类型太单调不能满足您的需求,您可以考虑用smallint类型,因为这个类型相对也是比较安全的,不接受恶意脚本内容的嵌入。
4、int 整型
int 数据类型可以存储从- 2的31次幂(-2147483648)到2的31次幂 (2147483 647)之间的整数。存储到数据库的几乎所有数值型的数据都可以用这种数据类型。这种数据类型在数据库里占用4个字节.
注意:如果smallint也不能够满足您的需求,您可以考虑用长度更大的int类型。
5、decimal 精确数值型
decimal 数据类型能用来存储从-10的38次幂-1到10的38次幂-1的固定精度和范围的数值型数据。使用这种数据类型时,必须指定范围和精度。 范围是小数点左右所能存储的数字的总位数。精度是小数点右边存储的数字的位数
6、numeric 精确数值型
numeric数据类型与decimal 相似。
7、smallmoney 货币型
smallmoney 数据类型用来表示钱和货币值。这种数据类型能存储从-214748.3648 到214748.3647 之间的数据,精确到货币单位的万分之一
8、money 货币型
money数据类型用来表示钱和货币值。这种数据类型能存储从-9220亿到9220 亿之间的数据,精确到货币单位的万分之一
9、float 近似数值型
float 数据类型是一种近似数值类型,供浮点数使用。说浮点数是近似的,是因为在其范围内不是所有的数都能精确表示。浮点数可以是从-1.79E+308到1.79E+308 之间的任意数
10、real 近似数值型
real 数据类型像浮点数一样,是近似数值类型。它可以表示数值在-3.40E+38到3.40E+38之间的浮点数
11、Smalldatetime 日期时间型
smalldatetime 数据类型用来表示从1900年1月1日到2079年6月6日间的日期和时间,精确到一分钟
12、datetime 日期时间型
datetime数据类型用来表示日期和时间。这种数据类型存储从1753年1月1日到9999年12月31日间所有的日期和时间数据, 精确到三百分之一秒或3.33毫秒 .
13、char 字符型
char数据类型用来存储指定长度的定长非统一编码型的数据。当定义一列为此类型时,你必须指定列长。当你总能知道要存储的数据的长度时,此数据类型很有用。例如,当你按邮政编码加4个字符格式来存储数据时,你知道总要用到10个字符。此数据类型的列宽最大为8000 个字符.
14、varchar 字符型
varchar数据类型,同char类型一样,用来存储非统一编码型字符数据。与char 型不一样,此数据类型为变长。当定义一列为该数据类型时,你要指定该列的最大长度。 它与char数据类型最大的区别是,存储的长度不是列长,而是数据的长度 .
14、text 字符型
text 数据类型用来存储大量的非统一编码型字符数据。这种数据类型最多可以有231-1或20亿个字符.
15、nchar 统一编码字符型
nchar 数据类型用来存储定长统一编码字符型数据。统一编码用双字节结构来存储每个字符,而不是用单字节(普通文本中的情况)。它允许大量的扩展字符。此数据类型能存储4000种字符,使用的字节空间上增加了一倍.
16、nvarchar 统一编码字符型
nvarchar 数据类型用作变长的统一编码字符型数据。此数据类型能存储4000种字符,使用的字节空间增加了一倍.
17、ntext 统一编码字符型
ntext 数据类型用来存储大量的统一编码字符型数据。这种数据类型能存储230 -1或将近10亿个字符,且使用的字节空间增加了一倍
非空列
列的属性是否为空决定着该列是否必须指定相应的数据值null(空,列可以不指定具体的值 )
当某列的属性设置为not null时。那么在插入数据时必须为该列提供具体的数据值。
主键与外键
创建表的SQL语法
1、创建CREATE然后是类型TABLE表示表,然后你要创建的数据表名称,最好用英文。
CREATE TABLE dushuwunet
(
学号 nvarchar(50) not null primary key,
姓名 nchar(10) not null,
性别 nchar(10) not null,
出生日期 date null,
民族 nchar(10) null,
所属班级 nchar(10) null,
家庭地址 ntext null
)
解释:
1、上述语句中将学号通过primary key定义为主键,确保了dushuwunet这个表的完整 性和不可重复性。但需注意,当某个字段被定义为主键时,该学号字段必须设为非空not null
2、学号(列的名称) nvarchar(50)(列的数据类型)表示是字符的可变长度(Unicode)字符数据
Unicode字符集就是为了解决字符集这种不兼容的问题而产生的,它所有的字符都用两个字节表示,即英文字符也是用两个字节表示
一般来说,如果含有中文字符,用nchar/nvarchar,如果纯英文和数字,用char/varchar
2创建外键
外键主要用于定义数据库的参照完整性 通过使用FOREIGN key 关键字定义外键;
注意:在建表的时候应该建立系别信息与辅导员信息表,只有这样,我们在建班级的时候才能使用Foreign key (所属系别) REFERENCES 系别信息(系别编号),建立主外键关系。也就是说要先有系别,然后才能有班级。先有了主键表,才有了对应的外键表。
CREATE TABLE班级信息
(
班级编号 nchar(10) not null primary key,
班级名 nchar(10),
班级人数 int null,
所属系别 nchar(10) not null,
辅导员 nchar(10) not null
Foreign key (所属系别) REFERENCES 系别信息(系别编号),
Foreign key (辅导员)REFERENCES辅导员信息(辅导员编号)
)
3、默认值 是指如果插入行时没有为该列指定具体的数值 ,则使用定义的默认值 default
分数(列的名称) int(列的数据类型) null DEFAULT(0) �D�D如果没有存入的值,就是0
创建check约束列
性别 nchar(10) not null check(性别in(‘男’,’女’)),
创建自动编号列 1每增加一行自动递增1
系别编号 int IDENTITY(1,1) primary key not null