每天一点面试题

一:用两种方式根据门号从高到低,工资从低到高列出每个员工的信息:

employee:

    eid,ename,salary,deptid

select * from employee order by deptid desc,salary asc;

 select eid,ename,salary,deptid,from employee orderby deptid desc,salary asc;

 

二:propagation定义的7个事务传播行为:

 

 1).REQUIRED(required):如果存在一个事物,则支持当前事务。如果没有事务则开启一个新的事物

 

2).SUPPORTS(supports):如果存在一个事物,则支持当前事务。如果没有事务,则非事务的执行。但对于事务同步的事务管理器,SUPPORTS与不使用事务有少许的不同。

 

3).REQUIRES_NEW(requires_new):总是开启一个新的事物。如果一个事物已经存在,则将这个事务挂起。

 

4).NOT_SUPPORTS(not_supports):总是非事务的执行,并挂起任何存在的事务。

 

5).NEVER(never):总是非事务的执行,如果存在一个活动事务,则抛出异常

 

  NESTED(nested):如果一个活动事物存在,则运行在一个嵌套事务中,如果没有活动事务,则按TransactionDefinition.PROPAGATION_REQUIRED属性执行。

 

  嵌套事务一个非常重要的概念就是内层事务依赖于外层事务。外层事务失败时,会回滚内层事务所做的动作。而内层事务操作失败并不会引起外层事务的回滚。

 

  REQUIRED应该是我们首先的事务传播行为。他能满足我们大多数的事务需求

三:isolation设定事务的隔离级别,事务管理器根据它来控制另外一个事务可以看到本事务内的那些数据定义的5个不同的事务隔离级别:

 

1. ISOLATION_DEFAULT(一般情况下使用这种配置既可)

 

这是一个PlatfromTransactionManager默认的隔离级别,使用数据库默认的事务隔离级别。

 

2. ISOLATION_READ_UNCOMMITTED

 

这是事务最低的隔离级别,它充许别外一个事务可以看到这个事务未提交的数据。这种隔离级别会产生脏读,不可重复读和幻像读。

 

(大部分数据库缺省的事物隔离级别都不会出现这种状况)

 

3. ISOLATION_READ_COMMITTED  

 

保证一个事务修改的数据提交后才能被另外一个事务读取。另外一个事务不能读取该事务未提交的数据。这种事务隔离级别可以避免脏读出现,但是可能会出现不可重复读和幻像读。

 

什么是脏读?

 

例如:

 

张三的工资为5000,事务A中把他的工资改为8000,但事务A尚未提交。

 

与此同时,

 

事务B正在读取张三的工资,读取到张三的工资为8000。

 

随后,

 

事务A发生异常,而回滚了事务。张三的工资又回滚为5000。

 

最后,

 

事务B读取到的张三工资为8000的数据即为脏数据,事务B做了一次脏读。

 

(大部分数据库缺省的事物隔离级别都不会出现这种状况)

 

4. ISOLATION_REPEATABLE_READ  

 

这种事务隔离级别可以防止脏读,不可重复读。但是可能出现幻像读。

 

什么是不可重复读?

 

例如:

 

在事务A中,读取到张三的工资为5000,操作没有完成,事务还没提交。

 

与此同时,

 

事务B把张三的工资改为8000,并提交了事务。

 

随后,

 

在事务A中,再次读取张三的工资,此时工资变为8000。在一个事务中前后两次读取的结果并不致,导致了不可重复读。

 

(大部分数据库缺省的事物隔离级别都不会出现这种状况)

 

5. ISOLATION_SERIALIZABLE

 

这是花费最高代价但是最可靠的事务隔离级别。事务被处理为顺序执行。除了防止脏读,不可重复读外,还避免了幻读。

 

什么是幻读?

 

例如:

 

目前工资为5000的员工有10人,事务A读取所有工资为5000的人数为10人。

 

此时,

 

事务B插入一条工资也为5000的记录。

 

这是,事务A再次读取工资为5000的员工,记录为11人。此时产生了幻读。

 

(大部分数据库缺省的事物隔离级别都会出现这种状况,此种事物隔离级别将带来表级锁)

 

 

四:spring事务是如何配置的:

    Spring有编程式事务和声明式事务

    

五:spring是什么?

 

六:项目中如何体现spring中的切面编程,举例说明:

 

面向切面编程:主要是横切一个关注点,将一个关注点模块化成一个切面。在切面上声明一个通知(advice)和切入点(Pointcut);通知:是指在切面的某个特定的连接点(代表一个方法的执行。通过声明一个org.aspectj.lang.JoinPoint类型的参数可以使通知Advice的主体部分获得连结点信息。)上执行的动作。通知中定义了要插入的方法。切入点:切入点的内容是一个表达式,以描述需要在哪些对象的哪些方法上插入通知中定义的方法。

 

 

 

项目中用到的spring中的切面编程最多的地方:声明式事务管理。

 

 

 

a、定义一个事务管理器

 

 

 

b、配置事务特征(相当于声明通知。一般在业务层的类的一些方法上定义事务)

 

 

 

c、配置哪些类的哪些方法需要配置事务(相当于切入点。一般是业务类的方法上)

 

posted @ 2017-08-28 10:25  会飞的豆子  阅读(158)  评论(0编辑  收藏  举报