1、第二 章SQL SERVER数据库表管理2n 掌握建库的 SQL语句n 掌握建表的 SQL语句n 掌握加约束的 SQL语句n 掌握创建安全帐户的 SQL语句 n创建数据库表n 设置表的主键、外键和建立表之间的关系n 为表增加约束本章目标3创建数据库 CREATE DATABASE 数据库名ON PRIMARY(, n )LOG ON (, n)T-SQL创建数据库的语法:主文件组,可选参数,默认4创建数据库示例 1CREATE DATABASE stuDBON PRIMARY -默认就属于 PRIMARY主文件组,可省略(NAME=stuDB_data, -主数据文件的逻辑名FILENAME=
2、D:projectstuDB_data.mdf, -主数据文件的物理名SIZE=5mb, -主数据文件初始大小MAXSIZE=100mb, -主数据文件增长的最大值FILEGROWTH=15% -主数据文件的增长率)LOG ON(NAME=stuDB_log,FILENAME=D:projectstuDB_log.ldf,SIZE=2mb,FILEGROWTH=1MB)GO 数据文件的具体描述日志文件的具体描述5创建数据库示例 2CREATE DATABASE employeesON (/*-主数据文件的具体描述 -*/NAME = employee1, FILENAME = D:projec
3、temployee1_Data.mdf , SIZE = 10, FILEGROWTH = 10%), (/*-次要数据文件的具体描述 -*/NAME = employee2, FILENAME = D:projectemployee2_Data.ndf , SIZE = 20, MAXSIZE = 100, FILEGROWTH = 1) LOG ON (/*-日志文件 1的具体描述 -*/NAME = employeelog1, FILENAME = D:projectemployeelog1_Log.ldf , SIZE = 10, FILEGROWTH = 1), (/*-日志文件 2
4、的具体描述 -*/NAME = employeelog2, FILENAME = D:projectemployeelog2_Log.ldf , SIZE = 10, MAXSIZE = 50, FILEGROWTH = 1)GO 6USE master -设置当前数据库为 master,以便访问 sysdatabases表GOIF EXISTS( SELECT * FROM sysdatabases WHERE name =stuDB)DROP DATABASE stuDBCREATE DATABASE stuDBON (.)LOG ON()GO删除数据库n删除数据库的语法:DROP DAT
5、ABASE 数据库名EXISTS()语句:检测是否存在 stuDB数据库如果存在 stuDB数据库,则删除 7SQL Server的数据类型分类 备注和说明 数据类型 说明二进制数据类型 存储非子符和文本的数据 Image 可用来存储图像文本数据类型 字符数据包括任意字母、符号或数字字符的组合Char 固定长度的非 Unicode 字符数据Varchar 可变长度非 Unicode 数据Nchar 固定长度的 Unicode 数据Nvarchar 可变长度 Unicode 数据Text 存储长文本信息Ntext 存储可变长度的长文本日期和时间 日期和时间在单引号内输入 Datetime 日期和
6、时间数字数据 该数据仅包含数字,包括正数、负数以及分数intsmallint整数floatreal数字货币数据类型 用于十进制货币值 MoneyBit数据类型 表示是 /否的数据 Bit 存储布尔数据类型8建表的基本步骤n确定表中有哪些列n确定每列的数据类型n给表添加各种约束n创建各表之间的关系9创建表n建表的语法CREATE TABLE 表名(字段 1 数据类型 列的特征,字段 2 数据类型 列的特征,.)列的特征:包括该列是是否为空( NULL)、是否是标识列(自动编号)、是否有默认值、是否为主键等。 10建表示例 1USE stuDB -将当前数据库设置为 stuDB GOCREATE TABLE stuInfo /*-创建学员信息表 -*/(stuName VARCHAR(20) NOT NULL , -姓名,非空(必填)stuNo CHAR(6) NOT NULL, -学号,非空(必填)stuAge INT NOT NULL, -年龄, INT类型默认为 4个字节stuID NUMERIC(18,0), -身份证号stuSeat SMALLINT IDENTITY (1,1), -座位号,自动编号stuAddress TEXT -住址,允许为空,即可选输入) GONUMERIC (18,0)代表 18位数字,小数位数为 0IDENTITY(起始值,递增量)