实验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

相关文章

批量导入txt数据到的redis过程

《批量导入txt数据到的redis过程》用户通过将Redis命令逐行写入txt文件,利用管道模式运行客户端,成功执行批量删除以Product*匹配的Key操作,提高了数据清理效率... 目录批量导入txt数据到Redisjs把redis命令按一条 一行写到txt中管道命令运行redis客户端成功了批量删除k

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

在macOS上安装jenv管理JDK版本的详细步骤

《在macOS上安装jenv管理JDK版本的详细步骤》jEnv是一个命令行工具,正如它的官网所宣称的那样,它是来让你忘记怎么配置JAVA_HOME环境变量的神队友,:本文主要介绍在macOS上安装... 目录前言安装 jenv添加 JDK 版本到 jenv切换 JDK 版本总结前言China编程在开发 Java

Spring Boot Actuator应用监控与管理的详细步骤

《SpringBootActuator应用监控与管理的详细步骤》SpringBootActuator是SpringBoot的监控工具,提供健康检查、性能指标、日志管理等核心功能,支持自定义和扩展端... 目录一、 Spring Boot Actuator 概述二、 集成 Spring Boot Actuat

MySQL多实例管理如何在一台主机上运行多个mysql

《MySQL多实例管理如何在一台主机上运行多个mysql》文章详解了在Linux主机上通过二进制方式安装MySQL多实例的步骤,涵盖端口配置、数据目录准备、初始化与启动流程,以及排错方法,适用于构建读... 目录一、什么是mysql多实例二、二进制方式安装MySQL1.获取二进制代码包2.安装基础依赖3.清

C#监听txt文档获取新数据方式

《C#监听txt文档获取新数据方式》文章介绍通过监听txt文件获取最新数据,并实现开机自启动、禁用窗口关闭按钮、阻止Ctrl+C中断及防止程序退出等功能,代码整合于主函数中,供参考学习... 目录前言一、监听txt文档增加数据二、其他功能1. 设置开机自启动2. 禁止控制台窗口关闭按钮3. 阻止Ctrl +

java如何实现高并发场景下三级缓存的数据一致性

《java如何实现高并发场景下三级缓存的数据一致性》这篇文章主要为大家详细介绍了java如何实现高并发场景下三级缓存的数据一致性,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 下面代码是一个使用Java和Redisson实现的三级缓存服务,主要功能包括:1.缓存结构:本地缓存:使

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分