使用SQL创建库、表、约束

来源:互联网 发布:东华软件应收账款 编辑:程序博客网 时间:2024/06/05 08:45

一、创建数据库

    create database stuDB     on  primary  -- 默认就属于primary文件组,可省略    (    /*--数据文件的具体描述--*/      name='stuDB_data',  -- 主数据文件的逻辑名称      filename='D:\stuDB_data.mdf', -- 主数据文件的物理名称      size=5mb, --主数据文件的初始大小      maxsize=100mb, -- 主数据文件增长的最大值      filegrowth=15%--主数据文件的增长率     )     log on     (     /*--日志文件的具体描述,各参数含义同上--*/         name='stuDB_log',         filename='D:\stuDB_log.ldf',         size=2mb,         filegrowth=1mb     )

二、删除数据库

use master -- 设置当前数据库为master,以便访问sysdatabases表goif exists(select * from sysdatabases where name='stuDB')drop database stuDBgo

三、创建表、

use StuDBgo if exists(select * from sysobjects where name='stuMarks')drop table stuMarkscreate table stuMarks(    ExamNo      int     identity(1,1) primary key,    stuNo       char(6) not null,    writtenExam int     not null,    LabExam     int     not null)go-- 其中,列属性"identity(起始值,递增量)" 表示"ExamNo"列为自动编号, 也称为标识列alter table 表名add constraint 约束名 约束类型 具体的约束说明alter table 表名drop constraint 约束名alter table stuMarksadd constraint UQ_stuNo Unique(stuNo)alter table stuMarksdrop constraint UQ_stuNo/*--添加SQL登录账户--*/exec sp_addlogin 'xie', '123456'  -- 账户名为xie,密码为123456--删除xie账户名exec sp_droplogin 'xie'/*--在stuDB数据库中添加两个用户(必须存在)--*/use stuDBgo  exec sp_grantdbaccess 'xie','123456'go-- 提示:SQL Server 中的dbo用户是具有在数据库中执行所有活动权限的用户,表示数据库的所有者(owner),一般来说,-- 如果创建了某个数据库,就是该数据库的所有者,即dbo用户,dbo用户是一个比较特殊的数据库用户,无法删除,且此用-- 户始终出现在每个数据库中/* --给数据库用户授权-- */-- 授权的语法如下-- grant 权限 [on 表名] to 数据库用户use stuDBgo  grant select,update,insert on stuMarks to xie  grant create table to xiego
0 0