视图的作用是什么?有哪些好处?(面试题)

视图(子查询):是从一个或多个表导出的虚拟的表,其内容由查询定义。具有普通表的结构,但是不实现数据存储。

对视图的修改:单表视图一般用于查询和修改,会改变基本表的数据,

多表视图一般用于查询,不会改变基本表的数据。

作用

简化了操作,把经常使用的数据定义为视图。

我们在使用查询时,在很多时候我们要使用聚合函数,同时还要 显示其它字段的信息,可能还会需要关联到其它表,这时写的语句可能会很长,如果这个动作频繁发生的话,我们可以创建视图,这以后,我们只需要select * from view就可以啦,这样很方便。

安全性,用户只能查询和修改能看到的数据。

因为视图是虚拟的,物理上是不存在的,只是存储了数据的集合,我们可以将基表中重要的字段信息,可以不通过视图给用户,视图是动态的数据的集合,数据是随着基表的更新而更新。同时,用户对视图不可以随意的更改和删除,可以保证数据的安全性。

逻辑上的独立性,屏蔽了真实表的结构带来的影响。

视图可以使应用程序和数据库表在一定程度上独立。如果没有视图,应用一定是建立在表上的。有了视图之后,程序可以建立在视图之上,从而程序与数据库表被视图分割开来。

缺点:

性能差

数据库必须把视图查询转化成对基本表的查询,如果这个视图是由一个复杂的多表查询所定义,那么,即使是视图的一个简单查询,数据库也要把它变成一个复杂的结合体,需要花费一定的时间。

修改限制

当用户试图修改视图的某些信息时,数据库必须把它转化为对基本表的某些信息的修改,对于简单的视图来说,这是很方便的,但是,对于比较复杂的试图,可能是不可修改的。

作用

简化了操作,把经常使用的数据定义为视图。

安全性,用户只能查询和修改能看到的数据。

逻辑上的独立性,屏蔽了真实表的结构带来的影响。

以往当我们查询数据时,一定要很认真的地从设计select语句开始,将需要查询的每个字段写在sql语句里,每次你要以同样的条件来查询数据时,那么每次都要重复输入相同的查询语句,效率很低。若将这个经常要重复使用的查询语句创建成视图,就不用那么麻烦了!直接用select * from 视图名就行了,其实将查询语句创建成视图,不仅仅是简化查询的动作;更重要的是,视图具备数据表的特性,还可以衍生出更多的应用。

所谓视图(View)其实是执行查询语句后得到的结果,但这个查询结果可以仿真成数据表来使用,所以有人也称它为“虚拟数据表”,视图在操作上和数据表没有什么区别,但两者的差异是其本质是不同的:数据表是实际存储记录的地方,然而视图并不保存任何记录,它存储的实际上是查询语句,其所呈现出来的记录实际来自于数据表,可以为多张数据表,大家由此可以预见到视图应用的弹性!我们可以依据各种查询需要创建不同视图,但不会因此而增加数据库的数据量。

下面总结视图的几大优点:1.增强可读性 2.数据安全及保密:针对不同用户,可以创建不同视图,限制其所能浏览和编辑的数据内容。3.降低查询复杂度 4.方便维护

  • 2
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是一些常见的 Spring 面试题以及回答建议: 1. 什么是 Spring?Spring 的优点有哪些? 回答建议:Spring 是一个轻量级的开源框架,用于构建企业级应用程序。它提供了一种依赖注入和面向切面编程的方式,使得应用程序开发更简单和更容易测试,并且提供了很多现成的模块,如数据访问、Web开发等。Spring 的优点包括:简化应用程序开发、提高应用程序的可测试性、提高应用程序的可扩展性和可维护性、提高代码的重用性等等。 2. Spring 的核心模块是哪些?它们各自的功能是什么? 回答建议:Spring 的核心模块包括:Spring Core、Spring Context、Spring AOP、Spring DAO、Spring ORM、Spring Web、Spring MVC、Spring Web Services 等。Spring Core 模块是 Spring 框架的核心,提供了 Spring 框架的基本功能,如依赖注入、控制反转等。Spring Context 模块是 Spring 框架的上下文,提供了 Spring 应用程序中的所有对象的访问点。Spring AOP 模块提供了面向切面编程的支持。Spring DAO 模块为数据访问提供了支持。Spring ORM 模块为对象关系映射提供了支持。Spring Web 模块为 Web 应用程序开发提供了支持。Spring MVC 模块是 Spring 框架的 MVC 框架。Spring Web Services 模块为 Web 服务开发提供了支持。 3. Spring 中 Bean 是什么?Bean 的作用域有哪些? 回答建议:在 Spring 中,Bean 是一个由 Spring IOC 容器管理的对象。Bean 可以是任何一个 Java 对象,如 POJO、Service、DAO、Entity 等。Bean 的作用域有五种:Singleton、Prototype、Request、Session 和 Global Session。Singleton 作用域表示在整个应用程序中只有一个 Bean 实例。Prototype 作用域表示每次从容器中获取 Bean 时都会创建一个新的实例。Request 作用域表示在一次 HTTP 请求中只有一个 Bean 实例。Session 作用域表示在一个 HTTP Session 中只有一个 Bean 实例。Global Session 作用域表示在一个全局的 HTTP Session 中只有一个 Bean 实例。 4. Spring 中的依赖注入是什么?有哪些方式可以实现依赖注入? 回答建议:依赖注入是 Spring 的一个核心特性,它允许我们将对象之间的依赖关系从代码中分离出来,交给 Spring IOC 容器处理。Spring 中有三种方式实现依赖注入:构造方法注入、Setter 方法注入和接口注入。构造方法注入是通过构造方法来注入依赖项。Setter 方法注入是通过 Setter 方法来注入依赖项。接口注入是通过实现一个特定的接口来注入依赖项。 5. Spring AOP 是什么?它的作用是什么?它的实现方式有哪些? 回答建议:Spring AOP 是 Spring 框架中的一个模块,它提供了面向切面编程的支持。AOP 的作用是将应用程序的横切关注点(如日志、事务、安全等)从应用程序主体中分离出来,并将它们封装成可重用的模块。Spring AOP 的实现方式有两种:使用 JDK 动态代理和使用 CGLIB(Code Generation Library)动态代理。 6. Spring 中的事务管理是如何实现的? 回答建议:Spring 中的事务管理是通过 Spring 的事务管理器来实现的。Spring 的事务管理器是一个用于管理事务的对象,它提供了一系列的方法来控制事务的提交和回滚。Spring 支持编程式事务管理和声明式事务管理。编程式事务管理是通过编写代码来控制事务的提交和回滚。声明式事务管理是通过配置文件来控制事务的提交和回滚。 7. Spring MVC 的工作原理是什么?它的核心组件有哪些? 回答建议:Spring MVC 是一个基于 MVC(Model-View-Controller)架构的 Web 框架,它提供了一种简单和易于使用的方式来创建 Web 应用程序。Spring MVC 的工作原理是:当用户发送请求时,请求将被控制器接收,控制器将调用模型来处理请求,并将处理结果返回给视图。Spring MVC 的核心组件包括:DispatcherServlet、HandlerMapping、Controller、ViewResolver 等。 8. Spring Boot 是什么?它的优点有哪些?如何使用 Spring Boot 创建一个 Web 应用程序? 回答建议:Spring Boot 是一个用于构建现代化 Web 应用程序的框架,它提供了一种简单和易于使用的方式来创建、配置和部署应用程序。Spring Boot 的优点包括:快速构建应用程序、自动配置应用程序、提供现成的模块、易于部署和维护等。使用 Spring Boot 创建一个 Web 应用程序的步骤如下:创建一个 Spring Boot 项目、添加 Web 依赖项、创建一个控制器、创建一个视图、运行应用程序。 9. Spring Cloud 是什么?它的主要组件有哪些? 回答建议:Spring Cloud 是一个用于构建分布式系统的框架,它提供了一系列的组件来帮助开发人员构建和部署分布式应用程序。Spring Cloud 的主要组件包括:服务注册与发现、负载均衡、断路器、配置中心、消息总线等。 10. Spring Security 是什么?它的作用是什么?它的常见使用场景有哪些? 回答建议:Spring Security 是一个用于保护 Web 应用程序安全的框架,它提供了一种简单和易于使用的方式来实现身份验证、授权和其他安全功能。Spring Security 的作用是保护 Web 应用程序免受各种安全攻击,如跨站点脚本、SQL 注入、会话劫持等。Spring Security 的常见使用场景包括:基于角色的访问控制、基于资源的访问控制、单点登录等。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值