建立一个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了
除非每个班级一张表,但是如果有删除操作的话,这个字段就又有其他问题了,例如删除的号以后不能用了,等等。