如果当时这20道题能答好,现在应该已经被录取了(记一次面试的亲身经历 2020-8-27

二、数据库一般会采取什么样的优化方法?


1、选取适合的字段属性

  • 为了获取更好的性能,可以将表中的字段宽度设得尽可能小。

  • 尽量把字段设置成not null

  • 执行查询的时候,数据库不用去比较null值。

  • 对某些省份或者性别字段,将他们定义为enum类型,enum类型被当做数值型数据来处理,而数值型数据被处理起来的速度要比文本类型块很多。

2、使用join连接代替子查询

3、使用联合union来代替手动创建的临时表

注意:union用法中,两个select语句的字段类型要匹配,而且字段个数要相同。

4、事务

要么都成功,要么都失败。

可以保证数据库中数据的一致性和完整性。事务以begin开始,commit关键字结束。

如果出错,rollback命令可以将数据库恢复到begin开始之前的状态。

事务的另一个重要作用是当多个用户同时使用相同的数据源时,它可以利用锁定数据库的方式为用户提供一种安全的访问方式,这样就可以保证用户的操作不被其他的用户干扰。

5、锁定表

尽管事务是维护数据库完整性的一个非常好的方法,但却因为它的独占性,有时会影响数据库的性能,尤其是在大应用中。

由于在事务执行的过程中,数据库会被锁定,因此其它用户只能暂时等待直到事务结束。

有的时候可以用锁定表的方法来获得更好的性能,

共享锁:其它用户只能看,不能修改

lock table person in share mode;

对于通过lock table 命令主动添加的锁来说,如果要释放它们,只需发出rollback命令即可。

6、使用外键

锁定表的方法可以维护数据的完整性,但是它却不能保证数据的关联性,这个时候可以使用外键。

7、使用索引

索引是提高数据库查询速度的常用方法,尤其是查询语句中包含max()、min()、order by这些命令的时候,性能提高更为显著。

一般来说索引应该建在常用于join、where、order by的字段上。尽量不要对数据库中含有大量重复的值得字段建立索引。

8、优化的查询语句

在索引的字段上尽量不要使用函数进行操作。

尽量不要使用like关键字和通配符,这样做法很简单,但却是以牺牲性能为代价的。

避免在查询中进行自动类型转换,因为类型转换也会使索引失效。

三、项目中会有生产环境、测试环境等,问配置文件中该怎么配置


四、怎么的处理service的事务传播


[Spri 《一线大厂Java面试题解析+后端开发学习笔记+最新架构讲解视频+实战项目源码讲义》无偿开源 威信搜索公众号【编程进阶路】 ng事务传播机制详解](()

五、说一下事务的隔离级别


数据库事务的隔离级别有4种,由低到高分别为Read uncommitted 、Read committed 、Repeatable read 、Serializable 。

六、Object常用方法


getClass、equals、hashcode、clone、wait、notify、notifyAll、

七、在线人员统计


通过监听session对象的方式来实现在线人数的统计和在线人信息展示,并且让超时的自动销毁。

对session对象实现监听,首先必须继承HttpSessionListener类,该程序的基本原理就是当浏览器访问页面的时候必定会产生一个session对象,当关闭该页面的时候必然会删除session对象。所以每当产生一个新的session对象就让在线人数+1,当删除一个session对象就让在线人数-1。

还要继承一个HttpSessionAttributeListener,来实现对其属性的监听。分别实现attributeAdded方法,attributeReplace方法以及attributeRemove方法。

sessionCreated//新建一个会话的时候触发,也可以说是客户端第一次喝服务器交互时触发。

sessionDestroyed//销毁会话的时候,一般来说只有某个按钮触发进行销毁,或者配置定时销毁。

HttpSessionAttributeListener有三个方法需要实现

  • attributeAdded//在session中添加对象时触发此操作 笼统的说就是调用setAttribute这个方法时候会触发的

  • attributeRemoved//修改、删除session中添加对象时触发此操作  笼统的说就是调用 removeAttribute这个方法时候会触发的

  • attributeReplaced//在Session属性被重新设置时

八、单点登录


  1. cookie方式,线程不安全、不跨域

  2. jsonp方式,线程安全,不跨域

  3. 重定向方式,线程安全,跨域,较繁琐

九、项目时如何发布的


  1. IDEA打包成jar包

  2. cmd命令打包成jar包

  3. 通过java -jar target/service_edu.jar命令启动springboot启动类。

[【Spring Boot 21】Spring Boot 项目如何部署](()

十、Redis有哪些应用


  1. 用于缓存

  2. 高速读写场合,如秒杀,抢红包等高并发场景

十一、SpringMVC和SpringBoot的区别


  1. SpringMVC和SpringBoot都是Spring的衍生产品;

  2. Spring MVC是基于servlet的一个MVC框架,主要应用于web开发。

  3. Spring Boot解决的是Spring配置繁琐的问题,为简化开发而生;

十二、Spring IOC和AOP


IOC可以称为控制反转或依赖注入,通过引入IOC容器,利用依赖注入的方式,实现对象之间的解耦。

AOP是面向切面编程,在不改变原有逻辑的基础上,增加一些额外功能。

AOP适用于解决日志、事务、权限方面的问题,这种散布在各处的无关的代码称为横切,在OOP的设计中,它导致了大量代码的重复,而不利于各个模块的重用。

AOP是面向切面编程,将影响多个类的共同行为封装到一个可重用的模块,并将其命名为“Aspect”,即切面。

关于切面是将那些与业务无关,却被业务模块所共同调用的逻辑或责任封装起来,便于减少系统的重复代码,降低模块间的耦合度,并有利于未来的可操作性和可维护性。

十三、beanFactory和factoryBean的区别


beanFactory是Spring关于容器的父接口,用来管理bean的接口,管理bean的注入和销毁;

factoryBean是Spring用来对beanFactory中的bean进行修饰的类,相当于装饰器模式;

十四、springboot项目中分为哪几个模块


  1. 公共方法模块

  2. 人员基本信息系统

  3. 安全监控模块

  4. 应急广播模块

  5. gis地图模块

  6. 视频监控模块

  7. 统计模块

十五、JSP取值的方式


  1. 通过表单提交,前台往后台传值,在后台使用set,get方法,可以直接获取。如果通过request.getParameter(paramName)去获取前台传过来的请求参数值。有name属性的表单才会生成请求参数,如果某个表单设置了disable=“disabled”,则该表单不会生成请求参数。

  2. EL表达式${param}

  3. jsp输出表达式 :

① 参数:<%=request.getParameter(paramName)%>

② 属性值:<%=request.getAttribute(“attributeName”)%>

十六、分页sql


无排序的版本:

SELECT * FROM (SELECT rownum AS rowno,w.* FROM ct_worker w WHERE rownum <=20) worker WHERE worker.rowno>10

有排序的版本:

SELECT * FROM (SELECT rownum AS rowno,w.* FROM (SELECT ctw.* FROM CT_WORKER ctw ORDER BY capid desc) w WHERE rownum <=20) worker WHERE worker.rowno>10

十七、分组sql


where使用在group by之前,where子句不能有分组函数;

group by 进行分组,having进行分组之后的过滤,having中可以使用聚合函数;

select t1.name 学生姓名,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值