0

如何将DAO 层中的这些代码设置为GENERIC以避免代码冗余并在使用 Spring Web 开发的多种情况下有效地使用一组简单的代码?

项目信息道.xml

<select id = "getItem1" resultMap="resultItem1">
    SELECT item_id, name, area FROM item1
</select> 
<insert id="insertItem1">
    INSERT INTO item1 (item_id, name, area) 
         VALUES (#{itemId}, #{itemName}, #{itemArea})
</insert>
<select id = "getItem2" resultMap="resultItem2">
    SELECT item_id, name, area FROM item2
</select>
<insert id="insertItem2">
    INSERT INTO item2 (item_id, name, area) 
         VALUES (#{itemId}, #{itemName}, #{itemArea})
</insert>

ItemInfoDao.java

List<Package> getItem1(Package package);

void insertItem1(Package package );

List<Box> getItem2(Box box);

void insertItem2(Box box);
4

1 回答 1

1

使用 Spring-Data-JPA 避免简单的 DB CRUD 操作的样板代码。

您可以定义一个通用接口:

@NoRepositoryBean
public interface ItemDao<T> extends JpaRepository<T, Long> {
    T getItem(T input);

    void insertItem(T input);
}

Package 的具体实现将是:

public interface PackageDao extends ItemDao<Package> {

}

Box 的具体实现将是:

public interface BoxDao extends ItemDao<Box> {

}
于 2015-04-26T08:45:11.240 回答