MySQL利用视图插入修改删除数据

这篇具有很好参考价值的文章主要介绍了MySQL利用视图插入修改删除数据。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 准备

已有数据库stu,数据表student、course、score:

create database stu;
use stu;

create table student(
sid char(4) primary key,
sname varchar(20) not null,
sex enum('男','女'),
birth date,
grade year,
department enum('信息工程系','化学工程系','机械电子系') default '信息工程系',
addr varchar(50)
)charset=utf8mb4;

create table course(
cno char(2) primary key,
cname varchar(20) not null,
start int,
credit float
)charset=utf8mb4;

create table  score(
scid int primary key auto_increment ,
sid char(4),
cno char(2),
result float  check(result >= 0 and result <= 100)
)charset=utf8mb4;

2.创建视图

create view  v1
as 
select sid,sname,sex,department,year(now())-year(birth) age
from student where department='化学工程系';

create view  v2
as 
select sid,sname,sex,department
from student where department='化学工程系';

create view v3
as 
select student.sid,sname,course.cno,cname,result
from student,score,course
where student.sid=score.sid and course.cno=score.cno;

3.插入数据

利用v1插入记录:

insert v1(sid,sname,sex,department)values('8888','张敏敏','女','信息工程系');

插入失败,错误提示:
Error Code: 1471. The target table v1 of the INSERT is not insertable-into

利用v2插入记录:

insert v2(sid,sname,sex,department)values('8888','张敏敏','女','信息工程系');

插入成功。
v1和v2相比,v1比v2多了个字段计算年龄的表达式year(now())-year(birth)。
插入失败可能原因1:定义视图的select语句后面有数学表达式或聚合函数。

利用v3插入记录

insert v3 values('8888','张敏敏','01','大学英语',90);

Error Code: 1394. Can not insert into join view ‘stu.v3’ without fields list

insert v3(cno,cname) values('55','人工智能');

插入成功
插入失败可能原因2:视图是定义在多个表上,通过视图插入一条记录可能是在多个表中插入记录。

定义视图v4,并在v4上定义视图v5、v6

create  view v4
as
select sid,cno,result
from score
where result>=70 ;

create  view v5
as
select sid,cno,result
from v4
where result<=90 with local check option ;

create  view v6
as
select sid,cno,result
from v4
where result<=90 with cascaded check option ;

利用v4插入记录,不管是否满足result>=70,均可插入:

insert v4 values('0404','01',60);
insert v4 values('0404','02',80);

利用v5插入记录:

insert v5 values('0405','01',60);
insert v5 values('0405','02',95);
insert v5 values('0405','03',80);

成绩为60、80均可插入,95插入失败:Error Code: 1369. CHECK OPTION failed ‘stu.v5’。因为在v5定义的时候有with local check option,必须满足视图v5本身定义的条件result<=90,对v4的条件result>=70不做要求。
with local check option 只要求满足该视图本身定义的条件

利用v6插入数据:

insert v6 values('0406','01',60);
insert v6 values('0406','02',95);
insert v6 values('0406','03',80);

只有成绩为80的记录插入成功,60和95均失败,因为在定义v6的时候有with cascaded check option,所以v6和v4定义的条件都必须满足。
with cascaded check option 要求满足所有视图和表定义的条件

插入失败可能原因3:插入记录不满足视图定义的基本条件。
在定义视图时select语句中含distinct、union、top、group by等短语时,插入记录也可能失败,不再举例。

4.修改记录、删除记录

利用v2修改学号8888为6688:

update v1 set sid='6688' where sid='8888';

不报错,不修改数据。提示为:0 row(s) affected Rows matched: 0 Changed: 0 Warnings: 0

利用v2删除8888记录:
delete from v2 where sid=‘8888’;
不报错、不删除。
如果修改v2定义去掉department=‘化学工程系’,则允许修改、允许删除:

create or replace view  v2
as 
select sid,sname,sex,department
from student;
update v2 set sid='6688' where sid='8888';
delete from v2 where sid='6688';

利用视图修改数据、删除数据时,不满足视图定义条件都不能修改或删除。不报错

5.总结:

利用视图插入数据时:
1.定义视图的select语句后面有数学表达式或聚合函数;
2.视图是定义在多个表上,通过视图插入一条记录是在多个表中插入记录;
3.视图定义时带‘with… check option’,不满足视图定义的条件;
4.视图带distinct、union、top、group by等短语时;
都可能导致插入记录失败。
利用视图修改数据、删除数据时,不满足视图定义条件都不能修改或删除。
文章来源地址https://www.toymoban.com/news/detail-462273.html

到了这里,关于MySQL利用视图插入修改删除数据的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【头歌educoder数据表中数据的插入、修改和删除】

    1、本关任务:在library数据库的reader数据表中插入一条数据 姓名xm为林团团,电话号码dhhm为13507311234,其余字段取默认值 显示数据表的所有数据 2、本关任务: 在reader数据表中插入一位读者 读者证号是2,姓名是陈洁,性别是女,身份是教研人员,电话号码是13319551234 提示:

    2024年02月04日
    浏览(114)
  • Iceberg从入门到精通系列之三:创建Iceberg表、修改表结构、插入数据、删除表

    Hive语法创建分区表,不会在元数据创建分区,而是将分区数据转换为Iceberg标识分区。 这种情况下不能使用Iceberg的分区转换,例如:days(timestamp),如果想要使用Iceberg格式表的分区转换标识分区,需要使用Spark或者Flink引擎创建表。 只支持HiveCatalog表修改表属性,Iceberg表属性和

    2024年02月11日
    浏览(65)
  • 数据结构课程设计题目——链表综合算法设计、带头双向循环链表、插入、显示、删除、修改、排序

      课程设计题目1–链表综合算法设计   一、设计内容   已知简单的人事信息系统中职工记录包含职工编号(no)、职工姓名(name)、部门名称(depname)、职称(title)和工资数(salary)等信息(可以增加其他信息),设计并完成一个简单的人事信息管理系统,要求完成但不

    2024年02月08日
    浏览(52)
  • 【数据结构】线性表(一)线性表的定义及其基本操作(顺序表插入、删除、查找、修改)

    目录 一、线性表 1. 线性表的定义 2. 线性表的要素 二、线性表的基本操作 三、线性表的顺序存储结构 1. 定义 2. 顺序表的操作       a. 插入操作 b. 删除操作 c. 查找操作 d. 修改操作 e. 代码实例          一个线性表是由零个或多个 具有相同类型的结点 组成的有序集合。

    2024年02月03日
    浏览(46)
  • 利用SQL语句创建、修改、删除、查看与使用数据库

    【技术路线图】 1、连接Mysql服务:mysql -u root -p 2、创建数据库:create database teacherdb; 注意:数据库的名字一旦创建后不可更改。 3、查看刚刚创建好的数据库:show databses; 4、删除数据库并查看是否删除掉:drop database teacherdb; 5、输出创建数据库时的SQL语句信息:show create dat

    2023年04月21日
    浏览(75)
  • 数据结构_链表_单向循环链表的初始化、插入、删除、修改、查询打印(基于C语言实现)

    版本: 2024年4月25日 V1.0 发布于博客园 目录 目录 单向循环链表公式 初始化单向循环链表 构建单向循环链表结点 创建一个空链表(仅头结点) 创建一个新结点 插入数据 头插 中插 尾插 删除数据 头删 中删 尾删 查询打印数据 遍历打印 测试 测试结果: 完整代码 CircularLinkedLis

    2024年04月25日
    浏览(40)
  • 数据结构_链表_双向循环链表的初始化、插入、删除、修改、查询打印(基于C语言实现)

    版本: 2024年4月26日 V1.0 发布于博客园 目录 目录 双向循环链表公式 初始化双向循环链表 构建双向循环链表结点 创建一个空链表(仅头结点) 创建一个新结点 插入数据 头插 中插 尾插 删除数据 头删 中删 尾删 查询打印数据 遍历打印 测试 测试结果: 完整代码 DoubleCirLList.h

    2024年04月27日
    浏览(37)
  • Mybatis 插入、修改、删除

    前面几篇我们介绍了使用Mybatis查询数据,并且也了解了如何在Mybatis中使用JDK的日志系统打印日志;本篇我们继续介绍如何使用Mybatis完成数据的插入、修改和删除。 如果您对查询数据和Mybatis集成JDK日志系统不太了解,建议您先进行了解后再阅读本篇,可以参考: Mybatis查询数

    2024年02月10日
    浏览(26)
  • {MySQL} 数据库约束& 表的关系& 新增&&删除& 修改& 查询

    提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 提示:这里可以添加本文要记录的大概内容: 承接上文,继续讲一下MySQL 提示:以下是本篇文章正文内容,下面案例可供参考 NOT NULL - 指示某列不能存储 NULL 值。 UNIQUE - 保证某列的每行必须有唯一的值

    2024年02月03日
    浏览(41)
  • pycharm连接MySql数据库,新建表creat table、删除表drop table、查询表select、插入数据insert

    亲爱的小伙伴,欢迎你来为学习新的知识啦~~~ 一、安装pymysql 首先我们肯定要先在python中把能操作mySql的第三方数据库安装一下呀~ 安装方式:pip安装(你有没有安装好pip呀,可以看安装pip的相关文章进行安装好哦~) 打开我们电脑的终端,然后输入以下的命令,将我们

    2024年02月09日
    浏览(39)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包