我是mybatis的新手,并关注mybatis3-user-guide.pdf。
我设置了我的第一个应用程序。
但是我发现我并不完全了解mapper界面。
到目前为止,这是我的应用程序的所有配置(以模型用户为例):
mybatis config.xml:
<configuration>
<typeAliases>
<typeAlias alias="User" type="com.king.mapper.User" />
</typeAliases>
<mappers>
<mapper resource="com/king/mapper/UserMapper.xml" />
</mappers>
</configuration>
UserMapper.xml:
<mapper namespace="com.king.mapper.UserMapper">
<select id="selectById" parameterType="int" resultMap="userMap">
select * from users where id = #{id}
</select>
<select id="selectAll" resultType="hashmap">
select * from users order by created_at desc
</select>
<insert id="insert" parameterType="User" useGeneratedKeys="true" keyProperty="id">
insert into users (name,created_at,updated_at) values (#{name},current_timestamp,current_timestamp)
</insert>
<update id="update" parameterType="User">
update users set name = #{name},updated_at=current_timestamp where id = #{id}
</update>
<delete id="delete" parameterType="int">
delete from users where id = #{id}
</delete>
<resultMap id="userMap" type="User">
<result property="createDate" column="created_at" />
<result property="updateDate" column="updated_at" />
</resultMap>
</mapper>
道:
public abstract class AbstractSimpleDaoImpl<T> extends SqlSessionDaoSupport implements IDao<T> {
@Override
public T query(int id) {
return getSqlSession().selectOne(getMapperNamespace() + ".selectById", id);
}
@Override
public List<T> list() {
return getSqlSession().selectList(getMapperNamespace() + ".selectAll");
}
@Override
public int add(T entity) {
return getSqlSession().insert(getMapperNamespace() + ".insert", entity);
}
@Override
public int update(T entity) {
return getSqlSession().update(getMapperNamespace() + ".update", entity);
}
@Override
public void delete(T entity) {
getSqlSession().delete(getMapperNamespace() + ".delete", entity);
}
protected abstract String getMapperNamespace();
}
userDAO的:
public class UserDao extends AbstractSimpleDaoImpl<User> {
private static String pack = "com.king.mapper.UserMapper";
@Override
protected String getMapperNamespace() {
return pack;
}
}
有效。但是我发现我的mybatis示例将引用mapper接口。
似乎我必须在上面的例子中创建一个名为UserMapper的接口。
但我想知道是否有必要?当我必须使用它时?
顺便说一句,在我看来,我发现mapper界面就像dao所做的一样。由于dao和接口可能有很多具有相同名称的方法。答案 0 :(得分:0)
您可以创建映射器接口UserMapper并避免在Dao对象上调用方法getSqlSession()....因此,使用mapper接口,您的xml配置保持不变,但您可以完全避免使用Dao对象。只需定义如下界面:
public interface UserMapper {
public List<User> selectAll();
public User selectById(@Param("id") int id);
// rest is ommited
}
方法名称必须与mapper文件中select / update / insert / detele的id匹配。 就是这样。