【前言】别人都在你看不到的地方暗自努力,在你看获得的地方,他们也和你同样显得不务正业,和你同样会抱怨,而只有你本身相信这些都是真的,最后,也只有你一我的继续不思进取 …… java
【下载】我的结合诸多资料,总结的一些JavaEE常见面试题,主要针对初/中级程序员。想要word完整版下载的,评论里留言留下你的邮箱!mysql
51.事务的特性?程序员
答:①原子性(Atomicity)面试
指事务是一个不可分割的工做单位,事务中的操做要么全都发生,要么全不发生;sql
②一致性(Consistency)数据库
事务先后数据的完成性必须保持一致;(例:转帐先后的,两我的的金额总数是不变的)api
③隔离性(Isolation)session
指多个用户并发访问数据库时,一个用户的事务不能被其余用户的事务干扰,多个并发事务之间要项目隔离;并发
④持久性(Durability)oracle
指一个事务一旦被提交,它对数据库中数据的改变是永久性的,接下来即便数据库发生故障,也不该该对其有任何影响;
52.事务并发访问的问题?
答:①脏读:一个事务读到了另外一个事务未提交的数据;
②不可重复读:在同一个事务中,屡次查询的结果不一致(由update引发的)
③虚读/幻读:在同一个事务中,屡次查询的结果不一致(由insert引发的)
53.隔离的级别?
答:①读未提交
read uncommitted;一个事务读到另外一个事务没有提交的数据;
(未解决,3问题都存在)
②读已提交 —— oracle默认
read committed;一个事务读到另外一个事务已提交的数据;
(解决脏读)
③可重复读 --- mysql默认
repeatable read;在一个事务中读到的数据始终保持一致,不管另外一个事务是否提交
(解决脏读和不可重复读)
④串行化
serializable 串行化,同时只能执行一个事务,至关于单线程事务;
(都解决)
54.tuncate和delete区别?
答:① truncate数据ddl delete属于dml
② truncate是先删除drop该表,再create该表。并且没法回滚!!!
55.在Hibernate中实现数据检索的5种方式?
答:① 对象导航(关联级别的数据检索)
② HQL语句
③ SQL语句
④ QBC语句
⑤ 经过OID加载(get( ) / load( ))
56.Cascade与Inverse区别?
答:①Cascade主要用于级联操做(如:级联添加,删除等);
②Inverse主要用于控制权是否要反转,通常将控制权放在多方,能够提升效率;
如:当删除部门时,级联删除部门下的全部用户。
若inverse = “false” 默认值,能够不配
控制台输出3条语句:
Update user set deptId = null where deptId = 1;//解决父子关系
Delete from user where deptId is null; //先干掉子类
Delete from user where id=1; //再自杀
若inverse = “true” 表明控制权要反转,交给多方维护,相率会提升;
控制台输出2条语句:
Delete from user where deptId=1; //自杀
Delete from user where id=1;//自杀
57.PO类的定义规范?
答:①是一个共有类;
②提供无参共有构造方法;
③属性是私有的;
④为私有属性提供共有的getter/setter;
⑤不能使用final修饰;
⑥能够实现java.io.Serializbale接口;
⑦若是是基本类型,须要使用它的包装类;
58.请分别写出一对一,一对多,多对一,多对多的PO类映射文件?
59.抽取BaseAction的理由?
答:①经过实现RequestAware、SessionAware、ApplicationAware接口,自定义protected Map<String,Object> request/session/application,并提供getter方法,继承setter方法,此时再编写Action类时,依赖的是本身的API,未来框架升级改造时,只要修改BaseAction就能够了,能够更好的实现与Struts2的解耦合;
②能够在BaseAction中抽取一些公共的操做方法;
60.XML文档定义有几种形式?它们之间有何本质区别?解析XML文档有哪几种方式?
答:(1)XML文档有两种约束方式:DTD约束和Schema约束;
(2)区别:
①DTD不符合XML的语法结构,schema符合XML的语法结构;
②DTD的约束扩展性比较差,XML文档只能引入一个DTD的文件。schema能够引入多个文件;
③DTD不支持名称空间(理解包结构),schema支持名称空间;
④DTD支持数据比较少,schema支持更多的数据类型;
(3)解析方式主要有三种:
①DOM解析:
(a)加载整个xml的文档到内存中,造成树状结构,生成对象;
(b)容易产生内存溢出;
(c)能够作增删改;
②SAX解析
(a)边读边解析;
(b)不能够作增删改;
③ DOM4J解析(hibernate底层采用)
(a)可以让SAX解析也产生树状结构。
(b)主要api开发步骤:
1)SAXReader.read(xxx.xml)表明解析xml的文档,返回对象是Document;
2)Document.getRootElement(),返回的是文档的根节点,是Element对象;
3)Element:
.element(...) -- 得到指定名称第一个子元素。能够不指定名称;
.elements(...) -- 得到指定名称的全部子元素。能够不指定名称;
.getText() -- 得到当前元素的文本内容;
.elementText(...) -- 得到指定名称子元素的文本值
.addElement() -- 添加子节点
.setText() -- 设置子标签内容
4)XMLWriter.write("..") --写出
5)XMLWriter.close() --关闭输出流
61.大家项目为何选用maven进行构建?
答:①首先,maven是一个优秀的项目构建工具。使用maven,能够很方便的对项目进行分模块构建,这样在开发和测试打包部署时,效率会提升不少。
②其次,maven能够进行依赖的管理。使用maven,能够将不一样系统的依赖进行统一管理,而且能够进行依赖之间的传递和继承。