001_创建数据库和表

001_创建数据库和表

 

--数据库的创建不能再事物中展开,因为创建数据库本身就是一个事物,平常应该注意避免嵌套事务

--创建数据库TEST_BAK

IF EXISTS ( SELECT  1

            FROM    sys.sysdatabases

            WHERE   name = 'TEST_BAK' )

    PRINT N'数据库 ''TEST_BAK'' 已存在!'

ELSE

    BEGIN

        CREATE DATABASE TEST_BAK ON

                   (

                            NAME='TEST_BAK_mdf',--数据文件逻辑名

                            FILENAME='E:\sql_2008\TEST_BAK.mdf',--数据文件存放路径

                            SIZE=3MB,--初始大小

                            MAXSIZE=30MB,--最大大小

                            FILEGROWTH=2MB--整张速度

                   ) LOG ON --日志文件

                   (

                            NAME='test_ldf',--日志文件逻辑名

                            FILENAME='E:\sql_2008\TEST_BAK.ldf',--数据文件存放路径

                            SIZE=1MB,--初始大小

                            MAXSIZE=10MB,--最大大小

                            FILEGROWTH=1MB--整张速度

                   )

    END

   

USE TEST_BAK

 

--------------------------------------------------------------

 

BEGIN TRANSACTION trans_test

 

IF EXISTS ( SELECT  *

            FROM    sysobjects

            WHERE   name = N'stuInfo' )

    DROP TABLE stuInfo

go 

IF @@ERROR <> 0

        PRINT N'删除table:''stuInfo''失败!'

 

go   

CREATE TABLE stuInfo    /*-创建学员信息表-*/

    (

      stuNo VARCHAR(6) NOT NULL

                       UNIQUE ,   --学号,非空(必填)

      stuName VARCHAR(20) NOT NULL ,  --姓名,非空(必填)

      stuAge INT NOT NULL ,  --年龄,INT类型默认为4个字节

      stuID NUMERIC(18, 0) ,     --身份证号

      stuSeat INT IDENTITY(1, 1) ,   --座位号,自动编号

      stuAddress TEXT   --住址,允许为空,即可选输入

    )

go

IF @@ERROR <> 0

        PRINT N'创建table:''stuInfo''失败!'

 

go

 

IF EXISTS ( SELECT  *

            FROM    sysobjects

            WHERE   name = N'stuMarks' )

    DROP TABLE stuMarks

IF @@ERROR <> 0

        PRINT N'删除table:''stuMarks''失败!'

CREATE TABLE stuMarks

    (

      ExamNo VARCHAR(6) NOT NULL

                        FOREIGN KEY REFERENCES stuInfo ( stuNo ) ,  --考号

      stuNo VARCHAR(6) NOT NULL ,   --学号

      writtenExam INT NOT NULL ,  --笔试成绩

      LabExam INT NOT NULL    --机试成绩

    )

go

IF @@ERROR <> 0

        PRINT N'创建table:''stuMarks''失败!'

 

go

 

IF EXISTS ( SELECT  *

            FROM    sysobjects

            WHERE   name = N'users' )

    DROP TABLE users

IF @@ERROR <> 0

        PRINT N'删除table:''users''失败!'

go

     

CREATE TABLE users

    (

      userID INT NOT NULL

                 PRIMARY KEY

                 IDENTITY(1, 1) ,

      userName VARCHAR(255) NOT NULL

                            UNIQUE ,

      userPWD VARCHAR(255) NOT NULL ,

      userAge INT ,

      userBirthDay DATETIME ,

      userEmail VARCHAR(255)

    )

go

IF @@ERROR <> 0

        PRINT N'创建table:''users''失败!'

 

 

COMMIT TRANSACTION trans_test

 

---------------------------------------------------------------

 

--调用sp_helpconstraint 来查询表 stuMarks 的外键

EXEC sp_helpconstraint N'stuMarks'

 

--直接删除外键

ALTER  TABLE stuMarks

    DROP constraint FK__stuMarks__ExamNo__023D5A04

 

--删除数据库

DROP DATABASE TEST_BAK

posted @ 2015-02-10 21:40  黑白叹  阅读(163)  评论(0编辑  收藏  举报