MySQL如何使用视图插入修改删除数据

 更新时间:2023年06月06日 16:29:26   作者:喜欢的牡丹花  
视图除了进行查询记录外,也可以利用视图进行插入、更新、删除记录的操作,减少对基表中信息的直接操作,提高了数据的安全性,下面这篇文章主要给大家介绍了关于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等短语时;

都可能导致插入记录失败。

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

到此这篇关于MySQL如何使用视图插入修改删除数据的文章就介绍到这了,更多相关MySQL视图插入修改删除数据内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 从零开始MySQL触发器实战攻略

    从零开始MySQL触发器实战攻略

    想要掌握MySQL触发器的实战技巧吗?从零开始,跟我一起揭开触发器神秘的面纱!轻松入门,迅速提升,这个指南将让你的MySQL技能焕然一新!一探究竟,惊喜等你发现!
    2024-02-02
  • MySQL在Windows上安装的详细流程

    MySQL在Windows上安装的详细流程

    MySQL 是最流行的数据库管理系统 (DBMS) 之一,它轻量、开源且易于安装和使用,因此对于那些刚开始学习和使用关系数据库的人来说是一个不错的选择, 本文主要系统介绍Windows的环境下MySQL的安装过程和验证过程,需要的朋友可以参考下
    2024-12-12
  • 详解MySQL如何选择合适的索引

    详解MySQL如何选择合适的索引

    选择合适的索引是数据库优化中非常重要的一步,正确的索引可以大幅提高查询性能,减少数据库响应时间;而不当的索引选择则可能增加存储开销,影响数据库性能,甚至使得某些操作变得更加缓慢,以下是选择合适索引的一些指导原则和策略,需要的朋友可以参考下
    2024-12-12
  • MySQL中的两阶段提交详解(2PC)

    MySQL中的两阶段提交详解(2PC)

    这篇文章主要介绍了MySQL中的两阶段提交(2PC),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • Mysql循环插入数据的实现

    Mysql循环插入数据的实现

    这篇文章主要介绍了Mysql循环插入数据的实现过程,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-08-08
  • textarea标签(存取数据库mysql)的换行方法

    textarea标签(存取数据库mysql)的换行方法

    textarea标签本身不识别换行功能,回车换行用的是\n换行符,输入时的确有换行的效果,但是html渲染或者保存数据库mysql时就只是一个空格了,这时就需要利用换行符\n和br标签的转换进行处理
    2023-09-09
  • MySQL数据恢复工具:ibd2sql离线解析.ibd文件转换为SQL

    MySQL数据恢复工具:ibd2sql离线解析.ibd文件转换为SQL

    ibd2sql是纯Python3工具,用于离线解析MySQL InnoDB IBD文件生成SQL语句,支持多版本和复杂结构,可恢复误删数据,优点包括无依赖、灵活输出,但存在性能慢、数据完整性风险及资源消耗大的缺点,适用于数据恢复、迁移和审计场景
    2025-06-06
  • MySQL中having和where的区别及应用详解

    MySQL中having和where的区别及应用详解

    这篇文章主要给大家详细介绍了MySQL中having和where的区别以及他们的使用方法,文中有相关的代码示例,具有一定的参考价值,需要的朋友可以参考下
    2023-06-06
  • 一文带你搞懂MySQL的事务隔离级别

    一文带你搞懂MySQL的事务隔离级别

    这篇文章主要给大家介绍了MySQL事务隔离级别,事务隔离级别分别是读未提交,读已提交,可重复读,串行化,文中有详细的图文介绍,需要的朋友可以参考下
    2023-07-07
  • Mysql删除重复数据并且只保留一条(附实例!)

    Mysql删除重复数据并且只保留一条(附实例!)

    最近有朋友打电话寻求一个SQL相关的问题,大致是表中存在重复数据,需要删除掉重复数据保留一条的场景,下面这篇文章主要给大家介绍了关于Mysql删除重复数据并且只保留一条的相关资料,需要的朋友可以参考下
    2023-02-02

最新评论