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