实验1 数据库及表的管理和数据操纵

2024-01-25 23:50

本文主要是介绍实验1 数据库及表的管理和数据操纵,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、实验项目:

数据库及表的管理和数据操纵。

二、实验目的

1、能够使用SQL语句创建、修改和删除数据库。

2、能够使用SQL语句创建、修改和删除数据表。

3、能够使用SQL语句插入、修改和删除表数据。

三、实验内容

(一):2学时

使用SQL语句完成下列题目:

1、创建一个名为agristore的数据库,采用字符集latin1和校对规则latin1_swedish_ci。

2、修改数据库agristore的默认字符集gb2312,校对规则为gb2312_chinese_ci。

3、在数据库agristore中创建如下表,表结构如下:

用户表account

属性名称

含义

数据类型

为空性

备注

userid

用户编号

Char(5)

NOT NULL

主键

fullname

用户名

Varchar(10)

NOT NULL

password

密码

Varchar(20)

NOT NULL

sex

性别

Char(2)

NOT NULL

address

住址

Varchar(40)

NULL

email

邮箱

Varchar(20)

NULL

phone

电话

Char(11)

NOT NULL

商品分类表category

属性名称

含义

数据类型

为空性

备注

catid

类别编号

Char(3)

NOT NULL

主键

catname

分类名称

Varchar(20)

NOT NULL

cades

类别描述

text

NULL

商品表product

属性名称

含义

数据类型

为空性

备注

productid

商品编号

Char(7)

NOT NULL

主键

catid

类别编号

Char(3)

NOT NULL

name

商品名

Varchar(30)

NOT NULL

descn

商品介绍

text

NULL

listprice

市场价格

Decimal(10,2)

NULL

unitcost

成本价格

Decimal(10,2)

NULL

qty

数量

Int

NOT NULL

订单表orders

属性名称

含义

数据类型

为空性

备注

orderid

订单号

Int

NOT NULL

主键,按订单生成顺序自动编号

userid

用户编号

Char(5)

NOT NULL

orderdate

订单日期

datetime

NOT NULL

当前日期

totalprice

订单总价

Decimal(10,2)

NULL

status

订单状态

Tinyint

NULL

订单明细表lineitem

属性名称

含义

数据类型

为空性

备注

orderid

订单号

Int

NOT NULL

主键

productid

商品编号

Char(7)

NOT NULL

主键

quantity

数量

Int

NOT NULL

unitprice

单价

Decimal(10,2)

NOT NULL

4、修改用户表account,向表中增加 新列“喜好”,数据类型为varchar(50),允许为空。

5、将account表中的列address的数据类型修改为varchar(50)。

6、删除account表中的“喜好”列。

(二):2学时

1、对orders表中userid(客户编号)列引用了account表中的userid(客户编号)。要求为orders表中userid(客户编号)列创建外键,以保证当要删除和更新account表中的数据时,只要orders表中还有该客户的订单,就拒绝对account表进行的删除和更新操作。

2、对lineitem表中productid(商品编号)列引用了product表中的productid(商品编号)。要求为lineitem表中productid(商品编号)列创建外键,以保证当要删除和更新product表中的商品编号时,自动删除或更新lineitem匹配的行。

3、在agristore数据库的下列表中插入如下数据:

用户表account数据

userid

fullname

password

sex

address

email

phone

u0001

刘晓和

123456

广东深圳市

liuxh@163.com

13512345678

商品表product数据

productid

catid

name

descn

listprice

unitcost

qty

0010001

001

金龙鱼一级大豆油5L

品质好

50.99

40.00

100

订单表orders数据

orderid

userid

orderdate

totalprice

status

20230411

u0001

2023-04-11 15:07:34

800

0

4、新进一批金龙鱼一级大豆油5L,数量为50桶,进价为45元,按库存与新进商品的平均值调整商品的成本价格。该商品将以高出成本价格20%的市场价格卖出,调整商品的市场价格和数量。

5、订单号为20230411的订单已经发货,在订单表中将该订单的状态修改为1。

6、删除商品表中名称为“金龙鱼一级大豆油5L”的商品信息。

四、实验参考代码

1、create database agristore

character set latin1

collate latin1_swedish_ci;

show create database agristore;

2、alter database agristore

default character set gb2312

default collate gb2312_chinese_ci;

show create database agristore;

3、(1)use agristore;

CREATE TABLE  account  (

   userid  char(5) NOT NULL,

   fullname  varchar(10) NOT NULL,

   password  varchar(20) NOT NULL,

   sex  char(2) NOT NULL,

   address  varchar(40) NULL,

   email  varchar(20) NULL,

   phone  char(11) NOT NULL,

  PRIMARY KEY  ( userid )

) ;

desc account;

(2)

CREATE TABLE  category  (

   catid  char(3) NOT NULL,

   catname  varchar(20) Not NULL,

   cades  text NULL,

  PRIMARY KEY  ( catid )

);

desc category;

(3)

CREATE TABLE  product  (

   productid  char(7) NOT NULL,

   catid  char(3) NOT NULL,

   name  varchar(30) Not NULL,

   descn  text NULL,

   listprice  decimal(10,2)  NULL,

   unitcost  decimal(10,2)  NULL,

   qty  int NOT NULL,

  PRIMARY KEY  ( productid )

) ;

desc product;

(4)

CREATE TABLE  orders  (

   orderid  int  NOT NULL auto_increment,

   userid  char(5) NOT NULL,

   orderdate  datetime NOT NULL DEFAULT NOW(),/*由于MySQL5.6以下的版本不支持datetime类型default now()的写法,故此处的也可以写成orderdate timestamp NOT NULL default now()*/

   totalprice  decimal(10,2)  NULL,

   status  tinyint  NULL,

  PRIMARY KEY( orderid )

) ;

desc orders;

(5)

CREATE TABLE  lineitem  (

   orderid  int NOT NULL,

   productid  char(7) NOT NULL,

   quantity  int NOT NULL,

   unitprice  decimal(10,2) NOT NULL,

  PRIMARY KEY  ( orderid , productid )

) ;

desc lineitem;

4、Alter table account add column 喜好 varchar(50) null;

Desc account;

5、Alter table account modify column address varchar(50);

Desc account;

6、Alter table account drop column 喜好;

Desc account;

(二)1、alter table orders

add constraint foreign key(userid)

references account(userid)

on update restrict

on delete restrict;

show create table orders\G

2、alter table lineitem

add constraint foreign key(productid)

references product(productid)

on update cascade

on delete cascade;

show create table lineitem\G

3、(1)

INSERT INTO  account  VALUES ('u0001', '刘晓和', '123456', '男', '广东深圳市', 'liuxh@163.com', '13512345678');

select * from account;

(2)INSERT INTO  product  VALUES ('0010001', '001', '金龙鱼一级大豆油5L', '品质好', 50.99, 40.00, 100);

select * from product;

(3)INSERT INTO  orders  VALUES (20230411, 'u0001', '2023-04-11 15:07:34', 800.00, 0);

select * from orders;

4、update  product

Set unitcost=(qty*unitcost+45*50)/(qty+50),listprice=unitcost*1.2,qty=qty+50

where name='金龙鱼一级大豆油5L';

修改前:select * from product;

修改后:select * from product;

5、update orders set status=1 where orderid=20230411;

修改前:select * from orders;

修改后:select * from orders;

6、delete from product where name='金龙鱼一级大豆油5L';

删除前:select * from product;

删除后:select * from product;

这篇关于实验1 数据库及表的管理和数据操纵的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/645021

相关文章

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

canal实现mysql数据同步的详细过程

《canal实现mysql数据同步的详细过程》:本文主要介绍canal实现mysql数据同步的详细过程,本文通过实例图文相结合给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的... 目录1、canal下载2、mysql同步用户创建和授权3、canal admin安装和启动4、canal

使用jenv工具管理多个JDK版本的方法步骤

《使用jenv工具管理多个JDK版本的方法步骤》jenv是一个开源的Java环境管理工具,旨在帮助开发者在同一台机器上轻松管理和切换多个Java版本,:本文主要介绍使用jenv工具管理多个JD... 目录一、jenv到底是干啥的?二、jenv的核心功能(一)管理多个Java版本(二)支持插件扩展(三)环境隔

使用SpringBoot整合Sharding Sphere实现数据脱敏的示例

《使用SpringBoot整合ShardingSphere实现数据脱敏的示例》ApacheShardingSphere数据脱敏模块,通过SQL拦截与改写实现敏感信息加密存储,解决手动处理繁琐及系统改... 目录痛点一:痛点二:脱敏配置Quick Start——Spring 显示配置:1.引入依赖2.创建脱敏

详解如何使用Python构建从数据到文档的自动化工作流

《详解如何使用Python构建从数据到文档的自动化工作流》这篇文章将通过真实工作场景拆解,为大家展示如何用Python构建自动化工作流,让工具代替人力完成这些数字苦力活,感兴趣的小伙伴可以跟随小编一起... 目录一、Excel处理:从数据搬运工到智能分析师二、PDF处理:文档工厂的智能生产线三、邮件自动化:

Python数据分析与可视化的全面指南(从数据清洗到图表呈现)

《Python数据分析与可视化的全面指南(从数据清洗到图表呈现)》Python是数据分析与可视化领域中最受欢迎的编程语言之一,凭借其丰富的库和工具,Python能够帮助我们快速处理、分析数据并生成高质... 目录一、数据采集与初步探索二、数据清洗的七种武器1. 缺失值处理策略2. 异常值检测与修正3. 数据

Python中bisect_left 函数实现高效插入与有序列表管理

《Python中bisect_left函数实现高效插入与有序列表管理》Python的bisect_left函数通过二分查找高效定位有序列表插入位置,与bisect_right的区别在于处理重复元素时... 目录一、bisect_left 基本介绍1.1 函数定义1.2 核心功能二、bisect_left 与

pandas实现数据concat拼接的示例代码

《pandas实现数据concat拼接的示例代码》pandas.concat用于合并DataFrame或Series,本文主要介绍了pandas实现数据concat拼接的示例代码,具有一定的参考价值,... 目录语法示例:使用pandas.concat合并数据默认的concat:参数axis=0,join=

C#代码实现解析WTGPS和BD数据

《C#代码实现解析WTGPS和BD数据》在现代的导航与定位应用中,准确解析GPS和北斗(BD)等卫星定位数据至关重要,本文将使用C#语言实现解析WTGPS和BD数据,需要的可以了解下... 目录一、代码结构概览1. 核心解析方法2. 位置信息解析3. 经纬度转换方法4. 日期和时间戳解析5. 辅助方法二、L