【数据库实验一】数据库及数据库中表的建立实验

news2024/11/13 3:39:08

目录

实验1  学习RDBMS的使用和创建数据库

一、 实验目的

二、实验内容

三、实验环境

四、实验前准备

五、实验步骤

六、实验结果

七、评价分析及心得体会

实验2 定义表和数据库完整性

一、 实验目的

二、实验内容

三、实验环境

四、实验前准备

五、实验步骤

六、实验结果

七、评价分析及心得体会


实验1  学习RDBMS的使用和创建数据库

一、 实验目的

(1)熟悉某一RDBMS产品(如:SQL Server ) 的环境。

(2)掌握企业管理器的基本使用方法,对数据库及其对象有基本了解,了解对SQL Server 进行配置的方法。

(3)掌握查询分析器的基本使用方法以及在查询分析器中执行T-SQL语句的方法。

(4)了解SQL Server 数据库的逻辑结构和物理结构。

(5)学会在企业管理器中创建数据库及查看数据库属性。

(6)学会使用T-SQL语句创建数据库。

二、实验内容

(1)学会使用企业管理器和查询分析器管理工具。

(2)使用企业管理器创建数据库。

创建一个教务管理数据库,名称为JWGL,数据文件的初始大小为20MB,文件增长方式为自动增长,文件增长增量设为5MB,文件的增长上限为500MB。日志文件的初始大小为10MB,文件增长增量设为1MB,文件的增长限制设为100MB。数据文件的逻辑文件名和物理文件名均采用默认值,分别为JWGL_data和d:\Microsoft SQL Server\MSSQL\data\ JWGL_data.mdf;事务日志文件的逻辑文件名和物理文件名也采用默认值,分别为JWGL_log和d:\Microsoft SQL Server\MSSQL\data\JWGL_log.ldf。

(3)在查询分析器中使用T-SQL语句创建数据库。

创建一个名为Market的数据库(注意e盘下应存在sql_data目录)。

CREATE DATABASE Market

ON

   (NAME = Market_Data,

    FILENAME = 'e:\sql_data\Market_Data.mdf',

    SIZE = 10,

    MAXSIZE = 50,

    FILEGROWTH = 10%)

LOG ON

    (NAME = Market_Log,

    FILENAME = 'e:\sql_data\ Market__Log.ldf',

    SIZE = 5,

    MAXSIZE = 15,

    FILEGROWTH = 10%);    

(4)使用T-SQL语句或企业管理器创建一个图书借阅管理数据库,数据库名为TSGL,数据文件和日志文件的初始大小、增长方式、文件的增长上限等均可采用默认值。

(5)使用T-SQL语句或企业管理器创建第2章习题10的SPJ数据库,可以自行定义文件大小、增长方式等。

(6)查看物理磁盘目录,理解并分析SQL Server 数据库的存储结构。

(7)使用企业管理器查看数据库属性。

(8)使用T-SQL语句或企业管理器对于(2)~(5)中建立的数据库进行修改和删除操作,并进一步查看物理磁盘目录。

三、实验环境

mysql-8.3.0-win64

MySQL Workbench 8.0 CE

四、实验前准备

下载并安装MySQL以及MySQL Workbench

五、实验步骤

可以使用Create a new scheme

使用语句

其他的均相同

六、实验结果

七、评价分析及心得体会

通过此次实验,我熟悉了MySQL Workbench的环境,掌握了企业管理器的基本使用方法,对数据库及其对象有基本了解,学会在企业管理器中创建数据库及查看数据库属性,学会使用MySQL语句创建数据库,并了解数据库的逻辑结构和物理结构。

实验2 定义表和数据库完整性

一、 实验目的

(1)了解SQL Server 的基本数据类型、空值的概念,以及表的结构特点。

(2)学会使用T-SQL语句和企业管理器创建表结构和修改表结构。

(3)学会使用SQL Server 提供的数据完整性功能,并在创建表时定义表的数据完整性。通过实验进一步理解数据完整性的概念及分类。

二、实验内容

(1)用企业管理器在教务管理数据库JWGL中创建学生表Student、课程表Course、学生选课表SC,它们的表结构如表B.1所示。

(2)用T-SQL语句在Market数据库中创建客户基本信息表Customers、货品信息表Goods、订单信息表Orders,它们的定义如下

 CREATE TABLE Customers(

         CustomerID  int  IDENTITY(1,1)  PRIMARY  KEY,

         CName  varchar(8)  NOT  NULL ,

         Address  varchar(50),

         City  varchar(10),

         Tel  varchar(20)  UNIQUE,

         Company  varchar(50),

         Birthday  datetime,

         Type  tinyint  DEFAULT 1);

CREATE TABLE Goods (

         GoodsID int  CONSTRAINT  C1 PRIMARY  KEY ,

         GoodsName  varchar(20)  NOT  NULL,

         Price  money,

         Description  varchar(200),

         Storage   int,

         Provider  varchar(50),

         Status  tinyint  DEFAULT(0));

CREATE TABLE Orders (

         OrderID  int  IDENTITY(1,1)  CONSTRAINT  C2  PRIMARY  KEY ,

         GoodsID  int  NOT NULL  REFERENCES Goods(GoodsID)  ON  DELETE

             CASCADE,

         CustomerID  int  NOT NULL  FOREIGN KEY(CustomerID)

             REFERENCES Customers (CustomerID)  ON  UPDATE  CASCADE

ON DELETE NO ACTION,

         Quantity  int  NOT NULL  CONSTRAINT  C3  CHECK(Quantity >0),

         OrderSum  money  NOT NULL,

         OrderDate  datetime  DEFAULT(getdate()) );

(3)使用T-SQL语句在SPJ数据库中创建第2章习题6中的4张表:供应商表S、零件表P、工程项目表J和供应情况表SPJ,数据类型和长度自行设计,注意要同时定义主键、外键和其他的数据完整性。

(4)使用T-SQL语句在图书借阅管理数据库TSGL中建立图书、读者和借阅3个表,其结构为

图书(书号,书名,类别,出版社,作者,定价,出版时间)

读者(借书证号,姓名,单位,性别,地址,电话号码)

借阅(书号,借书证号,借阅日期)

要求为属性选择合适的数据类型,定义每个主键、外键,是否允许空值等数据完整性约束。

三、实验环境

mysql-8.3.0-win64

MySQL Workbench 8.0 CE

四、实验前准备

复习创建表的语句

五、实验步骤

(1)可以通过Create Table进行建表

(2)也可以用MySQL语句实现

student、course、sc

customers、goods、orders

s、p、j、spj

图书、读者、借阅

CREATE TABLE jwgl.student (
  Sno CHAR(8) NOT NULL,
  Sname VARCHAR(10) NOT NULL ,
  Sex CHAR(2) NOT NULL DEFAULT '男' CHECK (Sex='男' or Sex='女'),
  Age TINYINT(1) NOT NULL DEFAULT 20 CHECK (Age BETWEEN 15 AND 30),
  Phonenumber CHAR(12) NULL UNIQUE,
  Sdept VARCHAR(20) NOT NULL,
  PRIMARY KEY (`Sno`));

CREATE TABLE jwgl.course (
    Cno CHAR(10) NOT NULL,
    Cname VARCHAR(20) NOT NULL UNIQUE,
    Total_perior TINYINT UNSIGNED NOT NULL DEFAULT 64 CHECK (Total_perior BETWEEN 32 AND 108),
    Week_perior TINYINT UNSIGNED NOT NULL DEFAULT 4 CHECK (Week_perior BETWEEN 2 AND 7),
    credit TINYINT UNSIGNED NOT NULL DEFAULT 4 CHECK (credit BETWEEN 1 AND 7),
    Pcno CHAR(10),
    PRIMARY KEY (Cno)
);
CREATE TABLE jwgl.sc (
  Sno CHAR(8) NOT NULL,
  Cno CHAR(10) NOT NULL,
  Grade TINYINT(1) NULL CHECK (Grade BETWEEN 0 AND 100), 
  PRIMARY KEY (Sno, Cno),
  FOREIGN KEY (Sno) REFERENCES Student(Sno),
  FOREIGN KEY (Cno) REFERENCES Course(Cno)
);

create table market.customers (
	CustomerID int not null auto_increment,
    CName varchar(8) not null,
    Address varchar(50),
    City varchar(10),
    Tel varchar(20) unique,
    Company varchar(50),
    Bithday date,
    Type tinyint default 1,
    primary key (CustomerID)
);

create table market.goods (
	GoodsID int not null,
    GoodsName varchar(20) not null,
    Price decimal(10,2),
    Description varchar(200),
    Storage int,
    Provider varchar(50),
    Status tinyint default 0,
    primary key(GoodsID)
);

create table market.orders(
	OrderID int not null auto_increment,
    GoodsID int not null,
    CustomerID int not null,
    Queantity int not null check ( Queantity>0),
    OrderSum decimal(10,2) not null,
    OrderDate datetime default  (now()),
    primary key (OrderID),
    foreign key( GoodsID) references goods(GoodsID) on delete cascade,
    foreign key(CustomerID) references customers(CustomerID) on update cascade on delete no action
);


create table spj.s(
	SNO CHAR(2) PRIMARY KEY,
   SNAME VARCHAR(50),
   STATUS INT,
   CITY VARCHAR(50)
);

create table spj.p(
	PNO char(2) primary key,
    PNAME varchar(50),
    COLOR varchar(20),
    WEIGHT float

);

create table spj.j(
	JNO char(2) primary key,
    JNAME varchar(50),
    CITY varchar(50)

);

create table spj.spj(
	SNO char(2),
    PNO char(2),
    JNO char(2),
    QTY int,
    primary key(SNO,PNO,JNO),
    foreign key(SNO) references s(SNO),
    foreign key(PNO) references p(PNO),
    foreign key(JNO) references j(JNO)

);

create table `tsgl`.`图书`(
	`书号` char(13) primary key,
    `书名` varchar(255) not null,
    `类别` varchar(50),
    `出版社` varchar(100),
    `作者` varchar(100),
    `定价` decimal(10,2),
    `出版时间` date
);

create table `tsgl`.`读者`(
	`借书证号` char(10) primary key,
    `姓名` varchar(50) not null,
    `单位` varchar(100),
    `性别` enum('男','女') not null,
    `地址` varchar(255),
    `电话号码` varchar(20)
);


CREATE TABLE `tsgl`.`借阅` (
    `书号` CHAR(13),
    `借书证号` CHAR(10),
    `借阅日期` DATE,
    PRIMARY KEY (`书号`, `借书证号`),
    FOREIGN KEY (`书号`) REFERENCES `图书`(`书号`) ON DELETE CASCADE ON UPDATE CASCADE,
    FOREIGN KEY (`借书证号`) REFERENCES `读者`(`借书证号`) ON DELETE CASCADE ON UPDATE CASCADE
);



 

六、实验结果

七、评价分析及心得体会

在本次实验中,我了解MySQL的基本数据类型、空值的概念,以及表的结构特点。并学会使用MySQL语句和企业管理器创建表结构和修改表结构。使用SQL Workbench提供的数据完整性功能,并在创建表时定义表的数据完整性,通过实验进一步理解数据完整性的概念及分类。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2236488.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

基于YOLO11/v10/v8/v5深度学习的煤矿传送带异物检测系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】

《------往期经典推荐------》 一、AI应用软件开发实战专栏【链接】 项目名称项目名称1.【人脸识别与管理系统开发】2.【车牌识别与自动收费管理系统开发】3.【手势识别系统开发】4.【人脸面部活体检测系统开发】5.【图片风格快速迁移软件开发】6.【人脸表表情识别系统】7.【…

【鸿蒙】HarmonyOS NEXT应用开发快速入门教程之布局篇(下)

系列文章目录 【鸿蒙】HarmonyOS NEXT开发快速入门教程之ArkTS语法装饰器(上) 【鸿蒙】HarmonyOS NEXT开发快速入门教程之ArkTS语法装饰器(下) 【鸿蒙】HarmonyOS NEXT应用开发快速入门教程之布局篇(上) 【…

设计模式-七个基本原则之一-单一职责原则 + SpringBoot案例

单一职责原理:(SRP) 面向对象七个基本原则之一 清晰的职责:每个类应该有一个明确的职责,避免将多个责任混合在一起。降低耦合:通过将不同的职责分开,可以降低类之间的耦合度,提高系统的灵活性。易于维护:当…

【Linux】进程信号全攻略(一)

🌈 个人主页:Zfox_ 🔥 系列专栏:Linux 目录 一:🔥 信号的概念 二:🔥 信号产生的方式 🦋 使用键盘🦋 系统调用函数🦋 软件条件🦋 进程异…

selenium+chromedriver下载与安装

安装selenium 使用pip安装selenium: pip install selenium安装成功: 安装WebDriver 根据你使用的浏览器下载相应的 WebDriver。 Chrome:下载地址Firefox:下载地址Edge:下载地址Safari:下载地址 1、c…

前端环境配置

对于换公司的小伙伴来讲,重新安装环境,百度或许稍微有点麻烦,本文章让你无脑式直接操作,保证环境畅通无阻。 1.安装nvm-setup 该插件是一款管理nodeJs的包,无需你单独下载nodeJs去安装,只需要下载安装此…

python(自用查看版)

目录 1.注意事项 1.1 python的除法不是整除,得到的是浮点数 1.2算术符号基于数学的算术优先级。具体可自行查看。 1.3注释 1.4缩进 1.5换行 1.6常见关键字 1.7续行符 1.8报错 1.9赋值 1.10比较运算符 2.常量和表达式 3.变量 4.数据类型 4.1整型int …

基于Prometheus的client_golang库实现应用的自定义可观测监控

文章目录 1. 安装client_golang库2. 编写可观测监控代码3. 运行效果4. jar、graalvm、golang编译运行版本对比 前文使用javagraalvm实现原生应用可观测监控: prometheus client_java实现进程的CPU、内存、IO、流量的可观测,但是部分java依赖包使用了复杂…

Docker网络概述

1. Docker 网络概述 1.1 网络组件 Docker网络的核心组件包括网络驱动程序、网络、容器以及IP地址管理(IPAM)。这些组件共同工作,为容器提供网络连接和通信能力。 网络驱动程序:Docker支持多种网络驱动程序,每种驱动程…

新160个crackme - 094-TheBigMan-crackme6

运行分析 需破解Name和Serial PE分析 LCC win32程序,32位,无壳 静态分析&动态调试 ida搜索字符串,进入关键函数 ida动调,发现关键判断函数func_1 进入后,发现Name长度需满足一定要求,且func_2返回值不能…

大数据-214 数据挖掘 机器学习理论 - KMeans Python 实现 算法验证 sklearn n_clusters labels

点一下关注吧!!!非常感谢!!持续更新!!! 目前已经更新到了: Hadoop(已更完)HDFS(已更完)MapReduce(已更完&am…

【Django】视图函数

【Django】视图函数 视图函数的本质是Python中的函数,视图函数负责处理用户的请求并返回响应,该响应可以是网页的HTML内容、重定向、404错误、XML文档、图像或者任何东西,一般在应用中的views.py编写,示例代码如下: …

kafka+zookeeper的搭建

kafka从2.8版本开始,就可以不用配置zookeeper了,但是也可以继续配置。我目前使用的kafka版本是kafka_2.12-3.0.0.tgz,其中前面的2.12表示是使用该版本的scala语言进行编写的,而后面的3.00才是kafka当前的版本。 通过百度网盘分享…

了解bootstrap改造asp.net core MVC的样式模板

我们都知道,在使用默认的asp.net core MVC模板建立项目的时候,里面的样式是已经事先被写好了的。一般来说都在css目录下的site.css和bootstrap.css及下面的bootstrap.min.css中。我们打开bootstrap这些样式文件,里面有大量的样式类的定义&…

HTMLCSS:旋转的动态卡片

效果演示 这段代码创建了一个具有动态背景和渐变效果的卡片。卡片背景有一个无限循环的旋转动画&#xff0c;增加了视觉吸引力。这种效果可以用于展示个人信息、项目介绍或其他需要吸引用户注意的内容。 HTML <div class"card"><h3>前端Hardy</h3&…

深入Pillow:处理图像下载中的意外挑战

在当今数字化时代&#xff0c;获取和处理图像数据已经成为了许多应用程序的核心功能。从社交媒体到电子商务&#xff0c;图像的获取和处理对于用户体验至关重要。下载图片不仅能够丰富我们的内容&#xff0c;还能够通过分析图像数据为我们的应用提供更多价值。然而&#xff0c;…

管理 Elasticsearch 变得更容易了,非常容易!

作者&#xff1a;来自 Elastic Ken Exner Elasticsearch 用户&#xff0c;我们听到了你的心声。管理 Elasticsearch 有时会变得很复杂&#xff0c;面临的挑战包括性能调整、问题检测和资源优化。我们一直致力于简化你的体验。今天&#xff0c;我们宣布了自收购 Opster 以来的一…

Linux挖矿病毒(kswapd0进程使cpu爆满)

一、摘要 事情起因:有台测试服务器很久没用了&#xff0c;突然监控到CPU飙到了95以上&#xff0c;并且阿里云服务器厂商还发送了通知消息&#xff0c;【阿里云】尊敬的xxh: 经检测您的阿里云服务&#xff08;ECS实例&#xff09;i-xxx存在挖矿活动。因此很明确服务器中挖矿病毒…

【go从零单排】迭代器(Iterators)

&#x1f308;Don’t worry , just coding! 内耗与overthinking只会削弱你的精力&#xff0c;虚度你的光阴&#xff0c;每天迈出一小步&#xff0c;回头时发现已经走了很远。 &#x1f4d7;概念 在 Go 语言中&#xff0c;迭代器的实现通常不是通过语言内置的迭代器类型&#x…

(混乱版)数据冒险-ld,sub和and

第一张图没有数据转发 从这张图来看&#xff0c;如果没有数据转发机制&#xff0c;流水线的执行会出现更多的停顿。这种情况下&#xff0c;数据依赖只能通过**插入停顿周期&#xff08;stalls&#xff09;**来解决。具体分析如下&#xff1a; 指令序列 ld r1, 0(r2)&#xf…