SpringMVC+JPA(上)

本文介绍了一种使用SpringMVC与JPA相结合的技术方案,涵盖了实体类定义、DAO层实现、Service业务逻辑处理及Controller层的具体实现。通过示例代码展示了如何进行增删改查操作,并提供了自定义SQL及分页功能的实现方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

SpringMVC+JPA


  • PO
@Entity
@Table(name = "TABLE_NAME")
@SequenceGenerator(name = "SEQ_ALIAS_NAME",sequenceName =
"SEQ_Name",allocationSize = 1)
    @Id
    @Column(name = "COLUMN_NAME")
    @GeneratedValue(strategy = GenerationType.SEQUENCE,generator = "SEQ_ALIAS_NAME")

  • DAO
//DAO
public interface DAO extends JpaRepository<PO,Serializable>,DAOCustom {
...
}
//DAO扩展接口
public interface DAOCustom {
...
}
//实现类
@Repository
public class DAOImpl implements DAOCustom {

    @PersistenceContext(unitName = "fpsUnit")
    protected EntityManager entityManager;
    //insert delete update
    public void updateInfo(){
            String sql = "";
            Query query = entityManager.createNativeQuery(sql);
            query.executeUpdate();
    }
    //自定义sql+分页
    public List<PO> getListBySQL(Integer start,Integer end){
                return (new AbstractPagingQuery<TrackMoneyConfirmVO>(entityManager) {
            @Override
            public String getQuerySql() {
                String sql = "";
                return sql;
            }
        }).getData(start,end);

    }
    ...
}

  • Service
@Service
public class TrackMoneyConfirmService {

    @Inject
    private DAO DAO;

    @Transactional(value = "transactionManagerName")
    public void update(){
    DAO.update()
    }
}

  • Controller
@controller
public class IndexController{
    @Inject
    private Service service;
    //普通get请求
    @RequestMapping(value="/URL",method = RequestMethod.GET)
    public String toIndex(Model model,HttpServletReqest request){
        return "index";
    }
    //post请求 返回json串
    @RequestMapping(value = "/url",method= RequestMethod.POST,produces="text/html;charset=UTF-8")
    @ResponseBody
    public String returnJSON(){
        return "JSON.......";
    }
    //从url获取参数
    @RequestMapping(value = "/url/{argName0}/{argName1}")
    public String downloadPDF(@PathVariable Long argName0, @PathVariable String argName1, HttpServletResponse response, ModelMap model) {
}

  • 从properties文件中取值
    @Value("${propertyName}")
    private Long xxx;

配置文件在下篇博客中贴出来

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值