是否需要映射器接口

时间:2012-09-05 06:25:25

标签: ibatis mybatis

我是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和接口可能有很多具有相同名称的方法。

1 个答案:

答案 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匹配。 就是这样。