日期:2014-05-16  浏览次数:20583 次

急急急 急急急 SpringJDBC 声明式事物不回滚 求大家帮忙看看
basedao

public class BaseDao<T, PK extends Serializable> extends JdbcDaoSupport{

/**
* 添加 ,属性和数据库字段名一致,返回主键
* @param objForSave ,继承Saveable 的接口的类
* @return
*/
public Number saveAndReturnKey(Saveable objForSave){
return saveAndReturnKey(objForSave, objForSave.getTableName(), objForSave.getKeyColumns());
}

/**
* 添加实体,返回主键
* @param objForSave
* @param tableName
* @param columnAndValue
* @param keyColumns
* @return
*/
public Number saveAndReturnKey(Object objForSave,String tableName,String...keyColumns){
SimpleJdbcInsert insertActor =   getSimpleJdbcInsert();
insertActor.setTableName(tableName);
insertActor.usingGeneratedKeyColumns(keyColumns);
Number newId = insertActor.executeAndReturnKey(new BeanPropertySqlParameterSource(objForSave)) ;
traceSql(insertActor.getInsertString());
return newId;
}
   * 更新数据的方法
   * @param sql
   * @param T entity
*/ 
public void update(String sql,T entity){ 
    getJdbcTemplate().update(sql,entity);



}



@Repository("userMgrDao")
@SuppressWarnings("unchecked")
public class UserMgrDao extends BaseDao{

//添加一个用户
public Users addUser(final Users users){
  users.setId(saveAndReturnKey(users).intValue());
  return users;
}
/**
   * 删除数据的方法
   * @param id
   */ 
  public void delete(String id){ 
    String sql = "delete from users where id=?"; 
    update(sql, id); 
  } 

}


@Service("userMgrService")
@Transactional
public class UserMgrService extends BaseService implements IUserMgrService{
public UserMgrService(){

}
private static Logger logger = Logger.getLogger(UserMgrService.class);

@Autowired
private UserMgrDao userMgrDao;
  @Transactional(rollbackFor=Throwable.class)
public void save(Users user) throws ServiceException {
    try {
user.setImportdate(new Date());
user.setFast(1L);
user.setUpdatedate(new Date());
user.setImportuserid(1L);
user.setUpdateuserid(1L);
userMgrDao.addUser(user);
}catch (Exception e) {
throw new ServiceException("获取失败", e);
}

}

@Transactional(propagation=Propagation.REQUIRED,isolation=Isolation.READ_COMMITTED)
public  void delete(String id){
try {
    userMgrDao.delete(id);
} catch (Exception e) {
logger.error(e);
}
}

}

applicationContext.xml 
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:p="http://www.springframework.org/schema/p"
xmlns:context="http://www.springframework.org/schema/context"
xmlns:aop="http://www.springframework.org/schema/aop"
    xmlns:tx="http://www.springframework.org/schema/tx"
xsi:schemaLocation="http://www.springframework.org/schema/beans  
           http://www.springframework.org/schema/beans/spring-beans-3.0.xsd 
           http://www.springframework.org/schema/context  
           http://www.springframework.org/schema/context/spring-context-3.0.xsd
           http://www.springframework