当前位置:网站首页 > SQL数据库编程 > 正文

mysql主键和外键的建立关系(主键 mysql)



视图(View)是一种虚拟存在的表。视图中的数据并不在数据库中实际存在,行和列数据来自定义视图的查询中使用的表,并且是在使用视图时动态生成的。

通俗的讲,视图只保存了查询的SQL逻辑,不保存查询结果。所以我们在创建视图的时候,主要的工作就落在创建这条SQL查询语句上。

数据准备:

1.2.1 创建视图

示例:

1.2.2 查询视图

示例1:查询stu_v_1视图的创建语句:

MySQL中用视图设置联合主键_MySQL中用视图设置联合主键

展开后:

示例2:查询stu_v_1视图里面的数据

MySQL中用视图设置联合主键_数据库_02

MySQL中用视图设置联合主键_软件工程_03

1.2.4
删除视图

1.2.5 插入数据说明

上述我们演示了,视图应该如何创建、查询、修改、删除,那么我们能不能通过视图来插入、更新数据呢? 接下来,做一个测试。

当使用WITH CHECK OPTION子句创建视图时,MySQL会通过视图检查正在更改的每个行,例如 插入,更新,删除,以使其符合视图的定义。 MySQL允许基于另一个视图创建视图,它还会检查依赖视图中的规则以保持一致性。为了确定检查的范围,mysql提供了两个选项: CASCADED 和 LOCAL,默认值为 CASCADED 。

1.3.1 CASCADED(级联)

比如,视图是基于视图的,如果在视图创建的时候指定了检查选项为 ,但是视图创建时未指定检查选项。 则在执行检查时,不仅会检查,还会级联检查的关联视图。

MySQL中用视图设置联合主键_MySQL中用视图设置联合主键_04

1.3.2 LOCAL(本地)

比如,视图是基于视图的,如果在视图创建的时候指定了检查选项为  ,但是视图创建时未指定检查选项。 则在执行检查时,只会检查,不会检查的关联视图。

MySQL中用视图设置联合主键_主键_05

要使视图可更新,视图中的行与基础表中的行之间必须存在一对一的关系(1行基础表数据对应视图里面的一行数据,不会出现类似2行基础表数据对应视图里面的一行数据的情况)。如果视图包含以下任何一项,则该视图不可更新:

  • 聚合函数或窗口函数(SUM()、 MIN()、 MAX()、 COUNT()等)
  • DISTINCT
  • GROUP BY
  • HAVING
  • UNION 或者 UNION ALL
  • 简单:视图不仅可以简化用户对数据的理解,也可以简化他们的操作。那些被经常使用的查询可以被定义为视图,从而使得用户不必为以后的操作每次指定全部的条件。
  • 安全:数据库可以授权,但不能授权到数据库特定行和特定的列上。通过视图用户只能查询和修改他们所能见到的数据。(保证敏感数据的安全性)
  • 数据独立:视图可帮助用户屏蔽真实表结构变化带来的影响。(当用户对数据库进行增加新的关系或添加新的字段等数据库重构行为时,会影响应用程序的运行。使用视图构造数据库重构之前的逻辑关系,可以保持用户应用程序不变,从而保持了数据逻辑独立性。)

数据准备:

1.6.1 案例1

为了保证数据库表的安全性,开发人员在操作表时,只能看到的用户的基本字段,屏蔽手机号和邮箱两个字段。

查看视图里面的数据:

1.6.2 案例2

查询每个学生所选修的课程(三张表联查),这个功能在很多的业务中都有使用到,为了简化操作,定义一个视图。

查看视图里面的数据:

到此这篇mysql主键和外键的建立关系(主键 mysql)的文章就介绍到这了,更多相关内容请继续浏览下面的相关推荐文章,希望大家都能在编程的领域有一番成就!

版权声明


相关文章:

  • sql循环函数(sql实现循环)2025-07-16 16:27:08
  • pymysql由于目标计算机积极拒绝(sqlserver由于目标计算机积极拒绝,无法连接)2025-07-16 16:27:08
  • mysql导入sql文件过大(mysql导入sql文件太慢)2025-07-16 16:27:08
  • pymysql连接池实现(pymysql连接sql server)2025-07-16 16:27:08
  • sql文件怎么写(sql文件怎么用)2025-07-16 16:27:08
  • 为什么用redis不用mysql(有redis为什么还要mq)2025-07-16 16:27:08
  • mysql自增主键和uuid(mysql自增主键缺点)2025-07-16 16:27:08
  • mysql主键查询慢(mysql查询慢查询)2025-07-16 16:27:08
  • mysql主键uuid(mysql主键重复怎么解决)2025-07-16 16:27:08
  • mysql导入sql文件跳过错误(mysql怎么导入sql文件错误)2025-07-16 16:27:08
  • 全屏图片