日期:2014-05-18  浏览次数:20602 次

这个数据库用T-SQL语句怎么写啊?
建立一个stuDB的学生库,
建立一个stuInfo的一张表.
学员姓名,该栏必填,要考虑姓氏可能是两个字的,如欧阳
学号,该栏必填,学号不能重复,且必须是s253**格式
学员性别,该栏必填,且只能是男女
学生年龄,该栏必填,必须在15~40之间
学生定座的座位号,该栏必填,采用自动编号方式,且必须是1~30号
学生地址,该栏可不填,如没有填写,显示地址不详

我写了一部分出来,大家看看..
/*创建数据库*/
USE   master --使用master库,确认建立的表是在stuDB库中.
IF   EXISTS   (SELECT   *   FROM   dbo.sysdatabases   WHERE   NAME= 'stuDB ')    
DROP   DATABASE   stuDB --如果有stuDB库就删除
CREATE   DATABASE   stuDB --建立stuDB库
ON
(
NAME   =   'stuDB.mdf ', --库名stuDB.mdf
FILENAME= 'D:\project\stuDB.mdf ', --库存放路径
FILEGROWTH=15% --库增长率15%
/*其他信息题中无要求.全部默认*/
)
/*创建表*/
USE   stuDB --使用stuDB库,确认建立的表是在stuDB库中.
IF   EXISTS   (SELECT   *   FROM   dbo.sysobjects   WHERE   NAME= 'stuInfo ')
DROP   TABLE   stuInfo --如果有stuInof表就删除
CREATE   TABLE   stuInfo --建立stuInof表
(
stuName   VARCHAR(10)   NOT   NULL, --学员姓名,该栏必填,要考虑姓氏可能是两个字的,如欧阳
stuNo   VARCHAR(6)   NOT   NULL, --学号,该栏必填,学号不能重复,且必须是s253**格式
stuSex   VARCHAR(2)   NOT   NULL, --学员性别,该栏必填,且只能是男女
stuAge   TINYINT   NOT   NULL, --学生年龄,该栏必填,必须在15~40之间
stuSeat   TINYINT   IDENTITY(1,1)   NOT   NULL, --学生定座的座位号,该栏必填,采用自动编号方式,且必须是1~30号
stuAddress   TEXT   --学生地址,该栏可不填,如没有填写,显示地址不详
)
/*添加约束*/
ALTER   TABLE   stuInfo   ADD   CONSTRAINT   UQ_stuNo   UNIQUE   (stuNo)
ALTER   TABLE   stuInfo   ADD   CONSTRAINT   CK_stuSex   CHECK   (stuSex= '男 '   OR   stuSex= '女 ')
ALTER   TABLE   stuInfo   ADD   CONSTRAINT   CK_stuAge   CHECK   (stuAge> 15   AND   stuAge <40)
ALTER   TABLE   stuInfo   ADD   CONSTRAINT   CK_stuSeat   CHECK   (stuSeat> =1   AND   stuSeat <=30)
ALTER   TABLE   stuInfo   ADD   CONSTRAINT   DF_stuAddress   DEFAULT( '地址不详 ')   FOR   stuAddress


帮忙看看有没有错误,另外有一个问题一直没解决,就是
学号,该栏必填,学号不能重复,且必须是s253**格式
这个如何实现??
用check语句可以实现吗?怎么写?
我只有这么多分了..感谢帮助我的朋友们!

------解决方案--------------------
ALTER TABLE stuInfo ADD CONSTRAINT CK_stuNo CHECK (stuNo like 's253__ ')
------解决方案--------------------
加上jetdw(空间商务) 的就对了

//学生定座的座位号,该栏必填,采用自动编号方式,且必须是1~30号
这个不太理解,自动编号??
------解决方案--------------------
关于 "stuSeat TINYINT IDENTITY(1,1) NOT NULL,--学生定座的座位号,该栏必填,采用自动编号方式,且必须是1~30号 "

这不会满足你的要求的,应该加入约束才可以做到这点

例如:如果这个表中有10行,你不会看出什么问题来,
但是如果这表表中插入了31行,你会看到这个字段成了31了
除非每个班级一张表,但是如果有删除操作的话,这个字段就又有其他问题了,例如删除的号以后不能用了,等等。