建立一个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语句可以实现吗?怎么写?
我只有这么多分了..感谢帮助我的朋友们!

解决方案 »

  1.   

    ALTER TABLE stuInfo ADD CONSTRAINT CK_stuNo CHECK (stuNo like 's253__')
      

  2.   

    加上jetdw(空间商务) 的就对了//学生定座的座位号,该栏必填,采用自动编号方式,且必须是1~30号
    这个不太理解,自动编号??
      

  3.   

    关于"stuSeat TINYINT IDENTITY(1,1) NOT NULL,--学生定座的座位号,该栏必填,采用自动编号方式,且必须是1~30号"这不会满足你的要求的,应该加入约束才可以做到这点例如:如果这个表中有10行,你不会看出什么问题来,
    但是如果这表表中插入了31行,你会看到这个字段成了31了
    除非每个班级一张表,但是如果有删除操作的话,这个字段就又有其他问题了,例如删除的号以后不能用了,等等。