那些年,到处刮起了业务处理分层的大风,无论何时何地,都有某MVC框架、Spring管理的Service、以及iBatis和Hibernate等代表的DAO,SSH、SSI等成了标准。然而,我们仔细研究这些代码时,真得很有必要么?
其一,DAO的实现,以Hibernate为例,UserDAO.create(User user),其中user可以是有很多属性的,但在这个方法中,我们传入的是一个user对象,很多属性提供给后来者并不清晰,哪些是必须的,又哪些是可选的。
其二,DAO的最后使用,基本上有DAO的地方都有Service,似乎DAO是被Service代理了,类似代码:
UserService.create(User user) {UserDAO.cerate(user);};
在上面的这些场景,甚至更多的场景,DAO作为一层完全没有必要,作为Service的一个辅助实现才是最佳的处理手段。
在flying中,DAO不再是一独立的层,通过声明的DAO注解和Param注解,在运行时,完成DAO处理,代码如下:
@Service("UserService")
public class UserService extends AbstractService{
@DaoCreate(entity="security.user")
public Data create(
@Param(value="username", required=true)String username,
@Param(value="password",required=true)String password,
@Param(value="org_name",required=true)String org_name,
@Param(value="real_name",required=true)String real_name) throws Exception {
return null;
}
@DaoUpdate(entity="security.user")
public Data update(
@Param(value="org_name",required=true)String org_name,
@Param(value="real_name",required=true)String real_name,
@Param(value="user_id",required=true)long user_id) throws Exception {
return null;
}
@DaoUpdate(entity="security.user")
public Data changePassword(
@Param(value="password",required=true)String password,
@Param(value="user_id",required=true)long user_id) throws Exception {
return null;
}
@DaoRemove(entity="security.user")
public Data remove(
@Param(value="user_id",required=true)long user_id) throws Exception {
return null;
}
@DaoRemove(entity="security.user")
public Data removeByUsername(
@Param(value="username",required=true)String username) throws Exception {
return null;
}
@DaoQuery(single=true, entity="security.user.perms")
public Data findByUsernamePassword(@Param(value="username",required=true)String username,
@Param(value="password",required=true)String password) throws Exception {
return null;
}
}
对于DaoCreate,运行时会根据entity属性生成对应的insert语句,并使用参数中的值完成sql执行。
实现原理:运行时,服务消费者调用服务方法,服务执行引擎解析服务方法相关的注解,并提取相关的服务参数,使用服务参数以及注解相关的参数拼装sql,如insert 的sql,并在jdbcTemplate中完成执行。
对于DaoCreate,所有的方法参数均是insert xx values(?,?)中的参数,其他的细节欢迎参加技术讨论群讨论。
框架源码:https://github.com/hifong/flying
Demo应用:https://github.com/hifong/pas
技术QQ群:455852142