实验二 数据库及数据库对象的创建和管理

实验二 数据库及数据库对象的创建和管理

一、实验目的
1.掌握用企业管理器(Enterprise Manager)对数据库的完整创建、修改和删除
2.掌握用企业管理器(Enterprise Manager)对常见的数据库对象如表、试图、索引等的创建、修改和删除
3.掌握用SQL语句进行创建和管理数据库、表、试图和索引

二、实验环境(实验的软件、硬件环境)
硬件:PC机 软件:SQL2000

三、实验指导说明
请复习相关的数据库及其对象的创建和管理的SQL语法知识点,并完成如下内容。

四、实验内容
1.数据库操作
(1)用SQL语句完整创建一个订单数据库,名为OrderDB,存放路径为:E:\MyOrder,它由5MB的主数据文件、2MB的次数据文件和1MB的日志文件组成。并且主数据文件以2MB的增长速度增长,其最大数据文件的大小为15MB,次数据文件以10%的增长速度增长,其最大次数据文件的大小为10MB,事务日志文件以1MB速度增长,其最大日志文件大小为10MB。

--创建数据库名为OrderDB的数据库,主文件名为OrderDB
create database OrderDB 
on(
    name = "OrderDB",
    filename="E:\MyOrder",
    size = 5MB,
    maxsize = 15MB,
    filegrowth= 2MB
),--次文件名为OrderDC
(
    name="OrderDC",
    filename="E:\MyOrderDC",
    size = 2MB,
    maxsize = 10MB,
    filegrowth=10%
)
--事物日志
LOG ON
(
    name = "OrderDB_log",
    filename="E:\MyOrderDB_log",
    size = 1MB,
    maxsize = 10MB,
    filegrowth = 1MB
)

(2)将主数据文件大小由5M增大到8M,并删除次数据文件。

--将主数据文件大小由5MB改为8MB
alter database OrderDB modify file (
    name = "OrderDB",
    size = 8MB
)

(3)为了扩大订单数据库,为它增加一个次要数据文件order3.ndf,该文件大小为4M,最大可增长到10M,以10%的速度增长。

--为数据库OrderDB再创建一个次要数据文件
alter database OrderDB
add file(
    name = "order3",
    filename="E:\order.ndf",
    size = 4MB,
    maxsize = 10MB,
    filegrowth = 10%
)

(4)删除数据库。

--删除数据库OrderDB
drop database OrderDB

2.表操作
(1)简单创建订单数据库orderDB

--简单创建数据库文件
create database OrderDB

(2)为订单数据库创建5张表,分别如下:(要求在创建的过程中,分别为每张表合理建立主键、外键约束)


--先使用数据库OrderDB
use OrderDB

员工表Employee
员工号 employeeNo Char(8)
员工姓名 employeeName Varchar(10)
性别 Sex Char(1)
所属部门 Department Varchar(30)
职务 Headship Varchar(6)
雇佣日期 Hiredate Datetime
出生日期 Birthday Datetime
薪水 Salary Number
住址 Address Varchar(50)
电话 Telephone Varchar(20)

--创建表Emoloyee
create table Employee (
    employee CHAR(8),
    employeeName VARCHAR(10),
    Sex CHAR(1),
    Department VARCHAR(30),
    Headship VARCHAR(6),
    Hiredate DATETIME,
    Birthday DATETIME,
    Slary Numeric(10,2),
    Address VARCHAR(50),
    Telephone VARCHAR(20)
)

客户表customer
客户号 CustomerNo Char(9)
客户名称 customerName Varchar(40)
客户住址 Address Varchar(40)
客户电话 Telephone Varchar(20)
邮政编码 Zip Char(6)
建立日期 Createdate datetime

CREATE TABLE customer(
CustomerNoChar( 9 ) ,
customerName Varchar( 40 ) ,
Address Varchar( 40 ) ,
Telephone Varchar( 20 ) ,
ZipChar( 6 ) ,
Createdate datetime
)

商品信息表product
商品编号 ProductNo Char(9)
商品名称 ProductName Varchar(40)
商品类别 ProductClass Varchar(20)
商品定价 ProductPrice Number
建立日期 Createdate datetime

--创建商品信息表
create table product (
    ProductNo CHAR(9),
    ProductName VARCHAR(40),
    ProductClass VARCHAR(20),
    ProductPrice Numeric(10,2),
    Createdate DATETIME
)

订单主表orderMaster
订单编号 OrderNo Char(12)
客户号 customerNo Char(9)
业务员编号 SaleNo Char(8)
订单金额 Ordersum Numeric
订货日期 Orderdate Datetime
出货日期 Shipdate Datetime
发票号码 InvoiceNo Char(10)

--创建订主表单
create table orderMaster(
    OrderNo Char(12),
    customerNo  Char(9),
    SaleNo  Char(8),
    Ordersum    Numeric(10,2),
    Orderdate   Datetime,
    Shipdate    Datetime,
    InvoiceNo   Char(10)
)

订单明细表orderDetail
订单编号 OrderNo Char(12)
商品编号 ProductNo Char(9)
销售数量 Qty Int
成交单价 Price Numeric

--创建定标明细单
create table orderDetail (
    OrderNo CHAR(12),
    ProductNo CHAR(9),
    Qty INT,
    Price NUMERIC(10,2)
)

(3)表结构的修改
 修改客户表结构,要求客户名称和客户电话属性为not null

alter table customer alter column customerName VARCHAR(40) not null
alter table customer alter column Telephone VARCHAR(20) not null

 修改员工表结构,要求员工姓名和电话属性为not null

alter table customer alter column customerName VARCHAR(40) not null
alter table customer alter column Telephone VARCHAR(20) not null

 修改订单表结构,要求发票号码属性为not null


alter table orderMaster alter column InvoiceNo CHAR(10) not null

3.索引操作
在已创建的基本表的基础上,完成以下索引
(1)在员工表中按所得薪水建立一个非聚集索引salaryIdx

create nonclustered index salaryIdx on Employee(Salary)

(2)在订单主表中,首先按订金金额的升序,然后按业务员编号的降序建立一个非聚集索引salenosumIdx。

create nonclustered index salenosumIdx on orderMaster(Ordersum ASC, SaleNo DESC)

4.视图操作
创建一个视图,该视图只含上海客户信息,即客户号、客户姓名、客户住址、建立日期。
5.利用企业管理器(Enterprise Manager)完成以上1~4中的操作。

五、实验步骤
请完成实验内容,并写出具体的实验步骤

六、思考题:
1.请思考数据库和各数据库中的对象的联系和区别?
2.请思考视图和表的联系和区别?

七、总结(实验过程的体会、心得和实验教与学之间还需改进的内容)

  • 6
    点赞
  • 24
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值