1.事务传播属性

# propagation: 传播
		REQUIRED:       需要事务,外部存在事务融入当前事务,外部没有事务,开启新的事务
		SUPPORTS:       支持事务,外部存在事务融入当前事务,外部没有事务,不开启新的事务
		REQUIRES_NEW:   每次开启新的事务,如果外部存在事务外部事务挂起,开启新的事务运行,运行结束后回复外部事务
		NOT_SUPPORTED:  不支持事务,如果外部存在事务外部事务挂起,已非事务方式运行.
		NEVER:	        不支持事务,存在事务报错
		MANDATORY:      强制事务没有事务报错
		NESTED:	        嵌套事务,数据库不支持

2.事务的隔离级别

# isolation 隔离级别
	
	DEFAULT:           采用数据库默认隔离级别
	READ_UNCOMMITTED:  读未提交 
	READ_COMMITTED:    读提交 用来避免脏读现象出现的   oracle默认隔离级别
	REPEATABLE_READ:   可重复读主要是用来避免不可重复读现象出现的 (在一次事务中一方更新,导致两次查询结果不一致这种情况叫不可重复读)  mysql默认隔离级别
	SERIALIZABLE:      序列化读 用来避免幻影读现象出现          (在一次事务中一方插入,导致两次查询结果不一致这种情况叫幻影读)

3.读写和异常性

# readonly 
   true:    本次事务只读
   false:   本次事务非只读
   <tx:method name="save*" propagation="REQUIRES_NEW" read-only="true|false" isolation="SERIALIZABLE"/>
	
# rollback-for && no-rollback-for=""
	rollback-for: 遇到什么类异常回滚
	no-rollback-for: 遇到什么类异常不回滚
   	<tx:method name="save*" rollback-for="" no-rollback-for="" propagation="REQUIRES_NEW" read-only="true" isolation="SERIALIZABLE"/>

# timeout 超时性
        timeout: -1 永不超时