{"id":10566,"date":"2025-04-18T18:02:59","date_gmt":"2025-04-18T10:02:59","guid":{"rendered":"https:\/\/www.wsisp.com\/helps\/10566.html"},"modified":"2025-04-18T18:02:59","modified_gmt":"2025-04-18T10:02:59","slug":"springdatajpa%ef%bc%88%e4%b8%89%ef%bc%89%ef%bc%9a%e5%a4%9a%e8%a1%a8%e6%93%8d%e4%bd%9c%ef%bc%8c%e5%a4%8d%e6%9d%82%e6%9f%a5%e8%af%a2","status":"publish","type":"post","link":"https:\/\/www.wsisp.com\/helps\/10566.html","title":{"rendered":"SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2"},"content":{"rendered":"<h4>\u4e00\u3001Specifications\u52a8\u6001\u67e5\u8be2<\/h4>\n<p>\u6709\u65f6\u6211\u4eec\u5728\u67e5\u8be2\u67d0\u4e2a\u5b9e\u4f53\u7684\u65f6\u5019&#xff0c;\u7ed9\u5b9a\u7684\u6761\u4ef6\u662f\u4e0d\u56fa\u5b9a\u7684&#xff0c;\u8fd9\u65f6\u5c31\u9700\u8981\u52a8\u6001\u6784\u5efa\u76f8\u5e94\u7684\u67e5\u8be2\u8bed\u53e5&#xff0c;\u5728Spring Data JPA\u4e2d\u53ef\u4ee5\u901a\u8fc7JpaSpecificationExecutor\u63a5\u53e3\u67e5\u8be2\u3002\u76f8\u6bd4JPQL,\u5176\u4f18\u52bf\u662f\u7c7b\u578b\u5b89\u5168,\u66f4\u52a0\u7684\u9762\u5411\u5bf9\u8c61\u3002<\/p>\n<p>import java.util.List;<\/p>\n<p>import org.springframework.data.domain.Page;<br \/>\nimport org.springframework.data.domain.Pageable;<br \/>\nimport org.springframework.data.domain.Sort;<br \/>\nimport org.springframework.data.jpa.domain.Specification;<\/p>\n<p>\/**<br \/>\n *JpaSpecificationExecutor\u4e2d\u5b9a\u4e49\u7684\u65b9\u6cd5\u5217\u8868<br \/>\n **\/<br \/>\n public interface JpaSpecificationExecutor&lt;T&gt; {<br \/>\n   \/\/ \u6839\u636e\u6761\u4ef6\u67e5\u8be2\u4e00\u4e2a\u5bf9\u8c61<br \/>\n T findOne(Specification&lt;T&gt; spec);<br \/>\n   \/\/ \u6839\u636e\u6761\u4ef6\u67e5\u8be2\u96c6\u5408<br \/>\n List&lt;T&gt; findAll(Specification&lt;T&gt; spec);<br \/>\n   \/\/ \u6839\u636e\u6761\u4ef6\u5206\u9875\u67e5\u8be2<br \/>\n Page&lt;T&gt; findAll(Specification&lt;T&gt; spec, Pageable pageable);<br \/>\n   \/\/ \u6392\u5e8f\u67e5\u8be2<br \/>\n List&lt;T&gt; findAll(Specification&lt;T&gt; spec, Sort sort);<br \/>\n   \/\/ \u7edf\u8ba1\u67e5\u8be2<br \/>\n long count(Specification&lt;T&gt; spec);<br \/>\n}<\/p>\n<p>\u5bf9\u4e8eJpaSpecificationExecutor&#xff0c;\u8fd9\u4e2a\u63a5\u53e3\u57fa\u672c\u662f\u56f4\u7ed5\u7740Specification\u63a5\u53e3\u6765\u5b9a\u4e49\u7684\u3002\u6211\u4eec\u53ef\u4ee5\u7b80\u5355\u7684\u7406\u89e3\u4e3a&#xff0c;Specification\u6784\u9020\u7684\u5c31\u662f\u67e5\u8be2\u6761\u4ef6\u3002<\/p>\n<p>Specification\u63a5\u53e3\u4e2d\u53ea\u5b9a\u4e49\u4e86\u5982\u4e0b\u4e00\u4e2a\u65b9\u6cd5&#xff1a;<\/p>\n<p> \/\/\u6784\u9020\u67e5\u8be2\u6761\u4ef6<br \/>\n    \/**<br \/>\n    *root&#xff1a;Root\u63a5\u53e3&#xff0c;\u4ee3\u8868\u67e5\u8be2\u7684\u6839\u5bf9\u8c61&#xff0c;\u53ef\u4ee5\u901a\u8fc7root\u83b7\u53d6\u5b9e\u4f53\u4e2d\u7684\u5c5e\u6027<br \/>\n    *query&#xff1a;\u4ee3\u8868\u4e00\u4e2a\u9876\u5c42\u67e5\u8be2\u5bf9\u8c61&#xff0c;\u7528\u6765\u81ea\u5b9a\u4e49\u67e5\u8be2\u65b9\u5f0f&#xff08;\u4e00\u822c\u4e0d\u7528&#xff09;<br \/>\n    *cb&#xff1a;\u7528\u6765\u6784\u5efa\u67e5\u8be2&#xff0c;\u6b64\u5bf9\u8c61\u91cc\u5c01\u88c5\u6709\u5f88\u591a\u67e5\u8be2\u6761\u4ef6\u65b9\u6cd5<br \/>\n    **\/<br \/>\n    public Predicate toPredicate(Root&lt;T&gt; root, CriteriaQuery&lt;?&gt; query, CriteriaBuilder cb);<\/p>\n<h5>\u6817\u5b50<\/h5>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\dao\\\\CustomerDao.java&#xff1a;<\/p>\n<p>package top.onefine.dao;<\/p>\n<p>import org.springframework.data.jpa.repository.JpaRepository;<br \/>\nimport org.springframework.data.jpa.repository.JpaSpecificationExecutor;<br \/>\nimport top.onefine.domain.Customer;<\/p>\n<p>public interface CustomerDao extends JpaRepository&lt;Customer, Long&gt;, JpaSpecificationExecutor&lt;Customer&gt; {<br \/>\n}<\/p>\n<p>src\\\\test\\\\java\\\\top\\\\onefine\\\\dao\\\\CustomerDaoTest.java&#xff1a;<\/p>\n<p>package top.onefine.dao;<\/p>\n<p>import org.junit.Test;<br \/>\nimport org.junit.runner.RunWith;<br \/>\nimport org.springframework.beans.factory.annotation.Autowired;<br \/>\nimport org.springframework.data.domain.Page;<br \/>\nimport org.springframework.data.domain.PageRequest;<br \/>\nimport org.springframework.data.domain.Pageable;<br \/>\nimport org.springframework.data.domain.Sort;<br \/>\nimport org.springframework.data.jpa.domain.Specification;<br \/>\nimport org.springframework.test.context.ContextConfiguration;<br \/>\nimport org.springframework.test.context.junit4.SpringJUnit4ClassRunner;<br \/>\nimport top.onefine.domain.Customer;<\/p>\n<p>import javax.persistence.criteria.*;<\/p>\n<p>import java.util.List;<\/p>\n<p>import static org.junit.Assert.*;<\/p>\n<p>&#064;RunWith(SpringJUnit4ClassRunner.class)<br \/>\n&#064;ContextConfiguration(locations &#061; &#034;classpath:applicationContext.xml&#034;)<br \/>\npublic class CustomerDaoTest {<\/p>\n<p>    &#064;SuppressWarnings(&#034;All&#034;)<br \/>\n    &#064;Autowired<br \/>\n    private CustomerDao customerDao;<\/p>\n<p>    \/**<br \/>\n     * \u5355\u6761\u4ef6\u7cbe\u786e\u67e5\u8be2demo\u2014\u2014\u81ea\u5b9a\u4e49\u67e5\u8be2\u6761\u4ef6<br \/>\n     *      1. \u5b9e\u73b0Specification\u63a5\u53e3&#xff0c;\u9700\u8981\u63d0\u4f9b\u7684\u6cdb\u578b\u662f\u67e5\u8be2\u7684\u5bf9\u8c61\u7c7b\u578b<br \/>\n     *      2. \u5b9e\u73b0\u63a5\u53e3\u4e2d\u7684toPredicate\u65b9\u6cd5&#xff0c;\u7528\u4e8e\u6784\u9020\u67e5\u8be2\u6761\u4ef6<br \/>\n     *      3. \u9700\u8981\u501f\u52a9\u65b9\u6cd5\u53c2\u6570\u4e2d\u7684\u4e24\u4e2a\u53c2\u6570<br \/>\n     *          &#8211; Root&#xff1a; \u83b7\u53d6\u9700\u8981\u67e5\u8be2\u7684\u5bf9\u8c61\u5c5e\u6027<br \/>\n     *          &#8211; CriteriaBuilder&#xff1a;\u7528\u4e8e\u6784\u9020\u67e5\u8be2\u6761\u4ef6&#xff0c;\u5185\u90e8\u5c01\u88c5\u4e86\u5f88\u591a\u7684\u67e5\u8be2\u6761\u4ef6&#xff08;\u6a21\u7cca\u5339\u914d&#xff0c;\u7cbe\u51c6\u5339\u914d&#xff09;<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    public void testFindOne() {<br \/>\n        \/\/ \u533f\u540d\u5185\u90e8\u7c7b<br \/>\n\/\/        Specification&lt;Customer&gt; specification &#061; new Specification&lt;Customer&gt;() {<br \/>\n\/\/            &#064;Override<br \/>\n\/\/            public Predicate toPredicate(Root&lt;Customer&gt; root, CriteriaQuery&lt;?&gt; criteriaQuery, CriteriaBuilder criteriaBuilder) {<br \/>\n\/\/                \/\/ \u6839\u636e\u5ba2\u6237\u540d\u79f0\u67e5\u8be2<br \/>\n\/\/                \/\/ 1. \u83b7\u53d6\u6bd4\u8f83\u7684\u5c5e\u6027<br \/>\n\/\/                Path&lt;Object&gt; custName &#061; root.get(&#034;custName&#034;);  \/\/ Root\u5bf9\u8c61\u4e2d\u83b7\u53d6\u7528\u4e8e\u6bd4\u8f83\u7684\u5c5e\u6027\u540d\u79f0<br \/>\n\/\/                \/\/ 2. \u6784\u9020\u67e5\u8be2\u6761\u4ef6    select * from cst_customer where cust_name &#061; &#034;one fine&#034;<br \/>\n\/\/                \/\/      equal\u8868\u793a\u8fdb\u884c\u7cbe\u51c6\u5339\u914d&#xff0c;\u7b2c\u4e00\u4e2a\u53c2\u6570\u8868\u793a\u9700\u8981\u6bd4\u8f83\u7684\u5c5e\u6027&#xff08;Path\u5bf9\u8c61&#xff09;&#xff0c;\u7b2c\u4e8c\u4e2a\u53c2\u6570\u8868\u793a\u6bd4\u8f83\u5c5e\u6027\u7684\u53d6\u503c<br \/>\n\/\/                &#064;SuppressWarnings(&#034;&#034;)<br \/>\n\/\/                Predicate predicate &#061; criteriaBuilder.equal(custName, &#034;one fine&#034;);\/\/ CriteriaBuilder\u5bf9\u8c61\u4e2d\u6784\u9020\u67e5\u8be2\u65b9\u5f0f<br \/>\n\/\/                return predicate;<br \/>\n\/\/            }<br \/>\n\/\/        };<br \/>\n\/\/        Customer customer &#061; customerDao.findOne(specification);<\/p>\n<p>        \/\/ Lambda\u7b80\u5316<br \/>\n        Customer customer &#061; customerDao.findOne((root, criteriaQuery, criteriaBuilder) -&gt; criteriaBuilder.equal(root.get(&#034;custName&#034;), &#034;one fine&#034;));<br \/>\n        System.out.println(customer);<br \/>\n    }<\/p>\n<p>    \/** \u591a\u6761\u4ef6\u7cbe\u786e\u67e5\u8be2demo\u2014\u2014\u6839\u636e\u5ba2\u6237\u540d\u548c\u5ba2\u6237\u6240\u5c5e\u884c\u4e1a\u67e5\u8be2<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    public void testFindOne_() {<br \/>\n        Customer customer &#061; customerDao.findOne((root, criteriaQuery, criteriaBuilder) -&gt; {<br \/>\n            \/\/ 1. \u6784\u9020\u5ba2\u6237\u540d\u7684\u7cbe\u51c6\u5339\u914d\u67e5\u8be2<br \/>\n            Predicate predicate1 &#061; criteriaBuilder.equal(root.get(&#034;custName&#034;), &#034;one fine&#034;);<br \/>\n            \/\/ 2. \u6784\u9020\u6240\u5c5e\u884c\u4e1a\u7684\u7cbe\u51c6\u5339\u914d\u67e5\u8be2<br \/>\n            Predicate predicate2 &#061; criteriaBuilder.equal(root.get(&#034;custIndustry&#034;), &#034;\u8f6f\u4ef6&#034;);<br \/>\n            \/\/ 3. \u5c06\u4ee5\u4e0a\u4e24\u4e2a\u67e5\u8be2\u8054\u7cfb\u8d77\u6765&#xff1a;\u7ec4\u5408<br \/>\n            \/\/  &#8211; \u4e0e\u5173\u7cfb&#xff1a;and   \u4ea4\u96c6<br \/>\n            \/\/  &#8211; \u6216\u5173\u7cfb&#xff1a;or    \u5e76\u96c6<br \/>\n            return criteriaBuilder.and(predicate1, predicate2);<br \/>\n        });<br \/>\n        System.out.println(customer);<br \/>\n    }<\/p>\n<p>    \/**<br \/>\n     * \u6a21\u7cca\u5339\u914d&#xff0c;\u6839\u636e\u5ba2\u6237\u540d\u79f0\u6a21\u7cca\u5339\u914d&#xff0c;\u8fd4\u56de\u5ba2\u6237\u5217\u8868<br \/>\n     *  &#8211; equal&#xff1a;\u76f4\u63a5\u5f97\u5230Path\u5bf9\u8c61&#xff08;\u5c5e\u6027&#xff09;&#xff0c;\u7136\u540e\u8fdb\u884c\u6bd4\u8f83\u5373\u53ef<br \/>\n     *  &#8211; gt, lt, ge, le, like&#8230;&#xff1a;\u5f97\u5230Path\u5bf9\u8c61&#xff0c;\u6839\u636ePath\u6307\u5b9a\u9700\u8981\u6bd4\u8f83\u7684\u53c2\u6570\u7c7b\u578b&#xff0c;\u518d\u53bb\u8fdb\u884c\u6bd4\u8f83<br \/>\n     *      \u6307\u5b9a\u53c2\u6570\u7c7b\u578b: path.as(\u7c7b\u578b\u7684\u5b57\u8282\u7801\u5bf9\u8c61)<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    public void testFindAll() {<br \/>\n\/\/        Specification&lt;Customer&gt; specification &#061; new Specification&lt;Customer&gt;() {<br \/>\n\/\/            &#064;Override<br \/>\n\/\/            public Predicate toPredicate(Root&lt;Customer&gt; root, CriteriaQuery&lt;?&gt; criteriaQuery, CriteriaBuilder criteriaBuilder) {<br \/>\n\/\/                Path&lt;Object&gt; custName &#061; root.get(&#034;custName&#034;);<br \/>\n\/\/                Expression&lt;String&gt; custNameExpression &#061; custName.as(String.class);<br \/>\n\/\/                &#064;SuppressWarnings(&#034;&#034;)<br \/>\n\/\/                Predicate predicate &#061; criteriaBuilder.like(custNameExpression, &#034;one fine&#034;);  \/\/ \u67e5\u8be2\u65b9\u5f0f&#xff1a;\u6a21\u7cca\u5339\u914d<br \/>\n\/\/                return predicate;<br \/>\n\/\/            }<br \/>\n\/\/        };<br \/>\n\/\/        List&lt;Customer&gt; customers &#061; customerDao.findAll(specification);<\/p>\n<p>\/\/        List&lt;Customer&gt; customers &#061; customerDao.findAll((Root&lt;Customer&gt; root, CriteriaQuery&lt;?&gt; criteriaQuery, CriteriaBuilder criteriaBuilder) -&gt;<br \/>\n\/\/            criteriaBuilder.like(root.get(&#034;custName&#034;).as(String.class), &#034;one fine&#034;));<br \/>\n        List&lt;Customer&gt; customers &#061; customerDao.findAll((root, criteriaQuery, criteriaBuilder) -&gt;<br \/>\n                criteriaBuilder.like(root.get(&#034;custName&#034;).as(String.class), &#034;%fine%&#034;));  \/\/ \u5305\u542b&#034;fine&#034;\u7684<br \/>\n        for (Customer customer : customers)<br \/>\n            System.out.println(customer);<br \/>\n    }<\/p>\n<p>    \/**<br \/>\n     * \u6392\u5e8f<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    public void testFindAll_desc() {<\/p>\n<p>        \/\/ \u521b\u5efa\u6392\u5e8f\u5bf9\u8c61<br \/>\n        \/\/ \u7b2c\u4e00\u4e2a\u53c2\u6570&#xff1a;\u6392\u5e8f\u7684\u987a\u5e8f<br \/>\n        \/\/ &#8211; Sort.Direction.DESC \u5012\u5e8f<br \/>\n        \/\/ &#8211; Sort.Direction.ASC \u5347\u5e8f<br \/>\n        \/\/ \u7b2c\u4e8c\u4e2a\u53c2\u6570&#xff1a;\u6392\u5e8f\u7684\u5c5e\u6027\u540d\u79f0<br \/>\n        Sort sort &#061; new Sort(Sort.Direction.DESC, &#034;custId&#034;);  \/\/ \u67e5\u8be2\u7ed3\u679c\u6309\u7167id\u5012\u5e8f<br \/>\n        \/\/ \u6dfb\u52a0\u6392\u5e8f<br \/>\n        List&lt;Customer&gt; customers &#061; customerDao.findAll((root, criteriaQuery, criteriaBuilder) -&gt;<br \/>\n                criteriaBuilder.like(root.get(&#034;custName&#034;).as(String.class), &#034;one fine&#034;), sort);<br \/>\n        for (Customer customer : customers)<br \/>\n            System.out.println(customer);<br \/>\n    }<\/p>\n<p>    \/**<br \/>\n     * \u5206\u9875\u67e5\u8be2<br \/>\n     *  &#8211; findAll(Specification, Pageable)  \u5e26\u6761\u4ef6\u7684\u5206\u9875<br \/>\n     *  &#8211; findAll(Pageable) \u4e0d\u5e26\u6761\u4ef6\u7684\u5206\u9875<br \/>\n     * \u8fd4\u56dePage\u5bf9\u8c61&#xff0c;\u662fSpringDataJPA\u5c01\u88c5\u597d\u7684pageBean\u5bf9\u8c61&#xff0c;\u53ef\u4ee5\u4ece\u4e2d\u83b7\u53d6\u5230\u6570\u636e\u5217\u8868\u548c\u603b\u6761\u6570\u7b49<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    public void testFindAll_page() {<br \/>\n        Specification&lt;Customer&gt; specification &#061; null;  \/\/ \u65e0\u67e5\u8be2\u6761\u4ef6<br \/>\n        \/\/ Pageable&#xff1a;\u5206\u9875\u53c2\u6570<br \/>\n        \/\/ PageRequest\u5bf9\u8c61\u662fPageable\u63a5\u53e3\u7684\u5b9e\u73b0\u7c7b<br \/>\n        \/\/  &#8211; \u7b2c\u4e00\u4e2a\u53c2\u6570&#xff1a;\u67e5\u8be2\u7684\u9875\u7801&#xff08;\u4ece0\u5f00\u59cb&#xff09;<br \/>\n        \/\/  &#8211; \u7b2c\u4e8c\u4e2a\u53c2\u6570&#xff1a;\u6bcf\u9875\u67e5\u8be2\u7684\u8bb0\u5f55\u6761\u6570<\/p>\n<p>        Pageable pageable &#061; new PageRequest(1, 2);  \/\/ \u7b2c2\u9875&#xff08;0\u5f00\u59cb\u7f16\u53f7&#xff09;&#xff0c;\u6bcf\u9875\u663e\u793a2\u4e2a\u6570\u636e<\/p>\n<p>        Page&lt;Customer&gt; customerPage &#061; customerDao.findAll(specification, pageable);  \/\/ \u65e0\u67e5\u8be2\u6761\u4ef6<br \/>\n        System.out.println(&#034;&#034; &#043; customerPage.getTotalElements() &#043; &#034;\\\\n&#034; &#043;  \/\/ \u8bb0\u5f55\u603b\u6570<br \/>\n                            &#034;&#034; &#043; customerPage.getTotalPages() &#043; &#034;\\\\n&#034; &#043;  \/\/ \u603b\u9875\u6570<br \/>\n                            &#034;&#034; &#043; customerPage.getSize() &#043; &#034;\\\\n&#034; &#043;  \/\/ \u5206\u9875\u5927\u5c0f<br \/>\n                            &#034;&#034; &#043; customerPage.getContent());  \/\/ \u7ed3\u679c\u5217\u8868<\/p>\n<p>    }<\/p>\n<p>    \/**<br \/>\n     * \u7edf\u8ba1\u67e5\u8be2<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    public void testCount() {<\/p>\n<p>        long count &#061; customerDao.count((root, criteriaQuery, criteriaBuilder) -&gt;<br \/>\n                criteriaBuilder.like(root.get(&#034;custName&#034;).as(String.class), &#034;%fine&#034;));  \/\/ \u4ee5&#034;fine&#034;\u7ed3\u675f\u7684<br \/>\n        System.out.println(count);<br \/>\n    }<br \/>\n}<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"325\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100257-6802235172933.png\" width=\"784\" \/><\/p>\n<h4>\u4e8c\u3001\u591a\u8868\u8bbe\u8ba1<\/h4>\n<h5>2.1 \u8868\u4e4b\u95f4\u5173\u7cfb\u7684\u5212\u5206<\/h5>\n<p>\u6570\u636e\u5e93\u4e2d\u591a\u8868\u4e4b\u95f4\u5b58\u5728\u7740\u4e09\u79cd\u5173\u7cfb&#xff0c;\u5982\u56fe\u6240\u793a\u3002<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"296\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100257-68022351908d3.png\" width=\"606\" \/><\/p>\n<p>\u4ece\u56fe\u53ef\u4ee5\u770b\u51fa&#xff0c;\u7cfb\u7edf\u8bbe\u8ba1\u7684\u4e09\u79cd\u5b9e\u4f53\u5173\u7cfb\u5206\u522b\u4e3a&#xff1a;\u591a\u5bf9\u591a\u3001\u4e00\u5bf9\u591a\u548c\u4e00\u5bf9\u4e00(\u4e00\u822c\u4e0d\u4f7f\u7528)\u5173\u7cfb\u3002\u6ce8\u610f&#xff1a;\u4e00\u5bf9\u591a\u5173\u7cfb\u53ef\u4ee5\u770b\u4e3a\u4e24\u79cd&#xff1a; \u5373\u4e00\u5bf9\u591a&#xff0c;\u591a\u5bf9\u4e00&#xff1b;\u6240\u4ee5\u8bf4\u56db\u79cd\u66f4\u7cbe\u786e\u3002<\/p>\n<p>\u4e00\u5bf9\u591a\u5173\u7cfb\u4e2d&#xff1a;\u4e60\u60ef\u5c06\u4e00\u7684\u4e00\u65b9\u79f0\u4f5c\u4e3b\u8868&#xff0c;\u5c06\u591a\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4ece\u8868\u3002\u7528\u5916\u952e\u63cf\u8ff0\u8fd9\u79cd\u5173\u7cfb&#xff0c;\u9700\u8981\u5728\u4ece\u8868\u4e2d\u65b0\u5efa\u4e00\u4e2a\u5c5e\u6027\u4f5c\u4e3a\u5916\u952e&#xff0c;\u5176\u53d6\u503c\u6765\u6e90\u4e8e\u4e3b\u8868\u7684\u4e3b\u952e\u3002<\/p>\n<p>\u591a\u5bf9\u591a\u5173\u7cfb\u4e2d&#xff1a;\u7528\u4e2d\u95f4\u8868&#xff08;\u7b2c\u4e09\u7ae0\u8868&#xff09;\u6765\u63cf\u8ff0\u8fd9\u79cd\u5173\u7cfb&#xff0c;\u4e2d\u95f4\u8868\u4e2d\u81f3\u5c11\u5e94\u8be5\u7531\u4e24\u4e2a\u5b57\u6bb5\u7ec4\u6210&#xff0c;\u8fd9\u4e24\u4e2a\u5b57\u6bb5\u4f5c\u4e3a\u5916\u952e\u6307\u5411\u4e24\u5f20\u8868\u7684\u4e3b\u952e&#xff0c;\u4e14\u8fd9\u4e24\u4e2a\u5b57\u6bb5\u53c8\u7ec4\u6210\u4e86\u8054\u5408\u4e3b\u952e\u3002<\/p>\n<p>\u660e\u786e&#xff1a; \u8fd9\u91cc\u53ea\u6d89\u53ca\u5b9e\u9645\u5f00\u53d1\u4e2d\u5e38\u7528\u7684\u5173\u8054\u5173\u7cfb&#xff0c;\u4e00\u5bf9\u591a\u548c\u591a\u5bf9\u591a\u3002\u800c\u4e00\u5bf9\u4e00\u7684\u60c5\u51b5&#xff0c;\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d\u51e0\u4e4e\u4e0d\u7528\u3002<\/p>\n<p>\u5b9e\u4f53\u7c7b\u4e2d\u7684\u5173\u7cfb&#xff1a;<\/p>\n<ul>\n<li>\u5305\u542b\u5173\u7cfb&#xff1a;\u53ef\u4ee5\u901a\u8fc7\u5b9e\u4f53\u7c7b\u4e2d\u7684\u5305\u542b\u5173\u7cfb\u63cf\u8ff0\u8868\u5173\u7cfb&#xff08;\u4e00\u5bf9\u4e00\u3001\u4e00\u5bf9\u591a\u3001\u591a\u5bf9\u4e00\u3001\u591a\u5bf9\u591a&#xff09;<\/li>\n<li>\u7ee7\u627f\u5173\u7cfb<\/li>\n<\/ul>\n<h5>2.2 \u5728JPA\u6846\u67b6\u4e2d\u8868\u5173\u7cfb\u7684\u5206\u6790\u6b65\u9aa4<\/h5>\n<p>\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d&#xff0c;\u6211\u4eec\u6570\u636e\u5e93\u7684\u8868\u96be\u514d\u4f1a\u6709\u76f8\u4e92\u7684\u5173\u8054\u5173\u7cfb&#xff0c;\u5728\u64cd\u4f5c\u8868\u7684\u65f6\u5019\u5c31\u6709\u53ef\u80fd\u4f1a\u6d89\u53ca\u5230\u591a\u5f20\u8868\u7684\u64cd\u4f5c\u3002\u800c\u5728\u8fd9\u79cd\u5b9e\u73b0\u4e86ORM\u601d\u60f3\u7684\u6846\u67b6\u4e2d&#xff08;\u5982JPA&#xff09;&#xff0c;\u53ef\u4ee5\u8ba9\u6211\u4eec\u901a\u8fc7\u64cd\u4f5c\u5b9e\u4f53\u7c7b\u5c31\u5b9e\u73b0\u5bf9\u6570\u636e\u5e93\u8868\u7684\u64cd\u4f5c\u3002\u6240\u4ee5\u4eca\u5929\u6211\u4eec\u7684\u5b66\u4e60\u91cd\u70b9\u662f&#xff1a;\u638c\u63e1\u914d\u7f6e\u5b9e\u4f53\u4e4b\u95f4\u7684\u5173\u8054\u5173\u7cfb\u3002<\/p>\n<p>\u7b2c\u4e00\u6b65&#xff1a;\u9996\u5148\u786e\u5b9a\u4e24\u5f20\u8868\u4e4b\u95f4\u7684\u5173\u7cfb\u3002<\/p>\n<p>\u5982\u679c\u5173\u7cfb\u786e\u5b9a\u9519\u4e86&#xff0c;\u540e\u9762\u505a\u7684\u6240\u6709\u64cd\u4f5c\u5c31\u90fd\u4e0d\u53ef\u80fd\u6b63\u786e\u3002 \u7b2c\u4e8c\u6b65&#xff1a;\u5728\u6570\u636e\u5e93\u4e2d\u5b9e\u73b0\u4e24\u5f20\u8868\u7684\u5173\u7cfb&#xff08;\u7528\u5916\u952e\u6216\u4e2d\u95f4\u8868\u63cf\u8ff0&#xff09;<\/p>\n<p>\u7b2c\u4e09\u6b65&#xff1a;\u5728\u5b9e\u4f53\u7c7b\u4e2d\u63cf\u8ff0\u51fa\u4e24\u4e2a\u5b9e\u4f53\u7684\u5173\u7cfb&#xff08;\u5b9e\u4f53\u7c7b\u7684\u5305\u542b\u5173\u7cfb&#xff09;<\/p>\n<p>\u7b2c\u56db\u6b65&#xff1a;\u914d\u7f6e\u51fa\u5b9e\u4f53\u7c7b\u548c\u6570\u636e\u5e93\u8868\u7684\u5173\u7cfb\u6620\u5c04&#xff08;\u91cd\u70b9&#xff09;<\/p>\n<h4>\u4e09\u3001JPA\u4e2d\u7684\u4e00\u5bf9\u591a<\/h4>\n<h5>3.1 \u793a\u4f8b\u5206\u6790<\/h5>\n<p>\u6211\u4eec\u91c7\u7528\u7684\u793a\u4f8b\u4e3a\u5ba2\u6237\u548c\u8054\u7cfb\u4eba\u3002<\/p>\n<p>\u5ba2\u6237&#xff1a;\u6307\u7684\u662f\u4e00\u5bb6\u516c\u53f8&#xff0c;\u6211\u4eec\u8bb0\u4e3aA\u3002<\/p>\n<p>\u8054\u7cfb\u4eba&#xff1a;\u6307\u7684\u662fA\u516c\u53f8\u4e2d\u7684\u5458\u5de5\u3002<\/p>\n<p>\u5728\u4e0d\u8003\u8651\u517c\u804c\u7684\u60c5\u51b5\u4e0b&#xff0c;\u516c\u53f8\u548c\u5458\u5de5\u7684\u5173\u7cfb\u5373\u4e3a\u4e00\u5bf9\u591a\u3002\u5373\u4e00\u4e2a\u5ba2\u6237\u5177\u6709\u591a\u4e2a\u8054\u7cfb\u4eba&#xff0c;\u4e00\u4e2a\u8054\u7cfb\u4eba\u4ece\u5c5e\u4e8e\u4e00\u5bb6\u516c\u53f8\u3002<\/p>\n<h5>3.2 \u8868\u5173\u7cfb\u5efa\u7acb<\/h5>\n<p>\u5728\u4e00\u5bf9\u591a\u5173\u7cfb\u4e2d&#xff0c;\u6211\u4eec\u4e60\u60ef\u628a\u4e00\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4e3b\u8868&#xff0c;\u628a\u591a\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4ece\u8868\u3002\u5728\u6570\u636e\u5e93\u4e2d\u5efa\u7acb\u4e00\u5bf9\u591a\u7684\u5173\u7cfb&#xff0c;\u9700\u8981\u4f7f\u7528\u6570\u636e\u5e93\u7684\u5916\u952e\u7ea6\u675f\u3002<\/p>\n<p>\u4ec0\u4e48\u662f\u5916\u952e&#xff1f; \u6307\u7684\u662f\u4ece\u8868\u4e2d\u6709\u4e00\u5217&#xff0c;\u53d6\u503c\u53c2\u7167\u4e3b\u8868\u7684\u4e3b\u952e&#xff0c;\u8fd9\u4e00\u5217\u5c31\u662f\u5916\u952e\u3002<\/p>\n<p>\u4e00\u5bf9\u591a\u6570\u636e\u5e93\u5173\u7cfb\u7684\u5efa\u7acb&#xff0c;\u5982\u4e0b\u56fe\u6240\u793a&#xff1a;<img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"170\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100257-68022351a0727.png\" width=\"842\" \/> \u00a0 \u00a0<\/p>\n<p>\u8fd9\u91cc\u4e00\u5bf9\u591a\u7684\u6817\u5b50\u4e2d&#xff0c;\u4e3b\u8868\u662f\u5ba2\u6237\u8868&#xff0c;\u4ece\u8868\u662f\u8054\u7cfb\u4eba\u8868&#xff08;\u9700\u8981\u6dfb\u52a0\u5916\u952e&#xff09;\u3002<\/p>\n<p>\/*\u521b\u5efa\u5ba2\u6237\u8868*\/<br \/>\nCREATE TABLE cst_customer (<br \/>\n  cust_id bigint(32) NOT NULL AUTO_INCREMENT COMMENT &#039;\u5ba2\u6237\u7f16\u53f7(\u4e3b\u952e)&#039;,<br \/>\n  cust_name varchar(32) NOT NULL COMMENT &#039;\u5ba2\u6237\u540d\u79f0(\u516c\u53f8\u540d\u79f0)&#039;,<br \/>\n  cust_source varchar(32) DEFAULT NULL COMMENT &#039;\u5ba2\u6237\u4fe1\u606f\u6765\u6e90&#039;,<br \/>\n  cust_industry varchar(32) DEFAULT NULL COMMENT &#039;\u5ba2\u6237\u6240\u5c5e\u884c\u4e1a&#039;,<br \/>\n  cust_level varchar(32) DEFAULT NULL COMMENT &#039;\u5ba2\u6237\u7ea7\u522b&#039;,<br \/>\n  cust_address varchar(128) DEFAULT NULL COMMENT &#039;\u5ba2\u6237\u8054\u7cfb\u5730\u5740&#039;,<br \/>\n  cust_phone varchar(64) DEFAULT NULL COMMENT &#039;\u5ba2\u6237\u8054\u7cfb\u7535\u8bdd&#039;,<br \/>\n  PRIMARY KEY (&#096;cust_id&#096;)<br \/>\n) ENGINE&#061;InnoDB AUTO_INCREMENT&#061;94 DEFAULT CHARSET&#061;utf8;<\/p>\n<p>\/*\u521b\u5efa\u8054\u7cfb\u4eba\u8868*\/<br \/>\nCREATE TABLE cst_linkman (<br \/>\n  lkm_id bigint(32) NOT NULL AUTO_INCREMENT COMMENT &#039;\u8054\u7cfb\u4eba\u7f16\u53f7(\u4e3b\u952e)&#039;,<br \/>\n  lkm_name varchar(16) DEFAULT NULL COMMENT &#039;\u8054\u7cfb\u4eba\u59d3\u540d&#039;,<br \/>\n  lkm_gender char(1) DEFAULT NULL COMMENT &#039;\u8054\u7cfb\u4eba\u6027\u522b&#039;,<br \/>\n  lkm_phone varchar(16) DEFAULT NULL COMMENT &#039;\u8054\u7cfb\u4eba\u529e\u516c\u7535\u8bdd&#039;,<br \/>\n  lkm_mobile varchar(16) DEFAULT NULL COMMENT &#039;\u8054\u7cfb\u4eba\u624b\u673a&#039;,<br \/>\n  lkm_email varchar(64) DEFAULT NULL COMMENT &#039;\u8054\u7cfb\u4eba\u90ae\u7bb1&#039;,<br \/>\n  lkm_position varchar(16) DEFAULT NULL COMMENT &#039;\u8054\u7cfb\u4eba\u804c\u4f4d&#039;,<br \/>\n  lkm_memo varchar(512) DEFAULT NULL COMMENT &#039;\u8054\u7cfb\u4eba\u5907\u6ce8&#039;,<br \/>\n  lkm_cust_id bigint(32) NOT NULL COMMENT &#039;\u5ba2\u6237id(\u5916\u952e)&#039;,<br \/>\n  PRIMARY KEY (&#096;lkm_id&#096;),<br \/>\n  KEY &#096;FK_cst_linkman_lkm_cust_id&#096; (&#096;lkm_cust_id&#096;),<br \/>\n  CONSTRAINT &#096;FK_cst_linkman_lkm_cust_id&#096; FOREIGN KEY (&#096;lkm_cust_id&#096;) REFERENCES &#096;cst_customer&#096; (&#096;cust_id&#096;) ON DELETE NO ACTION ON UPDATE NO ACTION<br \/>\n) ENGINE&#061;InnoDB AUTO_INCREMENT&#061;3 DEFAULT CHARSET&#061;utf8;<\/p>\n<h5>3.3 \u5b9e\u4f53\u7c7b\u5173\u7cfb\u5efa\u7acb\u4ee5\u53ca\u6620\u5c04\u914d\u7f6e<\/h5>\n<p>\u8981\u70b9&#xff1a; \u5ba2\u6237&#xff1a;\u5728\u5ba2\u6237\u7684\u5b9e\u4f53\u7c7b\u4e2d\u5305\u542b\u4e00\u4e2a\u8054\u7cfb\u4eba\u7684\u96c6\u5408 \u8054\u7cfb\u4eba&#xff1a;\u5728\u8054\u7cfb\u4eba\u7684\u5b9e\u4f53\u7c7b\u4e2d\u5305\u542b\u6709\u4e00\u4e2a\u5ba2\u6237\u7684\u5bf9\u8c61<\/p>\n<p>\u5728\u5b9e\u4f53\u7c7b\u4e2d&#xff0c;\u7531\u4e8e\u5ba2\u6237\u662f\u5c11\u7684\u4e00\u65b9&#xff0c;\u5b83\u5e94\u8be5\u5305\u542b\u591a\u4e2a\u8054\u7cfb\u4eba&#xff0c;\u6240\u4ee5\u5b9e\u4f53\u7c7b\u8981\u4f53\u73b0\u51fa\u5ba2\u6237\u4e2d\u6709\u591a\u4e2a\u8054\u7cfb\u4eba\u7684\u4fe1\u606f&#xff0c;\u4ee3\u7801\u5982\u4e0b<\/p>\n<p>package top.onefine.domain;<\/p>\n<p>import lombok.*;<\/p>\n<p>import javax.persistence.*;<br \/>\nimport java.util.HashSet;<br \/>\nimport java.util.Set;<\/p>\n<p>\/**<br \/>\n * 1. \u5b9e\u4f53\u7c7b\u548c\u8868\u7684\u6620\u5c04\u5173\u7cfb<br \/>\n *      -&#064;Eitity<br \/>\n *      -&#064;Table<br \/>\n * 2. \u7c7b\u4e2d\u5c5e\u6027\u548c\u6570\u636e\u5e93\u8868\u4e2d\u5b57\u6bb5\u7684\u6620\u5c04\u5173\u7cfb<br \/>\n *      -&#064;Id \u4e3b\u952e<br \/>\n *      -&#064;GeneratedValue \u4e3b\u952e\u751f\u6210\u7b56\u7565<br \/>\n *      -&#064;Column<br \/>\n *\/<br \/>\n&#064;Entity<br \/>\n&#064;Table(name &#061; &#034;cst_customer&#034;)<br \/>\n&#064;Data  \/\/ \u4f7f\u7528&#064;Getter\u548c&#064;Setter&#xff0c;\u4f46\u662f\u8981\u81ea\u5df1\u751f\u6210toString\u65b9\u6cd5<br \/>\n\/\/&#064;Getter<br \/>\n\/\/&#064;Setter<br \/>\n&#064;NoArgsConstructor<br \/>\npublic class Customer {<br \/>\n    &#064;Id<br \/>\n    &#064;GeneratedValue(strategy &#061; GenerationType.IDENTITY)<br \/>\n    &#064;Column(name &#061; &#034;cust_id&#034;)<br \/>\n    private Long custId;<br \/>\n    &#064;Column(name &#061; &#034;cust_address&#034;)<br \/>\n    private String custAddress;<br \/>\n    &#064;Column(name &#061; &#034;cust_industry&#034;)<br \/>\n    private String custIndustry;<br \/>\n    &#064;Column(name &#061; &#034;cust_level&#034;)<br \/>\n    private String custLevel;<br \/>\n    &#064;Column(name &#061; &#034;cust_name&#034;)<br \/>\n    private String custName;<br \/>\n    &#064;Column(name &#061; &#034;cust_phone&#034;)<br \/>\n    private String custPhone;<br \/>\n    &#064;Column(name &#061; &#034;cust_source&#034;)<br \/>\n    private String custSource;<\/p>\n<p>    \/\/ \u914d\u7f6e\u5ba2\u6237\u548c\u8054\u7cfb\u4eba\u4e4b\u95f4\u7684\u5173\u7cfb&#xff08;\u4e00\u5bf9\u591a\u5173\u7cfb&#xff09;<br \/>\n    \/*<br \/>\n        \u4f7f\u7528\u6ce8\u89e3\u7684\u5f62\u5f0f\u914d\u7f6e\u591a\u8868\u5173\u7cfb&#xff1a;<br \/>\n            1. \u58f0\u660e\u5173\u7cfb<br \/>\n                &#8211; &#064;OneToMany&#xff1a;\u914d\u7f6e\u4e00\u5bf9\u591a\u5173\u7cfb<br \/>\n                    targetEntity&#xff1a;\u5bf9\u65b9\u5bf9\u8c61\u7684\u5b57\u8282\u7801\u5bf9\u8c61<br \/>\n            2. \u914d\u7f6e\u5916\u952e&#xff08;\u6216\u4e2d\u95f4\u8868&#xff09;<br \/>\n                &#8211; &#064;JoinColumn&#xff1a;\u914d\u7f6e\u5916\u952e<br \/>\n                    name&#xff1a;\u4ece\u8868 \u5916\u952e\u5b57\u6bb5\u540d\u79f0<br \/>\n                    referencedColumnName&#xff1a;\u53c2\u7167\u7684 \u4e3b\u8868 \u7684\u4e3b\u952e\u5b57\u6bb5\u540d\u79f0<\/p>\n<p>        \u6ce8&#xff1a;\u5728\u5ba2\u6237\u5b9e\u4f53\u7c7b\u4e0a&#xff08;\u4e00\u7684\u4e00\u65b9&#xff09;\u6dfb\u52a0\u4e86\u5916\u952e\u7684\u914d\u7f6e&#xff0c;\u6240\u4ee5\u5bf9\u4e8e\u5ba2\u6237\u800c\u8a00&#xff0c;\u4e5f\u5177\u5907\u4e86\u7ef4\u62a4\u5916\u952e\u7684\u4f5c\u7528<\/p>\n<p>     *\/<br \/>\n    &#064;OneToMany(targetEntity &#061; LinkMan.class)<br \/>\n    &#064;JoinColumn(name &#061; &#034;lkm_cust_id&#034;, referencedColumnName &#061; &#034;cust_id&#034;)<br \/>\n    \/*<br \/>\n        \u653e\u5f03\u5916\u952e\u7ef4\u62a4\u6743<br \/>\n            mappedBy: \u5bf9\u65b9\u914d\u7f6e\u5173\u7cfb\u7684\u5c5e\u6027\u540d\u79f0<br \/>\n                \u8868\u793a\u53c2\u7167\u5bf9\u65b9\u7684\u5c5e\u6027\u6765\u505a<br \/>\n     *\/<br \/>\n\/\/    &#064;OneToMany(mappedBy &#061; &#034;customer&#034;)<br \/>\n    private Set&lt;LinkMan&gt; linkMans &#061; new HashSet&lt;&gt;();<\/p>\n<p>    \/\/ \u4e00\u5b9a\u8981\u81ea\u5df1\u5199&#xff0c;\u4e0d\u8981\u4f7f\u7528lombok\u63d0\u4f9b\u7684<br \/>\n\/\/    &#064;Override<br \/>\n\/\/    public String toString() {<br \/>\n\/\/        return &#034;Customer{&#034; &#043;<br \/>\n\/\/                &#034;custId&#061;&#034; &#043; custId &#043;<br \/>\n\/\/                &#034;, custAddress&#061;&#039;&#034; &#043; custAddress &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n\/\/                &#034;, custIndustry&#061;&#039;&#034; &#043; custIndustry &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n\/\/                &#034;, custLevel&#061;&#039;&#034; &#043; custLevel &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n\/\/                &#034;, custName&#061;&#039;&#034; &#043; custName &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n\/\/                &#034;, custPhone&#061;&#039;&#034; &#043; custPhone &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n\/\/                &#034;, custSource&#061;&#039;&#034; &#043; custSource &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n\/\/                &#034;, linkMans&#061;&#034; &#043; linkMans &#043;<br \/>\n\/\/                &#039;}&#039;;<br \/>\n\/\/    }<br \/>\n}<\/p>\n<p>\u7531\u4e8e\u8054\u7cfb\u4eba\u662f\u591a\u7684\u4e00\u65b9&#xff0c;\u5728\u5b9e\u4f53\u7c7b\u4e2d\u8981\u4f53\u73b0\u51fa&#xff0c;\u6bcf\u4e2a\u8054\u7cfb\u4eba\u53ea\u80fd\u5bf9\u5e94\u4e00\u4e2a\u5ba2\u6237&#xff0c;\u4ee3\u7801\u5982\u4e0b&#xff1a;<\/p>\n<p>package top.onefine.domain;<\/p>\n<p>import lombok.Data;<br \/>\nimport lombok.NoArgsConstructor;<\/p>\n<p>import javax.persistence.*;<\/p>\n<p>&#064;Entity<br \/>\n&#064;Table(name &#061; &#034;cst_linkman&#034;)<br \/>\n&#064;Data<br \/>\n&#064;NoArgsConstructor<br \/>\npublic class LinkMan {<br \/>\n    &#064;Id<br \/>\n    &#064;GeneratedValue(strategy &#061; GenerationType.IDENTITY)<br \/>\n    &#064;Column(name &#061; &#034;lkm_id&#034;)<br \/>\n    private Long lkmId;  \/\/ \u8054\u7cfb\u4eba\u7f16\u53f7<br \/>\n    &#064;Column(name &#061; &#034;lkm_name&#034;)<br \/>\n    private String lkmName;  \/\/ \u8054\u7cfb\u4eba\u59d3\u540d<br \/>\n    &#064;Column(name &#061; &#034;lkm_gender&#034;)<br \/>\n    private String lkmGender;  \/\/ \u8054\u7cfb\u4eba\u6027\u522b  \/\/ \u5bf9\u5e94\u6570\u636e\u5e93\u8868\u4e2d\u5b57\u6bb5char(1)<br \/>\n    &#064;Column(name &#061; &#034;lkm_phone&#034;)<br \/>\n    private String lkmPhone;  \/\/ \u8054\u7cfb\u4eba\u529e\u516c\u7535\u8bdd<br \/>\n    &#064;Column(name &#061; &#034;lkm_mobile&#034;)<br \/>\n    private String lkmMobile;  \/\/ \u8054\u7cfb\u4eba\u624b\u673a<br \/>\n    &#064;Column(name &#061; &#034;lkm_email&#034;)<br \/>\n    private String lkmEmail;  \/\/ \u8054\u7cfb\u4eba\u90ae\u7bb1<br \/>\n    &#064;Column(name &#061; &#034;lkm_position&#034;)<br \/>\n    private String lkmPosition;  \/\/ \u8054\u7cfb\u4eba\u804c\u4f4d<br \/>\n    &#064;Column(name &#061; &#034;lkm_memo&#034;)<br \/>\n    private String lkmMemo;  \/\/ \u8054\u7cfb\u4eba\u5907\u6ce8<\/p>\n<p>    \/\/ \u914d\u7f6e\u8054\u7cfb\u4eba\u5230\u5ba2\u6237\u7684\u591a\u5bf9\u4e00\u5173\u7cfb<br \/>\n    \/*<br \/>\n        \u4f7f\u7528\u6ce8\u89e3\u7684\u5f62\u5f0f\u914d\u7f6e\u591a\u5bf9\u4e00\u5173\u7cfb<br \/>\n            1. \u914d\u7f6e\u8868\u5173\u7cfb<br \/>\n                &#8211; &#064;ManyToOne&#xff1a;\u914d\u7f6e\u591a\u5bf9\u4e00\u5173\u7cfb<br \/>\n                    targetEntity&#xff1a;\u5bf9\u65b9\u5bf9\u8c61\u7684\u5b57\u8282\u7801\u5bf9\u8c61<br \/>\n            2. \u914d\u7f6e\u5916\u952e&#xff08;\u6216\u4e2d\u95f4\u8868&#xff09;<\/p>\n<p>        \u6ce8&#xff1a;\u914d\u7f6e\u5916\u952e\u7684\u8fc7\u7a0b&#xff0c;\u914d\u7f6e\u5230\u4e86\u591a\u7684\u4e00\u65b9&#xff0c;\u5c31\u4f1a\u5728\u591a\u7684\u4e00\u65b9\u7ef4\u62a4\u5916\u952e<br \/>\n     *\/<br \/>\n    &#064;ManyToOne(targetEntity &#061; Customer.class)<br \/>\n    &#064;JoinColumn(name &#061; &#034;lkm_cust_id&#034;, referencedColumnName &#061; &#034;cust_id&#034;)<br \/>\n    private Customer customer;<br \/>\n}<\/p>\n<h6>\u5176\u4ed6\u914d\u7f6e<\/h6>\n<p>pom.xml&#xff1a;<\/p>\n<p>&lt;?xml version&#061;&#034;1.0&#034; encoding&#061;&#034;UTF-8&#034;?&gt;<br \/>\n&lt;project xmlns&#061;&#034;http:\/\/maven.apache.org\/POM\/4.0.0&#034;<br \/>\n         xmlns:xsi&#061;&#034;http:\/\/www.w3.org\/2001\/XMLSchema-instance&#034;<br \/>\n         xsi:schemaLocation&#061;&#034;http:\/\/maven.apache.org\/POM\/4.0.0 http:\/\/maven.apache.org\/xsd\/maven-4.0.0.xsd&#034;&gt;<br \/>\n    &lt;modelVersion&gt;4.0.0&lt;\/modelVersion&gt;<\/p>\n<p>    &lt;groupId&gt;top.onefine&lt;\/groupId&gt;<br \/>\n    &lt;artifactId&gt;jpa_day3_one2mant&lt;\/artifactId&gt;<br \/>\n    &lt;version&gt;1.0-SNAPSHOT&lt;\/version&gt;<br \/>\n    &lt;packaging&gt;jar&lt;\/packaging&gt;<\/p>\n<p>    &lt;properties&gt;<br \/>\n        &lt;project.build.sourceEncoding&gt;UTF-8&lt;\/project.build.sourceEncoding&gt;<br \/>\n&lt;!&#8211;        &lt;project.hibernate.version&gt;5.4.14.Final&lt;\/project.hibernate.version&gt;&#8211;&gt;<br \/>\n&lt;!&#8211;        &lt;project.hibernate.version&gt;5.0.7.Final&lt;\/project.hibernate.version&gt;&#8211;&gt;<br \/>\n        &lt;project.hibernate.version&gt;5.1.17.Final&lt;\/project.hibernate.version&gt;<br \/>\n        &lt;project.spring.version&gt;5.2.5.RELEASE&lt;\/project.spring.version&gt;<br \/>\n        &lt;project.slf4j.version&gt;1.7.30&lt;\/project.slf4j.version&gt;<br \/>\n        &lt;project.log4j.version&gt;1.2.17&lt;\/project.log4j.version&gt;<br \/>\n        &lt;project.c3p0.version&gt;0.9.5.5&lt;\/project.c3p0.version&gt;<br \/>\n        &lt;project.mysql.version&gt;8.0.19&lt;\/project.mysql.version&gt;<br \/>\n    &lt;\/properties&gt;<\/p>\n<p>    &lt;dependencies&gt;<br \/>\n        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/junit\/junit &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;junit&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;junit&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;4.13&lt;\/version&gt;<br \/>\n            &lt;scope&gt;test&lt;\/scope&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; \u4ee5\u4e0b\u4e24\u4e2a\u662fspring aop\u76f8\u5173\u7684\u5750\u6807 &#8211;&gt;<br \/>\n        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.aspectj\/aspectjweaver &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.aspectj&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;aspectjweaver&lt;\/artifactId&gt;<br \/>\n&lt;!&#8211;            &lt;version&gt;1.9.5&lt;\/version&gt;&#8211;&gt;<br \/>\n            &lt;version&gt;1.6.8&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.springframework\/spring-aop &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.springframework&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;spring-aop&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.spring.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.springframework\/spring-context &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.springframework&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;spring-context&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.spring.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.springframework\/spring-context-support &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.springframework&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;spring-context-support&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.spring.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; spring\u5bf9orm\u6846\u67b6\u7684\u652f\u6301\u5305 &#8211;&gt;<br \/>\n        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.springframework\/spring-orm &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.springframework&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;spring-orm&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.spring.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.springframework\/spring-beans &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.springframework&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;spring-beans&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.spring.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.springframework\/spring-core &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.springframework&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;spring-core&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.spring.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.hibernate\/hibernate-core &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.hibernate&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;hibernate-core&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.hibernate.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.hibernate\/hibernate-entitymanager &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.hibernate&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;hibernate-entitymanager&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.hibernate.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.hibernate\/hibernate-validator &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.hibernate&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;hibernate-validator&lt;\/artifactId&gt;<br \/>\n            &lt;!&#8211;            &lt;version&gt;6.1.4.Final&lt;\/version&gt;&#8211;&gt;<br \/>\n            &lt;version&gt;5.4.3.Final&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/log4j\/log4j &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;log4j&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;log4j&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.log4j.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.slf4j\/slf4j-api &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.slf4j&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;slf4j-api&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.slf4j.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.slf4j\/slf4j-log4j12 &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.slf4j&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;slf4j-log4j12&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.slf4j.version}&lt;\/version&gt;<br \/>\n            &lt;scope&gt;test&lt;\/scope&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/com.mchange\/c3p0 &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;com.mchange&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;c3p0&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.c3p0.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/mysql\/mysql-connector-java &#8211;&gt;<br \/>\n        &lt;!&#8211; Mysql and MariaDB &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;mysql&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;mysql-connector-java&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.mysql.version}&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; spring data jpa \u7684\u5750\u6807 &#8211;&gt;<br \/>\n        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.springframework.data\/spring-data-jpa &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.springframework.data&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;spring-data-jpa&lt;\/artifactId&gt;<br \/>\n            &lt;!&#8211;            &lt;version&gt;2.2.6.RELEASE&lt;\/version&gt;&#8211;&gt;<br \/>\n            &lt;!&#8211;            &lt;version&gt;1.9.0.RELEASE&lt;\/version&gt;&#8211;&gt;<br \/>\n            &lt;version&gt;1.11.23.RELEASE&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; spring \u63d0\u4f9b\u7684\u5355\u5143\u6d4b\u8bd5\u7684\u5750\u6807 &#8211;&gt;<br \/>\n        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.springframework\/spring-test &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.springframework&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;spring-test&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;${project.spring.version}&lt;\/version&gt;<br \/>\n            &lt;scope&gt;test&lt;\/scope&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; \u4ee5\u4e0b\u4e24\u4e2a spring data jpa\u5fc5\u987b\u5bfc\u5165\u7684\u5750\u6807 &#8211;&gt;<br \/>\n        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/javax.el\/javax.el-api &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;javax.el&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;javax.el-api&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;2.2.4&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.glassfish.web\/javax.el &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.glassfish.web&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;javax.el&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;2.2.4&lt;\/version&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>        &lt;!&#8211; https:\/\/mvnrepository.com\/artifact\/org.projectlombok\/lombok &#8211;&gt;<br \/>\n        &lt;dependency&gt;<br \/>\n            &lt;groupId&gt;org.projectlombok&lt;\/groupId&gt;<br \/>\n            &lt;artifactId&gt;lombok&lt;\/artifactId&gt;<br \/>\n            &lt;version&gt;1.18.12&lt;\/version&gt;<br \/>\n            &lt;scope&gt;provided&lt;\/scope&gt;<br \/>\n        &lt;\/dependency&gt;<\/p>\n<p>    &lt;\/dependencies&gt;<\/p>\n<p>&lt;\/project&gt;<\/p>\n<p>src\\\\main\\\\resources\\\\applicationContext.xml&#xff1a;<\/p>\n<p>&lt;?xml version&#061;&#034;1.0&#034; encoding&#061;&#034;UTF-8&#034;?&gt;<br \/>\n&lt;beans xmlns&#061;&#034;http:\/\/www.springframework.org\/schema\/beans&#034;<br \/>\n       xmlns:xsi&#061;&#034;http:\/\/www.w3.org\/2001\/XMLSchema-instance&#034;<br \/>\n       xmlns:aop&#061;&#034;http:\/\/www.springframework.org\/schema\/aop&#034;<br \/>\n       xmlns:context&#061;&#034;http:\/\/www.springframework.org\/schema\/context&#034;<br \/>\n       xmlns:jdbc&#061;&#034;http:\/\/www.springframework.org\/schema\/jdbc&#034;<br \/>\n       xmlns:tx&#061;&#034;http:\/\/www.springframework.org\/schema\/tx&#034;<br \/>\n       xmlns:jpa&#061;&#034;http:\/\/www.springframework.org\/schema\/data\/jpa&#034;<br \/>\n       xmlns:task&#061;&#034;http:\/\/www.springframework.org\/schema\/task&#034;<br \/>\n       xsi:schemaLocation&#061;&#034;<br \/>\nhttp:\/\/www.springframework.org\/schema\/beans http:\/\/www.springframework.org\/schema\/beans\/spring-beans.xsd<br \/>\nhttp:\/\/www.springframework.org\/schema\/aop http:\/\/www.springframework.org\/schema\/aop\/spring-aop.xsd<br \/>\nhttp:\/\/www.springframework.org\/schema\/context http:\/\/www.springframework.org\/schema\/context\/spring-context.xsd<br \/>\nhttp:\/\/www.springframework.org\/schema\/jdbc http:\/\/www.springframework.org\/schema\/jdbc\/spring-jdbc.xsd<br \/>\nhttp:\/\/www.springframework.org\/schema\/tx http:\/\/www.springframework.org\/schema\/tx\/spring-tx.xsd<br \/>\nhttp:\/\/www.springframework.org\/schema\/data\/jpa<br \/>\nhttp:\/\/www.springframework.org\/schema\/data\/jpa\/spring-jpa.xsd&#034;&gt;<\/p>\n<p>    &lt;!&#8211; spring \u548c spring data jpa \u7684\u914d\u7f6e &#8211;&gt;<br \/>\n    &lt;!&#8211; 1. \u521b\u5efaentityManagerFactory\u5bf9\u8c61\u4ea4\u7ed9spring\u5bb9\u5668\u7ba1\u7406 &#8211;&gt;<br \/>\n    &lt;bean id&#061;&#034;entityManagerFactory&#034; class&#061;&#034;org.springframework.orm.jpa.LocalContainerEntityManagerFactoryBean&#034;&gt;<br \/>\n        &lt;!&#8211; \u914d\u7f6e\u6570\u636e\u6e90 &#8211;&gt;<br \/>\n        &lt;property name&#061;&#034;dataSource&#034; ref&#061;&#034;dataSource&#034;\/&gt;<\/p>\n<p>        &lt;!&#8211; \u914d\u7f6e\u626b\u63cf\u7684\u5305\u2014\u2014\u5b9e\u4f53\u7c7b\u6240\u5728\u7684\u5305 &#8211;&gt;<br \/>\n        &lt;property name&#061;&#034;packagesToScan&#034; value&#061;&#034;top.onefine.domain&#034;\/&gt;<\/p>\n<p>        &lt;!&#8211; \u914d\u7f6ejpa\u7684\u5b9e\u73b0\u5382\u5bb6 &#8211;&gt;<br \/>\n        &lt;property name&#061;&#034;persistenceProvider&#034;&gt;<br \/>\n            &lt;bean class&#061;&#034;org.hibernate.jpa.HibernatePersistenceProvider&#034;\/&gt;<br \/>\n        &lt;\/property&gt;<\/p>\n<p>        &lt;!&#8211; JPA\u7684\u4f9b\u5e94\u5546\u9002\u914d\u5668 &#8211;&gt;<br \/>\n        &lt;property name&#061;&#034;jpaVendorAdapter&#034;&gt;<br \/>\n            &lt;bean class&#061;&#034;org.springframework.orm.jpa.vendor.HibernateJpaVendorAdapter&#034;&gt;<br \/>\n                &lt;!&#8211; \u914d\u7f6e\u662f\u5426\u81ea\u52a8\u521b\u5efa\u6570\u636e\u5e93\u8868&#xff0c;\u8fd9\u91ccfalse &#8211;&gt;<br \/>\n                &lt;property name&#061;&#034;generateDdl&#034; value&#061;&#034;false&#034;\/&gt;<br \/>\n                &lt;!&#8211; \u6307\u5b9a\u6570\u636e\u5e93\u7c7b\u578b &#8211;&gt;<br \/>\n                &lt;property name&#061;&#034;database&#034; value&#061;&#034;MYSQL&#034;\/&gt;<br \/>\n                &lt;!&#8211; \u914d\u7f6e\u6570\u636e\u5e93\u65b9\u8a00&#xff0c;\u5373\u6570\u636e\u5e93\u652f\u6301\u7684\u7279\u6709\u8bed\u6cd5 &#8211;&gt;<br \/>\n                &lt;property name&#061;&#034;databasePlatform&#034; value&#061;&#034;org.hibernate.dialect.MySQLDialect&#034;\/&gt;<br \/>\n                &lt;!&#8211; \u914d\u7f6e\u662f\u5426\u663e\u793asql\u8bed\u53e5&#xff0c;\u9ed8\u8ba4\u5728\u63a7\u5236\u53f0 &#8211;&gt;<br \/>\n                &lt;property name&#061;&#034;showSql&#034; value&#061;&#034;true&#034;\/&gt;<br \/>\n            &lt;\/bean&gt;<br \/>\n        &lt;\/property&gt;<\/p>\n<p>        &lt;!&#8211; \u914d\u7f6ejpa\u7684\u65b9\u8a00&#xff0c;\u9ad8\u7ea7\u7279\u6027 &#8211;&gt;<br \/>\n        &lt;property name&#061;&#034;jpaDialect&#034;&gt;<br \/>\n            &lt;bean class&#061;&#034;org.springframework.orm.jpa.vendor.HibernateJpaDialect&#034;\/&gt;<br \/>\n        &lt;\/property&gt;<\/p>\n<p>        &lt;!&#8211; \u6ce8\u5165jpa\u7684\u914d\u7f6e\u4fe1\u606f<br \/>\n            \u52a0\u8f7djpa\u7684\u57fa\u672c\u914d\u7f6e\u4fe1\u606f\u548cjpa\u5b9e\u73b0\u65b9\u5f0f&#xff08;\u5982hibernate&#xff09;\u7684\u914d\u7f6e\u4fe1\u606f<br \/>\n            hibernate.hbm2ddl.auto: \u81ea\u52a8\u521b\u5efa\u6570\u636e\u5e93\u8868<br \/>\n                create: \u6bcf\u6b21\u90fd\u4ece\u65b0\u521b\u5efa\u6570\u636e\u5e93\u8868<br \/>\n                update: \u6709\u8868\u4e0d\u4f1a\u91cd\u65b0\u521b\u5efa&#xff0c;\u6ca1\u6709\u8868\u4f1a\u91cd\u65b0\u521b\u5efa\u8868<br \/>\n        &#8211;&gt;<br \/>\n        &lt;property name&#061;&#034;jpaProperties&#034;&gt;<br \/>\n            &lt;props&gt;<br \/>\n                &lt;prop key&#061;&#034;hibernate.hbm2ddl.auto&#034;&gt;create&lt;\/prop&gt;&lt;!&#8211; \u6682\u65f6 &#8211;&gt;<br \/>\n            &lt;\/props&gt;<br \/>\n        &lt;\/property&gt;<br \/>\n    &lt;\/bean&gt;<\/p>\n<p>    &lt;!&#8211; 2. \u521b\u5efa\u6570\u636e\u5e93\u8fde\u63a5\u6c60 &#8211;&gt;<br \/>\n    &lt;bean id&#061;&#034;dataSource&#034; class&#061;&#034;com.mchange.v2.c3p0.ComboPooledDataSource&#034;&gt;<br \/>\n        &lt;!&#8211;  \u8fde\u63a5\u53c2\u6570 &#8211;&gt;<br \/>\n        &lt;property name&#061;&#034;driverClass&#034; value&#061;&#034;com.mysql.cj.jdbc.Driver&#034; \/&gt;<br \/>\n        &lt;property name&#061;&#034;jdbcUrl&#034; value&#061;&#034;jdbc:mysql:\/\/127.0.0.1:3306\/study_eesy?serverTimezone&#061;UTC&#034; \/&gt;<br \/>\n        &lt;property name&#061;&#034;user&#034; value&#061;&#034;root&#034; \/&gt;<br \/>\n        &lt;property name&#061;&#034;password&#034; value&#061;&#034;963123&#034; \/&gt;<\/p>\n<p>        &lt;!&#8211; \u8fde\u63a5\u6c60\u53c2\u6570 &#8211;&gt;<br \/>\n        &lt;property name&#061;&#034;initialPoolSize&#034; value&#061;&#034;5&#034; \/&gt;<br \/>\n        &lt;property name&#061;&#034;maxPoolSize&#034; value&#061;&#034;8&#034; \/&gt;<br \/>\n        &lt;property name&#061;&#034;checkoutTimeout&#034; value&#061;&#034;3000&#034; \/&gt;<br \/>\n    &lt;\/bean&gt;<\/p>\n<p>    &lt;!&#8211; 3. \u6574\u5408spring dataJpa<br \/>\n            dao\u63a5\u53e3\u6240\u5728\u5305<br \/>\n    &#8211;&gt;<br \/>\n    &lt;jpa:repositories base-package&#061;&#034;top.onefine.dao&#034;<br \/>\n                      transaction-manager-ref&#061;&#034;transactionManager&#034;<br \/>\n                      entity-manager-factory-ref&#061;&#034;entityManagerFactory&#034; \/&gt;<\/p>\n<p>    &lt;!&#8211; 4. \u914d\u7f6e\u4e8b\u52a1\u7ba1\u7406\u5668 &#8211;&gt;<br \/>\n    &lt;bean id&#061;&#034;transactionManager&#034; class&#061;&#034;org.springframework.orm.jpa.JpaTransactionManager&#034;&gt;<br \/>\n        &lt;property name&#061;&#034;entityManagerFactory&#034; ref&#061;&#034;entityManagerFactory&#034; \/&gt;<br \/>\n    &lt;\/bean&gt;<\/p>\n<p>    &lt;!&#8211; 4.txAdvice&#8211;&gt;<br \/>\n    &lt;tx:advice id&#061;&#034;txAdvice&#034; transaction-manager&#061;&#034;transactionManager&#034;&gt;<br \/>\n        &lt;tx:attributes&gt;<br \/>\n            &lt;tx:method name&#061;&#034;save*&#034; propagation&#061;&#034;REQUIRED&#034;\/&gt;<br \/>\n            &lt;tx:method name&#061;&#034;insert*&#034; propagation&#061;&#034;REQUIRED&#034;\/&gt;<br \/>\n            &lt;tx:method name&#061;&#034;update*&#034; propagation&#061;&#034;REQUIRED&#034;\/&gt;<br \/>\n            &lt;tx:method name&#061;&#034;delete*&#034; propagation&#061;&#034;REQUIRED&#034;\/&gt;<br \/>\n            &lt;tx:method name&#061;&#034;get*&#034; read-only&#061;&#034;true&#034;\/&gt;<br \/>\n            &lt;tx:method name&#061;&#034;find*&#034; read-only&#061;&#034;true&#034;\/&gt;<br \/>\n            &lt;tx:method name&#061;&#034;*&#034; propagation&#061;&#034;REQUIRED&#034;\/&gt;<br \/>\n        &lt;\/tx:attributes&gt;<br \/>\n    &lt;\/tx:advice&gt;<\/p>\n<p>    &lt;!&#8211; 5.aop&#8211;&gt;<br \/>\n    &lt;aop:config&gt;<br \/>\n        &lt;aop:pointcut id&#061;&#034;pointcut&#034; expression&#061;&#034;execution(* top.onefine.service.*.*(..))&#034; \/&gt;<br \/>\n        &lt;aop:advisor advice-ref&#061;&#034;txAdvice&#034; pointcut-ref&#061;&#034;pointcut&#034; \/&gt;<br \/>\n    &lt;\/aop:config&gt;<\/p>\n<p>    &lt;!&#8211; 5. \u914d\u7f6e\u58f0\u660e\u5f0f\u4e8b\u52a1 &#8211;&gt;<\/p>\n<p>    &lt;!&#8211; 6. \u914d\u7f6e\u5305\u626b\u63cf &#8211;&gt;<br \/>\n    &lt;context:component-scan base-package&#061;&#034;top.onefine&#034; \/&gt;<br \/>\n&lt;\/beans&gt;<\/p>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\dao\\\\CustomerDao.java&#xff1a;<\/p>\n<p>package top.onefine.dao;<\/p>\n<p>import org.springframework.data.jpa.repository.JpaRepository;<br \/>\nimport org.springframework.data.jpa.repository.JpaSpecificationExecutor;<br \/>\nimport top.onefine.domain.Customer;<\/p>\n<p>public interface CustomerDao extends JpaRepository&lt;Customer, Long&gt;, JpaSpecificationExecutor&lt;Customer&gt; {<br \/>\n}<\/p>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\dao\\\\LinkManDao.java&#xff1a;<\/p>\n<p>package top.onefine.dao;<\/p>\n<p>import org.springframework.data.jpa.repository.JpaRepository;<br \/>\nimport org.springframework.data.jpa.repository.JpaSpecificationExecutor;<br \/>\nimport top.onefine.domain.LinkMan;<\/p>\n<p>\/**<br \/>\n * \u8054\u7cfb\u4ebadao\u63a5\u53e3<br \/>\n *\/<br \/>\npublic interface LinkManDao extends JpaRepository&lt;LinkMan, Long&gt;, JpaSpecificationExecutor&lt;LinkMan&gt; {<br \/>\n}<\/p>\n<h5>3.4 \u6620\u5c04\u7684\u6ce8\u89e3\u8bf4\u660e<\/h5>\n<p>&#064;OneToMany:<br \/>\n   \u4f5c\u7528&#xff1a;\u5efa\u7acb\u4e00\u5bf9\u591a\u7684\u5173\u7cfb\u6620\u5c04<br \/>\n    \u5c5e\u6027&#xff1a;<br \/>\n    targetEntityClass&#xff1a;\u6307\u5b9a\u591a\u7684\u591a\u65b9\u7684\u7c7b\u7684\u5b57\u8282\u7801<br \/>\n    mappedBy&#xff1a;\u6307\u5b9a\u4ece\u8868\u5b9e\u4f53\u7c7b\u4e2d\u5f15\u7528\u4e3b\u8868\u5bf9\u8c61\u7684\u540d\u79f0\u3002<br \/>\n    cascade&#xff1a;\u6307\u5b9a\u8981\u4f7f\u7528\u7684\u7ea7\u8054\u64cd\u4f5c<br \/>\n    fetch&#xff1a;\u6307\u5b9a\u662f\u5426\u91c7\u7528\u5ef6\u8fdf\u52a0\u8f7d<br \/>\n    orphanRemoval&#xff1a;\u662f\u5426\u4f7f\u7528\u5b64\u513f\u5220\u9664<\/p>\n<p>&#064;ManyToOne<br \/>\n    \u4f5c\u7528&#xff1a;\u5efa\u7acb\u591a\u5bf9\u4e00\u7684\u5173\u7cfb<br \/>\n    \u5c5e\u6027&#xff1a;<br \/>\n    targetEntityClass&#xff1a;\u6307\u5b9a\u4e00\u7684\u4e00\u65b9\u5b9e\u4f53\u7c7b\u5b57\u8282\u7801<br \/>\n    cascade&#xff1a;\u6307\u5b9a\u8981\u4f7f\u7528\u7684\u7ea7\u8054\u64cd\u4f5c<br \/>\n    fetch&#xff1a;\u6307\u5b9a\u662f\u5426\u91c7\u7528\u5ef6\u8fdf\u52a0\u8f7d<br \/>\n    optional&#xff1a;\u5173\u8054\u662f\u5426\u53ef\u9009\u3002\u5982\u679c\u8bbe\u7f6e\u4e3afalse&#xff0c;\u5219\u5fc5\u987b\u59cb\u7ec8\u5b58\u5728\u975e\u7a7a\u5173\u7cfb\u3002<\/p>\n<p>&#064;JoinColumn<br \/>\n\u4f5c\u7528&#xff1a;\u7528\u4e8e\u5b9a\u4e49\u4e3b\u952e\u5b57\u6bb5\u548c\u5916\u952e\u5b57\u6bb5\u7684\u5bf9\u5e94\u5173\u7cfb\u3002<br \/>\n\u5c5e\u6027&#xff1a;<br \/>\nname&#xff1a;\u6307\u5b9a\u5916\u952e\u5b57\u6bb5\u7684\u540d\u79f0<br \/>\nreferencedColumnName&#xff1a;\u6307\u5b9a\u5f15\u7528\u4e3b\u8868\u7684\u4e3b\u952e\u5b57\u6bb5\u540d\u79f0<br \/>\nunique&#xff1a;\u662f\u5426\u552f\u4e00\u3002\u9ed8\u8ba4\u503c\u4e0d\u552f\u4e00<br \/>\nnullable&#xff1a;\u662f\u5426\u5141\u8bb8\u4e3a\u7a7a\u3002\u9ed8\u8ba4\u503c\u5141\u8bb8\u3002<br \/>\ninsertable&#xff1a;\u662f\u5426\u5141\u8bb8\u63d2\u5165\u3002\u9ed8\u8ba4\u503c\u5141\u8bb8\u3002<br \/>\nupdatable&#xff1a;\u662f\u5426\u5141\u8bb8\u66f4\u65b0\u3002\u9ed8\u8ba4\u503c\u5141\u8bb8\u3002<br \/>\ncolumnDefinition&#xff1a;\u5217\u7684\u5b9a\u4e49\u4fe1\u606f\u3002<\/p>\n<h5>3.5 \u4e00\u5bf9\u591a\u7684\u64cd\u4f5c<\/h5>\n<h6>3.5.1 \u6dfb\u52a0<\/h6>\n<h6>1 \u5ba2\u6237\u548c\u8054\u7cfb\u4eba\u4f5c\u4e3a\u72ec\u7acb\u7684\u6570\u636e\u4fdd\u5b58\u5230\u6570\u636e\u5e93\u4e2d&#xff1a;<\/h6>\n<p>package top.onefine.dao;<\/p>\n<p>import org.junit.Test;<br \/>\nimport org.junit.runner.RunWith;<br \/>\nimport org.springframework.beans.factory.annotation.Autowired;<\/p>\n<p>import org.springframework.test.annotation.Rollback;<br \/>\nimport org.springframework.test.context.ContextConfiguration;<br \/>\nimport org.springframework.test.context.junit4.SpringJUnit4ClassRunner;<br \/>\nimport org.springframework.transaction.annotation.Transactional;<br \/>\nimport top.onefine.domain.Customer;<br \/>\nimport top.onefine.domain.LinkMan;<\/p>\n<p>&#064;SuppressWarnings(&#034;All&#034;)<br \/>\n&#064;RunWith(SpringJUnit4ClassRunner.class)<br \/>\n&#064;ContextConfiguration(locations &#061; &#034;classpath:applicationContext.xml&#034;)<br \/>\npublic class One2ManyTest {<\/p>\n<p>    &#064;Autowired<br \/>\n    private CustomerDao customerDao;<\/p>\n<p>    &#064;Autowired<br \/>\n    private LinkManDao linkManDao;<\/p>\n<p>    \/**<br \/>\n     * \u4fdd\u5b58\u4e00\u4e2a\u5ba2\u6237&#xff0c;\u4fdd\u5b58\u4e00\u4e2a\u8054\u7cfb\u4eba<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u914d\u7f6e\u4e8b\u52a1<br \/>\n    &#064;Rollback(value &#061; false)  \/\/ \u8bbe\u7f6e\u4e0d\u81ea\u52a8\u56de\u6eda<br \/>\n    public void testAdd() {<br \/>\n        Customer customer &#061; new Customer();<br \/>\n        customer.setCustName(&#034;\u6d4b\u8bd5&#034;);<br \/>\n        customer.setCustLevel(&#034;\u91cd\u8981&#034;);<br \/>\n        LinkMan linkMan &#061; new LinkMan();<br \/>\n        linkMan.setLkmName(&#034;one fine&#034;);<\/p>\n<p>        customerDao.save(customer);<br \/>\n        linkManDao.save(linkMan);<br \/>\n    }<br \/>\n}<\/p>\n<p>\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table cst_linkman drop foreign key FKh9yp1nql5227xxcopuxqx2e7q<br \/>\nHibernate: drop table if exists cst_customer<br \/>\nHibernate: drop table if exists cst_linkman<br \/>\nHibernate: create table cst_customer (cust_id bigint not null auto_increment, cust_address varchar(255), cust_industry varchar(255), cust_level varchar(255), cust_name varchar(255), cust_phone varchar(255), cust_source varchar(255), primary key (cust_id))<br \/>\nHibernate: create table cst_linkman (lkm_id bigint not null auto_increment, lkm_email varchar(255), lkm_gender varchar(255), lkm_memo varchar(255), lkm_mobile varchar(255), lkm_name varchar(255), lkm_phone varchar(255), lkm_position varchar(255), lkm_cust_id bigint, primary key (lkm_id))<br \/>\nHibernate: alter table cst_linkman add constraint FKh9yp1nql5227xxcopuxqx2e7q foreign key (lkm_cust_id) references cst_customer (cust_id)<br \/>\nHibernate: insert into cst_customer (cust_address, cust_industry, cust_level, cust_name, cust_phone, cust_source) values (?, ?, ?, ?, ?, ?)<br \/>\nHibernate: insert into cst_linkman (lkm_cust_id, lkm_email, lkm_gender, lkm_memo, lkm_mobile, lkm_name, lkm_phone, lkm_position) values (?, ?, ?, ?, ?, ?, ?, ?)<\/p>\n<p>2 \u914d\u7f6e\u4e86\u5ba2\u6237\u5230\u8054\u7cfb\u4eba\u7684\u5173\u7cfb&#xff1a;<\/p>\n<p>&#064;SuppressWarnings(&#034;All&#034;)<br \/>\n&#064;RunWith(SpringJUnit4ClassRunner.class)<br \/>\n&#064;ContextConfiguration(locations &#061; &#034;classpath:applicationContext.xml&#034;)<br \/>\npublic class One2ManyTest {<\/p>\n<p>    &#064;Autowired<br \/>\n    private CustomerDao customerDao;<\/p>\n<p>    &#064;Autowired<br \/>\n    private LinkManDao linkManDao;<\/p>\n<p>    \/**<br \/>\n     * \u4fdd\u5b58\u4e00\u4e2a\u5ba2\u6237&#xff0c;\u4fdd\u5b58\u4e00\u4e2a\u8054\u7cfb\u4eba<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u914d\u7f6e\u4e8b\u52a1<br \/>\n    &#064;Rollback(value &#061; false)  \/\/ \u8bbe\u7f6e\u4e0d\u81ea\u52a8\u56de\u6eda<br \/>\n    public void testAdd() {<br \/>\n        Customer customer &#061; new Customer();<br \/>\n        customer.setCustName(&#034;\u6d4b\u8bd5&#034;);<br \/>\n        customer.setCustLevel(&#034;\u91cd\u8981&#034;);<br \/>\n        LinkMan linkMan &#061; new LinkMan();<br \/>\n        linkMan.setLkmName(&#034;one fine&#034;);<br \/>\n        \/*<br \/>\n            \u914d\u7f6e\u4e86\u5ba2\u6237\u5230\u8054\u7cfb\u4eba\u7684\u5173\u7cfb&#xff1a;<br \/>\n                \u4ece\u5ba2\u6237\u7684\u89d2\u5ea6\u4e0a&#xff0c;\u53d1\u9001\u4e24\u6761insert\u8bed\u53e5&#xff0c;\u53d1\u9001\u4e00\u6761\u66f4\u65b0\u8bed\u53e5\u66f4\u65b0\u6570\u636e\u5e93&#xff08;\u66f4\u65b0\u5916\u952e&#xff09;<br \/>\n                    \u7531\u4e8e\u914d\u7f6e\u4e86\u5ba2\u6237\u5230\u8054\u7cfb\u4eba\u7684\u5173\u7cfb&#xff1a;\u5ba2\u6237\u53ef\u4ee5\u5bf9\u5916\u952e\u8fdb\u884c\u7ef4\u62a4<br \/>\n         *\/<br \/>\n        customer.getLinkMans().add(linkMan);<\/p>\n<p>        customerDao.save(customer);<br \/>\n        linkManDao.save(linkMan);<br \/>\n    }<\/p>\n<p>}<\/p>\n<p>\u6548\u679c<\/p>\n<p>Hibernate: alter table cst_linkman drop foreign key FKh9yp1nql5227xxcopuxqx2e7q<br \/>\nHibernate: drop table if exists cst_customer<br \/>\nHibernate: drop table if exists cst_linkman<br \/>\nHibernate: create table cst_customer (cust_id bigint not null auto_increment, cust_address varchar(255), cust_industry varchar(255), cust_level varchar(255), cust_name varchar(255), cust_phone varchar(255), cust_source varchar(255), primary key (cust_id))<br \/>\nHibernate: create table cst_linkman (lkm_id bigint not null auto_increment, lkm_email varchar(255), lkm_gender varchar(255), lkm_memo varchar(255), lkm_mobile varchar(255), lkm_name varchar(255), lkm_phone varchar(255), lkm_position varchar(255), lkm_cust_id bigint, primary key (lkm_id))<br \/>\nHibernate: alter table cst_linkman add constraint FKh9yp1nql5227xxcopuxqx2e7q foreign key (lkm_cust_id) references cst_customer (cust_id)<br \/>\nHibernate: insert into cst_customer (cust_address, cust_industry, cust_level, cust_name, cust_phone, cust_source) values (?, ?, ?, ?, ?, ?)<br \/>\nHibernate: insert into cst_linkman (lkm_cust_id, lkm_email, lkm_gender, lkm_memo, lkm_mobile, lkm_name, lkm_phone, lkm_position) values (?, ?, ?, ?, ?, ?, ?, ?)<br \/>\nHibernate: update cst_linkman set lkm_cust_id&#061;? where lkm_id&#061;?<\/p>\n<p>3 \u914d\u7f6e\u4e86\u8054\u7cfb\u4eba\u5230\u5ba2\u6237\u7684\u5173\u7cfb&#xff1a;<\/p>\n<p>&#064;SuppressWarnings(&#034;All&#034;)<br \/>\n&#064;RunWith(SpringJUnit4ClassRunner.class)<br \/>\n&#064;ContextConfiguration(locations &#061; &#034;classpath:applicationContext.xml&#034;)<br \/>\npublic class One2ManyTest {<\/p>\n<p>    &#064;Autowired<br \/>\n    private CustomerDao customerDao;<\/p>\n<p>    &#064;Autowired<br \/>\n    private LinkManDao linkManDao;<\/p>\n<p>    \/**<br \/>\n     * \u4fdd\u5b58\u4e00\u4e2a\u5ba2\u6237&#xff0c;\u4fdd\u5b58\u4e00\u4e2a\u8054\u7cfb\u4eba<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u914d\u7f6e\u4e8b\u52a1<br \/>\n    &#064;Rollback(value &#061; false)  \/\/ \u8bbe\u7f6e\u4e0d\u81ea\u52a8\u56de\u6eda<br \/>\n    public void testAdd() {<br \/>\n        Customer customer &#061; new Customer();<br \/>\n        customer.setCustName(&#034;\u6d4b\u8bd5&#034;);<br \/>\n        customer.setCustLevel(&#034;\u91cd\u8981&#034;);<br \/>\n        LinkMan linkMan &#061; new LinkMan();<br \/>\n        linkMan.setLkmName(&#034;one fine&#034;);<br \/>\n        \/*<br \/>\n            \u914d\u7f6e\u8054\u7cfb\u4eba\u5230\u5ba2\u6237\u7684\u5173\u7cfb&#xff08;\u591a\u5bf9\u4e00&#xff09;<br \/>\n                \u53ea\u53d1\u9001\u4e86\u4e24\u6761insert\u8bed\u53e5&#xff1a;\u7531\u4e8e\u914d\u7f6e\u4e86\u8054\u7cfb\u4eba\u5230\u5ba2\u6237\u7684\u6620\u5c04\u5173\u7cfb&#xff08;\u591a\u5bf9\u4e00&#xff09;<br \/>\n         *\/<br \/>\n        linkMan.setCustomer(customer);<\/p>\n<p>        customerDao.save(customer);<br \/>\n        linkManDao.save(linkMan);<br \/>\n    }<\/p>\n<p>}<\/p>\n<p>\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table cst_linkman drop foreign key FKh9yp1nql5227xxcopuxqx2e7q<br \/>\nHibernate: drop table if exists cst_customer<br \/>\nHibernate: drop table if exists cst_linkman<br \/>\nHibernate: create table cst_customer (cust_id bigint not null auto_increment, cust_address varchar(255), cust_industry varchar(255), cust_level varchar(255), cust_name varchar(255), cust_phone varchar(255), cust_source varchar(255), primary key (cust_id))<br \/>\nHibernate: create table cst_linkman (lkm_id bigint not null auto_increment, lkm_email varchar(255), lkm_gender varchar(255), lkm_memo varchar(255), lkm_mobile varchar(255), lkm_name varchar(255), lkm_phone varchar(255), lkm_position varchar(255), lkm_cust_id bigint, primary key (lkm_id))<br \/>\nHibernate: alter table cst_linkman add constraint FKh9yp1nql5227xxcopuxqx2e7q foreign key (lkm_cust_id) references cst_customer (cust_id)<br \/>\nHibernate: insert into cst_customer (cust_address, cust_industry, cust_level, cust_name, cust_phone, cust_source) values (?, ?, ?, ?, ?, ?)<br \/>\nHibernate: insert into cst_linkman (lkm_cust_id, lkm_email, lkm_gender, lkm_memo, lkm_mobile, lkm_name, lkm_phone, lkm_position) values (?, ?, ?, ?, ?, ?, ?, ?)<\/p>\n<p>4 \u53cc\u5411\u7ed1\u5b9a&#xff1a;<\/p>\n<p>&#064;SuppressWarnings(&#034;All&#034;)<br \/>\n&#064;RunWith(SpringJUnit4ClassRunner.class)<br \/>\n&#064;ContextConfiguration(locations &#061; &#034;classpath:applicationContext.xml&#034;)<br \/>\npublic class One2ManyTest {<\/p>\n<p>    &#064;Autowired<br \/>\n    private CustomerDao customerDao;<\/p>\n<p>    &#064;Autowired<br \/>\n    private LinkManDao linkManDao;<\/p>\n<p>    \/**<br \/>\n     * \u4fdd\u5b58\u4e00\u4e2a\u5ba2\u6237&#xff0c;\u4fdd\u5b58\u4e00\u4e2a\u8054\u7cfb\u4eba<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u914d\u7f6e\u4e8b\u52a1<br \/>\n    &#064;Rollback(value &#061; false)  \/\/ \u8bbe\u7f6e\u4e0d\u81ea\u52a8\u56de\u6eda<br \/>\n    public void testAdd() {<br \/>\n        Customer customer &#061; new Customer();<br \/>\n        customer.setCustName(&#034;\u6d4b\u8bd5&#034;);<br \/>\n        customer.setCustLevel(&#034;\u91cd\u8981&#034;);<br \/>\n        LinkMan linkMan &#061; new LinkMan();<br \/>\n        linkMan.setLkmName(&#034;one fine&#034;);<\/p>\n<p>        \/*<br \/>\n            \u7531\u4e8e\u4e00\u7684\u4e00\u65b9\u53ef\u4ee5\u7ef4\u62a4\u5916\u952e&#xff0c;\u4f1a\u53d1\u9001\u4e00\u6761\u591a\u4f59update\u8bed\u53e5<br \/>\n                \u89e3\u51b3\u6b64\u95ee\u9898&#xff0c;\u53ea\u9700\u8981\u5728\u4e00\u7684\u4e00\u65b9\u653e\u5f03\u7ef4\u62a4\u6743\u5373\u53ef<br \/>\n                    &#064;OneToMany(mappedBy &#061; &#034;customer&#034;)<br \/>\n         *\/<br \/>\n        customer.getLinkMans().add(linkMan);  \/\/ \u53d1\u9001\u4e00\u6761update\u8bed\u53e5<br \/>\n        linkMan.setCustomer(customer);<\/p>\n<p>        customerDao.save(customer);<br \/>\n        linkManDao.save(linkMan);<br \/>\n    }<br \/>\n}<\/p>\n<p>\u76f4\u63a5\u6267\u884c&#xff1a;<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"348\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100257-68022351b5354.png\" width=\"1122\" \/><\/p>\n<p>\u8fd9\u91cc\u8e29\u4e86\u4e2a\u5751&#xff1a;<\/p>\n<p>\u5728\u8fdb\u884c\u4e00\u5bf9\u591a\u914d\u7f6e\u540e&#xff0c;\u5728\u6d4b\u8bd5\u65b9\u6cd5\u4e2d\u5c1d\u8bd5\u4f7f\u7528\u83b7\u53d6\u4e00\u65b9\u4fe1\u606f&#xff0c;\u7ed3\u679c\u51fa\u73b0\u4e86\u5185\u5b58\u6ea2\u51fa\u7684\u9519\u8bef\u3002<\/p>\n<p>\u603b\u7ed3\u4e00\u4e0b\u539f\u56e0\u4ee5\u53ca\u89e3\u51b3\u65b9\u6848&#xff1a;<\/p>\n<p>\u539f\u56e0\u4e00&#xff1a;\u4e3a\u4e86\u65b9\u4fbf\u770b\u4fe1\u606f,\u5728\u4e24\u7c7b\u4e2d\u5206\u522b\u91cd\u5199\u4e86 toString \u65b9\u6cd5,\u5bfc\u81f4\u67e5\u8be2\u52a0\u8f7d\u65f6\u4e24\u7c7b\u5728\u4e92\u76f8\u8c03\u7528\u5bf9\u65b9\u7684toString,\u5f62\u6210\u9012\u5f52,\u9020\u6210\u5185\u5b58\u6ea2\u51fa\u3002 \u89e3\u51b3\u65b9\u6848&#xff1a; \u5728 toString \u65b9\u6cd5\u4e2d\u4efb\u610f\u4e00\u65b9\u53bb\u9664\u6253\u5370\u7684\u5bf9\u65b9\u4fe1\u606f\u3002<\/p>\n<p>\u539f\u56e0\u4e8c&#xff1a; \u4e3a\u4e86\u7f16\u5199\u65b9\u4fbf\u7b80\u6d01&#xff0c;\u4ee3\u7801\u66f4\u52a0\u4f18\u96c5&#xff0c;\u4f7f\u7528\u4e86 lombok \u63d2\u4ef6\u4e2d\u7684&#064;Data\u4ee5\u53ca&#064;ToString\u6ce8\u89e3\u6765\u6807\u6ce8\u7c7b&#xff0c;\u8ba9 lombok \u6765\u4ee3\u66ff\u751f\u6210 gettet\/setter \u4ee5\u53ca toString&#xff0c;\u4f46\u662f lombok \u5728\u751f\u6210\u65f6\u4f1a\u51fa\u73b0\u5faa\u73af\u6bd4\u8f83\u4e24\u7c7b\u4e2d\u7684 hashcode&#xff0c;\u5bfc\u81f4\u5185\u5b58\u6ea2\u51fa\u3002 \u89e3\u51b3\u65b9\u6848&#xff1a; \u4e0d\u8981\u4f7f\u7528 lombok &#xff0c;\u81ea\u5df1\u624b\u5199\u3002<\/p>\n<p>\u53c2\u8003&#xff1a; https:\/\/blog.csdn.net\/weixin_43464964\/article\/details\/90669843<\/p>\n<p>\u66f4\u6539&#xff1a;src\\\\main\\\\java\\\\top\\\\onefine\\\\domain\\\\Customer.java<\/p>\n<p>package top.onefine.domain;<\/p>\n<p>import lombok.*;<\/p>\n<p>import javax.persistence.*;<br \/>\nimport java.util.HashSet;<br \/>\nimport java.util.Set;<\/p>\n<p>\/**<br \/>\n * 1. \u5b9e\u4f53\u7c7b\u548c\u8868\u7684\u6620\u5c04\u5173\u7cfb<br \/>\n *      -&#064;Eitity<br \/>\n *      -&#064;Table<br \/>\n * 2. \u7c7b\u4e2d\u5c5e\u6027\u548c\u6570\u636e\u5e93\u8868\u4e2d\u5b57\u6bb5\u7684\u6620\u5c04\u5173\u7cfb<br \/>\n *      -&#064;Id \u4e3b\u952e<br \/>\n *      -&#064;GeneratedValue \u4e3b\u952e\u751f\u6210\u7b56\u7565<br \/>\n *      -&#064;Column<br \/>\n *\/<br \/>\n&#064;Entity<br \/>\n&#064;Table(name &#061; &#034;cst_customer&#034;)<br \/>\n\/\/&#064;Data  \/\/ \u4f7f\u7528&#064;Getter\u548c&#064;Setter&#xff0c;\u4f46\u662f\u8981\u81ea\u5df1\u751f\u6210toString\u65b9\u6cd5<br \/>\n&#064;Getter<br \/>\n&#064;Setter<br \/>\n&#064;NoArgsConstructor<br \/>\npublic class Customer {<br \/>\n    &#064;Id<br \/>\n    &#064;GeneratedValue(strategy &#061; GenerationType.IDENTITY)<br \/>\n    &#064;Column(name &#061; &#034;cust_id&#034;)<br \/>\n    private Long custId;<br \/>\n    &#064;Column(name &#061; &#034;cust_address&#034;)<br \/>\n    private String custAddress;<br \/>\n    &#064;Column(name &#061; &#034;cust_industry&#034;)<br \/>\n    private String custIndustry;<br \/>\n    &#064;Column(name &#061; &#034;cust_level&#034;)<br \/>\n    private String custLevel;<br \/>\n    &#064;Column(name &#061; &#034;cust_name&#034;)<br \/>\n    private String custName;<br \/>\n    &#064;Column(name &#061; &#034;cust_phone&#034;)<br \/>\n    private String custPhone;<br \/>\n    &#064;Column(name &#061; &#034;cust_source&#034;)<br \/>\n    private String custSource;<\/p>\n<p>    \/\/ \u914d\u7f6e\u5ba2\u6237\u548c\u8054\u7cfb\u4eba\u4e4b\u95f4\u7684\u5173\u7cfb&#xff08;\u4e00\u5bf9\u591a\u5173\u7cfb&#xff09;<br \/>\n    \/*<br \/>\n        \u4f7f\u7528\u6ce8\u89e3\u7684\u5f62\u5f0f\u914d\u7f6e\u591a\u8868\u5173\u7cfb&#xff1a;<br \/>\n            1. \u58f0\u660e\u5173\u7cfb<br \/>\n                &#8211; &#064;OneToMany&#xff1a;\u914d\u7f6e\u4e00\u5bf9\u591a\u5173\u7cfb<br \/>\n                    targetEntity&#xff1a;\u5bf9\u65b9\u5bf9\u8c61\u7684\u5b57\u8282\u7801\u5bf9\u8c61<br \/>\n            2. \u914d\u7f6e\u5916\u952e&#xff08;\u6216\u4e2d\u95f4\u8868&#xff09;<br \/>\n                &#8211; &#064;JoinColumn&#xff1a;\u914d\u7f6e\u5916\u952e<br \/>\n                    name&#xff1a;\u4ece\u8868 \u5916\u952e\u5b57\u6bb5\u540d\u79f0<br \/>\n                    referencedColumnName&#xff1a;\u53c2\u7167\u7684 \u4e3b\u8868 \u7684\u4e3b\u952e\u5b57\u6bb5\u540d\u79f0<\/p>\n<p>        \u6ce8&#xff1a;\u5728\u5ba2\u6237\u5b9e\u4f53\u7c7b\u4e0a&#xff08;\u4e00\u7684\u4e00\u65b9&#xff09;\u6dfb\u52a0\u4e86\u5916\u952e\u7684\u914d\u7f6e&#xff0c;\u6240\u4ee5\u5bf9\u4e8e\u5ba2\u6237\u800c\u8a00&#xff0c;\u4e5f\u5177\u5907\u4e86\u7ef4\u62a4\u5916\u952e\u7684\u4f5c\u7528<\/p>\n<p>     *\/<br \/>\n    &#064;OneToMany(targetEntity &#061; LinkMan.class)<br \/>\n    &#064;JoinColumn(name &#061; &#034;lkm_cust_id&#034;, referencedColumnName &#061; &#034;cust_id&#034;)<br \/>\n    \/*<br \/>\n        \u653e\u5f03\u5916\u952e\u7ef4\u62a4\u6743<br \/>\n            mappedBy: \u5bf9\u65b9\u914d\u7f6e\u5173\u7cfb\u7684\u5c5e\u6027\u540d\u79f0<br \/>\n                \u8868\u793a\u53c2\u7167\u5bf9\u65b9\u7684\u5c5e\u6027\u6765\u505a<br \/>\n     *\/<br \/>\n\/\/    &#064;OneToMany(mappedBy &#061; &#034;customer&#034;)<br \/>\n    private Set&lt;LinkMan&gt; linkMans &#061; new HashSet&lt;&gt;();<\/p>\n<p>    \/\/ \u4e00\u5b9a\u8981\u81ea\u5df1\u5199&#xff0c;\u4e0d\u8981\u4f7f\u7528lombok\u63d0\u4f9b\u7684<br \/>\n    &#064;Override<br \/>\n    public String toString() {<br \/>\n        return &#034;Customer{&#034; &#043;<br \/>\n                &#034;custId&#061;&#034; &#043; custId &#043;<br \/>\n                &#034;, custAddress&#061;&#039;&#034; &#043; custAddress &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custIndustry&#061;&#039;&#034; &#043; custIndustry &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custLevel&#061;&#039;&#034; &#043; custLevel &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custName&#061;&#039;&#034; &#043; custName &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custPhone&#061;&#039;&#034; &#043; custPhone &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custSource&#061;&#039;&#034; &#043; custSource &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, linkMans&#061;&#034; &#043; linkMans &#043;<br \/>\n                &#039;}&#039;;<br \/>\n    }<br \/>\n}<\/p>\n<p>\u91cd\u65b0\u6267\u884c&#xff0c;\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table cst_linkman drop foreign key FKh9yp1nql5227xxcopuxqx2e7q<br \/>\nHibernate: drop table if exists cst_customer<br \/>\nHibernate: drop table if exists cst_linkman<br \/>\nHibernate: create table cst_customer (cust_id bigint not null auto_increment, cust_address varchar(255), cust_industry varchar(255), cust_level varchar(255), cust_name varchar(255), cust_phone varchar(255), cust_source varchar(255), primary key (cust_id))<br \/>\nHibernate: create table cst_linkman (lkm_id bigint not null auto_increment, lkm_email varchar(255), lkm_gender varchar(255), lkm_memo varchar(255), lkm_mobile varchar(255), lkm_name varchar(255), lkm_phone varchar(255), lkm_position varchar(255), lkm_cust_id bigint, primary key (lkm_id))<br \/>\nHibernate: alter table cst_linkman add constraint FKh9yp1nql5227xxcopuxqx2e7q foreign key (lkm_cust_id) references cst_customer (cust_id)<br \/>\nHibernate: insert into cst_customer (cust_address, cust_industry, cust_level, cust_name, cust_phone, cust_source) values (?, ?, ?, ?, ?, ?)<br \/>\nHibernate: insert into cst_linkman (lkm_cust_id, lkm_email, lkm_gender, lkm_memo, lkm_mobile, lkm_name, lkm_phone, lkm_position) values (?, ?, ?, ?, ?, ?, ?, ?)<br \/>\nHibernate: update cst_linkman set lkm_cust_id&#061;? where lkm_id&#061;?<\/p>\n<p>\u901a\u8fc7\u4fdd\u5b58\u7684\u6848\u4f8b&#xff0c;\u6211\u4eec\u53ef\u4ee5\u53d1\u73b0\u5728\u8bbe\u7f6e\u4e86\u53cc\u5411\u5173\u7cfb\u4e4b\u540e&#xff0c;\u4f1a\u53d1\u9001\u4e24\u6761insert\u8bed\u53e5&#xff0c;\u4e00\u6761\u591a\u4f59\u7684update\u8bed\u53e5&#xff0c;\u90a3\u6211\u4eec\u7684\u89e3\u51b3\u662f\u601d\u8def\u5f88\u7b80\u5355&#xff0c;\u5c31\u662f\u4e00\u7684\u4e00\u65b9\u653e\u5f03\u7ef4\u62a4\u6743&#xff0c;\u5728src\\\\main\\\\java\\\\top\\\\onefine\\\\domain\\\\Customer.java\u4e2d&#xff1a;<\/p>\n<p>\/\/ \u653e\u5f03\u5916\u952e\u7ef4\u62a4\u6743\u7684\u914d\u7f6e\u5c06\u5982\u4e0b\u914d\u7f6e\u6539\u4e3a<br \/>\n\/\/    &#064;OneToMany(targetEntity &#061; LinkMan.class)<br \/>\n\/\/    &#064;JoinColumn(name &#061; &#034;lkm_cust_id&#034;, referencedColumnName &#061; &#034;cust_id&#034;)<br \/>\n    \/*<br \/>\n        \u653e\u5f03\u5916\u952e\u7ef4\u62a4\u6743<br \/>\n            mappedBy: \u5bf9\u65b9\u914d\u7f6e\u5173\u7cfb\u7684\u5c5e\u6027\u540d\u79f0<br \/>\n                \u8868\u793a\u53c2\u7167\u5bf9\u65b9\u7684\u5c5e\u6027\u6765\u505a<br \/>\n     *\/<br \/>\n     \/\/ \u8bbe\u7f6e\u4e3a<br \/>\n    &#064;OneToMany(mappedBy &#061; &#034;customer&#034;)<br \/>\n    private Set&lt;LinkMan&gt; linkMans &#061; new HashSet&lt;&gt;();<\/p>\n<p>\u91cd\u65b0\u6267\u884c\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table cst_linkman drop foreign key FKh9yp1nql5227xxcopuxqx2e7q<br \/>\nHibernate: drop table if exists cst_customer<br \/>\nHibernate: drop table if exists cst_linkman<br \/>\nHibernate: create table cst_customer (cust_id bigint not null auto_increment, cust_address varchar(255), cust_industry varchar(255), cust_level varchar(255), cust_name varchar(255), cust_phone varchar(255), cust_source varchar(255), primary key (cust_id))<br \/>\nHibernate: create table cst_linkman (lkm_id bigint not null auto_increment, lkm_email varchar(255), lkm_gender varchar(255), lkm_memo varchar(255), lkm_mobile varchar(255), lkm_name varchar(255), lkm_phone varchar(255), lkm_position varchar(255), lkm_cust_id bigint, primary key (lkm_id))<br \/>\nHibernate: alter table cst_linkman add constraint FKh9yp1nql5227xxcopuxqx2e7q foreign key (lkm_cust_id) references cst_customer (cust_id)<br \/>\nHibernate: insert into cst_customer (cust_address, cust_industry, cust_level, cust_name, cust_phone, cust_source) values (?, ?, ?, ?, ?, ?)<br \/>\nHibernate: insert into cst_linkman (lkm_cust_id, lkm_email, lkm_gender, lkm_memo, lkm_mobile, lkm_name, lkm_phone, lkm_position) values (?, ?, ?, ?, ?, ?, ?, ?)<\/p>\n<h6>3.5.2 \u5220\u9664<\/h6>\n<p>&#064;Autowired<br \/>\nprivate CustomerDao customerDao;<\/p>\n<p>&#064;Test<br \/>\n&#064;Transactional<br \/>\n&#064;Rollback(false)\/\/\u8bbe\u7f6e\u4e3a\u4e0d\u56de\u6eda<br \/>\npublic void testDelete() {<br \/>\ncustomerDao.delete(1l);<br \/>\n}<\/p>\n<p>\u5220\u9664\u64cd\u4f5c\u7684\u8bf4\u660e\u5982\u4e0b&#xff1a;<\/p>\n<ul>\n<li>\n<p>\u5220\u9664\u4ece\u8868\u6570\u636e&#xff1a;\u53ef\u4ee5\u968f\u65f6\u4efb\u610f\u5220\u9664\u3002<\/p>\n<\/li>\n<li>\n<p>\u5220\u9664\u4e3b\u8868\u6570\u636e&#xff1a;<\/p>\n<p>\u6709\u4ece\u8868\u6570\u636e 1\u3001\u5728\u9ed8\u8ba4\u60c5\u51b5\u4e0b&#xff0c;\u5b83\u4f1a\u628a\u5916\u952e\u5b57\u6bb5\u7f6e\u4e3anull&#xff0c;\u7136\u540e\u5220\u9664\u4e3b\u8868\u6570\u636e\u3002\u5982\u679c\u5728\u6570\u636e\u5e93\u7684\u8868 \u7ed3\u6784\u4e0a&#xff0c;\u5916\u952e\u5b57\u6bb5\u6709\u975e\u7a7a\u7ea6\u675f&#xff0c;\u9ed8\u8ba4\u60c5\u51b5\u5c31\u4f1a\u62a5\u9519\u4e86\u3002 2\u3001\u5982\u679c\u914d\u7f6e\u4e86\u653e\u5f03\u7ef4\u62a4\u5173\u8054\u5173\u7cfb\u7684\u6743\u5229&#xff0c;\u5219\u4e0d\u80fd\u5220\u9664&#xff08;\u4e0e\u5916\u952e\u5b57\u6bb5\u662f\u5426\u5141\u8bb8\u4e3anull&#xff0c; \u6ca1\u6709\u5173\u7cfb&#xff09;\u56e0\u4e3a\u5728\u5220\u9664\u65f6&#xff0c;\u5b83\u6839\u672c\u4e0d\u4f1a\u53bb\u66f4\u65b0\u4ece\u8868\u7684\u5916\u952e\u5b57\u6bb5\u4e86\u3002 3\u3001\u5982\u679c\u8fd8\u60f3\u5220\u9664&#xff0c;\u4f7f\u7528\u7ea7\u8054\u5220\u9664\u5f15\u7528<\/p>\n<p>\u6ca1\u6709\u4ece\u8868\u6570\u636e\u5f15\u7528&#xff1a;\u968f\u4fbf\u5220<\/p>\n<\/li>\n<\/ul>\n<p>\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d&#xff0c;\u7ea7\u8054\u5220\u9664\u8bf7\u614e\u7528&#xff01;(\u5728\u4e00\u5bf9\u591a\u7684\u60c5\u51b5\u4e0b)<\/p>\n<h6>3.5.3 \u7ea7\u8054\u64cd\u4f5c<\/h6>\n<p>\u7ea7\u8054\u64cd\u4f5c&#xff1a;\u6307\u64cd\u4f5c\u4e00\u4e2a\u5bf9\u8c61\u540c\u65f6\u64cd\u4f5c\u5b83\u7684\u5173\u8054\u5bf9\u8c61\u3002\u6709\u7ea7\u8054\u5220\u9664\u3001\u7ea7\u8054\u66f4\u65b0\u3001\u7ea7\u8054\u6dfb\u52a0\u2026<\/p>\n<ul>\n<li>\u7ea7\u8054\u6dfb\u52a0&#xff1a;\u4fdd\u5b58\u5ba2\u6237\u7684\u65f6\u5019\u540c\u65f6\u4fdd\u5b58\u8054\u7cfb\u4eba<\/li>\n<li>\u7ea7\u8054\u5220\u9664&#xff1a;\u5220\u9664\u5ba2\u6237\u7684\u65f6\u5019\u540c\u65f6\u5220\u9664\u6b64\u5ba2\u6237\u7684\u6240\u6709\u8054\u7cfb\u4eba<\/li>\n<\/ul>\n<p>\u4f7f\u7528\u65b9\u6cd5&#xff1a;\u53ea\u9700\u8981\u5728\u64cd\u4f5c\u4e3b\u4f53\u7684\u5b9e\u4f53\u7c7b\u4e0a\u6dfb\u52a0\u7ea7\u8054\u5c5e\u6027\u2014\u2014\u9700\u8981\u6dfb\u52a0\u5230\u591a\u8868\u6620\u5c04\u5173\u7cfb\u7684\u6ce8\u89e3\u4e0a&#xff0c;\u5373\u6ce8\u89e3\u4e0a\u914d\u7f6ecascade&#xff08;\u4f5c\u7528&#xff1a;\u914d\u7f6e\u7ea7\u8054&#xff09;<\/p>\n<p>\u6ce8\u610f\u533a\u5206\u64cd\u4f5c\u4e3b\u4f53<\/p>\n<p>\/**<br \/>\n * cascade:\u914d\u7f6e\u7ea7\u8054\u64cd\u4f5c<br \/>\n * CascadeType.MERGE\u7ea7\u8054\u66f4\u65b0<br \/>\n * CascadeType.PERSIST\u7ea7\u8054\u4fdd\u5b58&#xff1a;<br \/>\n * CascadeType.REFRESH \u7ea7\u8054\u5237\u65b0&#xff1a;<br \/>\n * CascadeType.REMOVE\u7ea7\u8054\u5220\u9664&#xff1a;<br \/>\n * CascadeType.ALL\u5305\u542b\u4ee5\u4e0a\u6240\u6709<br \/>\n *\/<br \/>\n&#064;OneToMany(mappedBy&#061;&#034;customer&#034;,cascade&#061;CascadeType.ALL)<\/p>\n<h6>\u7ea7\u8054\u6dfb\u52a0&#xff1a;<\/h6>\n<p>src\\\\main\\\\resources\\\\applicationContext.xml\u4e2d&#xff1a;<\/p>\n<p>&lt;bean&gt;<br \/>\n    &lt;property name&#061;&#034;jpaProperties&#034;&gt;<br \/>\n            &lt;props&gt;<br \/>\n                &lt;prop key&#061;&#034;hibernate.hbm2ddl.auto&#034;&gt;update&lt;\/prop&gt;<br \/>\n            &lt;\/props&gt;<br \/>\n        &lt;\/property&gt;<br \/>\n    &lt;\/bean&gt;<\/p>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\domain\\\\Customer.java\u4e2d&#xff1a;<\/p>\n<p>\/*<br \/>\n        \u653e\u5f03\u5916\u952e\u7ef4\u62a4\u6743<br \/>\n            mappedBy: \u5bf9\u65b9\u914d\u7f6e\u5173\u7cfb\u7684\u5c5e\u6027\u540d\u79f0<br \/>\n                \u8868\u793a\u53c2\u7167\u5bf9\u65b9\u7684\u5c5e\u6027\u6765\u505a<\/p>\n<p>            cascade:\u914d\u7f6e\u7ea7\u8054\u64cd\u4f5c&#xff0c;\u53ef\u4ee5\u914d\u7f6e\u5230\u8bbe\u7f6e\u591a\u8868\u7684\u6620\u5c04\u5173\u7cfb\u7684\u6ce8\u89e3\u4e0a<br \/>\n            * CascadeType.MERGE\u7ea7\u8054\u66f4\u65b0<br \/>\n            * CascadeType.PERSIST\u7ea7\u8054\u4fdd\u5b58&#xff1a;<br \/>\n            * CascadeType.REFRESH \u7ea7\u8054\u5237\u65b0&#xff1a;<br \/>\n            * CascadeType.REMOVE\u7ea7\u8054\u5220\u9664&#xff1a;<br \/>\n            * CascadeType.ALL\u5305\u542b\u4ee5\u4e0a\u6240\u6709&#xff0c;\u63a8\u8350\u914d\u7f6e<br \/>\n     *\/<br \/>\n    &#064;OneToMany(mappedBy &#061; &#034;customer&#034;, cascade &#061; CascadeType.ALL)<br \/>\n    private Set&lt;LinkMan&gt; linkMans &#061; new HashSet&lt;&gt;();<\/p>\n<p>\/\/ \u7ea7\u8054\u6dfb\u52a0&#xff1a;\u4fdd\u5b58\u4e00\u4e2a\u5ba2\u6237\u7684\u540c\u65f6&#xff0c;\u4fdd\u5b58\u8be5\u5ba2\u6237\u7684\u6240\u6709\u8054\u7cfb\u4eba<br \/>\n    \/\/ \u9700\u8981\u5728\u64cd\u4f5c\u4e3b\u4f53\u7684\u5b9e\u4f53\u7c7b\u4e0a&#xff0c;\u914d\u7f6ecasacde\u5c5e\u6027<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u914d\u7f6e\u4e8b\u52a1<br \/>\n    &#064;Rollback(false)  \/\/ \u4e0d\u81ea\u52a8\u56de\u6eda<br \/>\n    public void testCascadeAdd() {<br \/>\n        Customer customer &#061; new Customer();<br \/>\n        customer.setCustName(&#034;\u767e\u5ea61&#034;);<br \/>\n        LinkMan linkMan1 &#061; new LinkMan();<br \/>\n        linkMan1.setLkmName(&#034;\u5c0f\u738b1&#034;);<br \/>\n        LinkMan linkMan2 &#061; new LinkMan();<br \/>\n        linkMan2.setLkmName(&#034;\u5c0f\u738b2&#034;);<\/p>\n<p>        customer.getLinkMans().add(linkMan1);<br \/>\n        customer.getLinkMans().add(linkMan2);<br \/>\n        linkMan1.setCustomer(customer);<br \/>\n        linkMan2.setCustomer(customer);<\/p>\n<p>        customerDao.save(customer);  \/\/ \u64cd\u4f5c\u7684\u4e3b\u4f53\u662fCustomer<br \/>\n    }<\/p>\n<p>\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: insert into cst_customer (cust_address, cust_industry, cust_level, cust_name, cust_phone, cust_source) values (?, ?, ?, ?, ?, ?)<br \/>\nHibernate: insert into cst_linkman (lkm_cust_id, lkm_email, lkm_gender, lkm_memo, lkm_mobile, lkm_name, lkm_phone, lkm_position) values (?, ?, ?, ?, ?, ?, ?, ?)<br \/>\nHibernate: insert into cst_linkman (lkm_cust_id, lkm_email, lkm_gender, lkm_memo, lkm_mobile, lkm_name, lkm_phone, lkm_position) values (?, ?, ?, ?, ?, ?, ?, ?)<\/p>\n<p>\u7ea7\u8054\u5220\u9664&#xff1a;<\/p>\n<p>\/\/ \u7ea7\u8054\u5220\u9664&#xff1a;\u5220\u96642\u53f7\u5ba2\u6237&#xff08;\u4e0a\u4e2a\u7ea7\u8054\u6dfb\u52a0\u6dfb\u52a0\u7684\u6570\u636e&#xff09;\u7684\u540c\u65f6&#xff0c;\u5220\u96642\u53f7\u5ba2\u6237\u7684\u6240\u6709\u8054\u7cfb\u4eba<br \/>\n    \/\/ \u9700\u8981\u5728\u64cd\u4f5c\u4e3b\u4f53\u7684\u5b9e\u4f53\u7c7b\u4e0a&#xff0c;\u914d\u7f6ecasacde\u5c5e\u6027<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u914d\u7f6e\u4e8b\u52a1<br \/>\n    &#064;Rollback(false)  \/\/ \u4e0d\u81ea\u52a8\u56de\u6eda<br \/>\n    public void testCascadeRemove() {<br \/>\n        \/\/ 1. \u67e5\u8be2\u5ba2\u6237<br \/>\n        Customer customer &#061; customerDao.findOne(2L);<br \/>\n        \/\/ 2. \u5220\u96642\u53f7\u5ba2\u6237<br \/>\n        customerDao.delete(customer);<br \/>\n    }<\/p>\n<p>\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: select customer0_.cust_id as cust_id1_0_0_, customer0_.cust_address as cust_add2_0_0_, customer0_.cust_industry as cust_ind3_0_0_, customer0_.cust_level as cust_lev4_0_0_, customer0_.cust_name as cust_nam5_0_0_, customer0_.cust_phone as cust_pho6_0_0_, customer0_.cust_source as cust_sou7_0_0_ from cst_customer customer0_ where customer0_.cust_id&#061;?<br \/>\nHibernate: select linkmans0_.lkm_cust_id as lkm_cust9_1_0_, linkmans0_.lkm_id as lkm_id1_1_0_, linkmans0_.lkm_id as lkm_id1_1_1_, linkmans0_.lkm_cust_id as lkm_cust9_1_1_, linkmans0_.lkm_email as lkm_emai2_1_1_, linkmans0_.lkm_gender as lkm_gend3_1_1_, linkmans0_.lkm_memo as lkm_memo4_1_1_, linkmans0_.lkm_mobile as lkm_mobi5_1_1_, linkmans0_.lkm_name as lkm_name6_1_1_, linkmans0_.lkm_phone as lkm_phon7_1_1_, linkmans0_.lkm_position as lkm_posi8_1_1_ from cst_linkman linkmans0_ where linkmans0_.lkm_cust_id&#061;?<br \/>\nHibernate: delete from cst_linkman where lkm_id&#061;?<br \/>\nHibernate: delete from cst_linkman where lkm_id&#061;?<br \/>\nHibernate: delete from cst_customer where cust_id&#061;?<\/p>\n<h4>\u56db\u3001JPA\u4e2d\u7684\u591a\u5bf9\u591a<\/h4>\n<h5>4.1 \u793a\u4f8b\u5206\u6790<\/h5>\n<p>\u91c7\u7528\u7684\u793a\u4f8b\u4e3a\u7528\u6237\u548c\u89d2\u8272\u3002<\/p>\n<ul>\n<li>\n<p>\u7528\u6237&#xff1a;\u6307\u7684\u662f\u54b1\u4eec\u73ed\u7684\u6bcf\u4e00\u4e2a\u540c\u5b66\u3002<\/p>\n<\/li>\n<li>\n<p>\u89d2\u8272&#xff1a;\u6307\u7684\u662f\u54b1\u4eec\u73ed\u540c\u5b66\u7684\u8eab\u4efd\u4fe1\u606f\u3002<\/p>\n<\/li>\n<\/ul>\n<p>\u6bd4\u5982A\u540c\u5b66&#xff0c;\u5b83\u662f\u6211\u7684\u5b66\u751f&#xff0c;\u5176\u4e2d\u6709\u4e2a\u8eab\u4efd\u5c31\u662f\u5b66\u751f&#xff0c;\u8fd8\u662f\u5bb6\u91cc\u7684\u5b69\u5b50&#xff0c;\u90a3\u4e48\u4ed6\u8fd8\u6709\u4e2a\u8eab\u4efd\u662f\u5b50\u5973\u3002<\/p>\n<p>\u540c\u65f6B\u540c\u5b66&#xff0c;\u5b83\u4e5f\u5177\u6709\u5b66\u751f\u548c\u5b50\u5973\u7684\u8eab\u4efd\u3002<\/p>\n<p>\u90a3\u4e48\u4efb\u4f55\u4e00\u4e2a\u540c\u5b66\u90fd\u53ef\u80fd\u5177\u6709\u591a\u4e2a\u8eab\u4efd\u3002\u540c\u65f6\u5b66\u751f\u8fd9\u4e2a\u8eab\u4efd\u53ef\u4ee5\u88ab\u591a\u4e2a\u540c\u5b66\u6240\u5177\u6709\u3002<\/p>\n<p>\u6240\u4ee5\u6211\u4eec\u8bf4&#xff0c;\u7528\u6237\u548c\u89d2\u8272\u4e4b\u95f4\u7684\u5173\u7cfb\u662f\u591a\u5bf9\u591a\u3002<\/p>\n<p>\u5206\u6790\u6b65\u9aa4&#xff1a;<\/p>\n<p>1.\u660e\u786e\u8868\u5173\u7cfb&#xff1a;\u591a\u5bf9\u591a\u5173\u7cfb 2.\u786e\u5b9a\u8868\u5173\u7cfb&#xff08;\u63cf\u8ff0 \u5916\u952e|\u4e2d\u95f4\u8868&#xff09;&#xff1a;\u4e2d\u95f4\u95f4\u8868 3.\u7f16\u5199\u5b9e\u4f53\u7c7b&#xff0c;\u518d\u5b9e\u4f53\u7c7b\u4e2d\u63cf\u8ff0\u8868\u5173\u7cfb&#xff08;\u5305\u542b\u5173\u7cfb&#xff09;<\/p>\n<ul>\n<li>\u7528\u6237&#xff1a;\u5305\u542b\u89d2\u8272\u7684\u96c6\u5408<\/li>\n<li>\u89d2\u8272&#xff1a;\u5305\u542b\u7528\u6237\u7684\u96c6\u5408<\/li>\n<\/ul>\n<p>4.\u914d\u7f6e\u6620\u5c04\u5173\u7cfb<\/p>\n<h5>4.2 \u8868\u5173\u7cfb\u5efa\u7acb<\/h5>\n<p>\u591a\u5bf9\u591a\u7684\u8868\u5173\u7cfb\u5efa\u7acb\u9760\u7684\u662f\u4e2d\u95f4\u8868&#xff0c;\u5176\u4e2d\u7528\u6237\u8868\u548c\u4e2d\u95f4\u8868\u7684\u5173\u7cfb\u662f\u4e00\u5bf9\u591a&#xff0c;\u89d2\u8272\u8868\u548c\u4e2d\u95f4\u8868\u7684\u5173\u7cfb\u4e5f\u662f\u4e00\u5bf9\u591a&#xff0c;\u5982\u4e0b\u56fe\u6240\u793a&#xff1a;<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"336\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100257-68022351e29c8.png\" width=\"760\" \/><\/p>\n<h5>4.3 \u5b9e\u4f53\u7c7b\u5173\u7cfb\u5efa\u7acb\u4ee5\u53ca\u6620\u5c04\u914d\u7f6e<\/h5>\n<p>\u4e00\u4e2a\u7528\u6237\u53ef\u4ee5\u5177\u6709\u591a\u4e2a\u89d2\u8272&#xff0c;\u6240\u4ee5\u5728\u7528\u6237\u5b9e\u4f53\u7c7b\u4e2d\u5e94\u8be5\u5305\u542b\u591a\u4e2a\u89d2\u8272\u7684\u4fe1\u606f&#xff0c;\u4ee3\u7801\u5982\u4e0b&#xff1a;<\/p>\n<p>package top.onefine.domain;<\/p>\n<p>import lombok.Getter;<br \/>\nimport lombok.Setter;<\/p>\n<p>import javax.persistence.*;<br \/>\nimport java.util.HashSet;<br \/>\nimport java.util.Set;<\/p>\n<p>&#064;Entity<br \/>\n&#064;Table(name &#061; &#034;sys_user&#034;)<br \/>\n&#064;Getter<br \/>\n&#064;Setter<br \/>\npublic class User {<br \/>\n    &#064;Id<br \/>\n    &#064;GeneratedValue(strategy &#061; GenerationType.IDENTITY)<br \/>\n    &#064;Column(name &#061; &#034;user_id&#034;)<br \/>\n    private Long userId;<br \/>\n    &#064;Column(name &#061; &#034;user_name&#034;)<br \/>\n    private String userName;<br \/>\n    &#064;Column(name &#061; &#034;user_age&#034;)<br \/>\n    private Integer age;<\/p>\n<p>    \/\/ \u914d\u7f6e\u7528\u6237\u5230\u89d2\u8272\u7684\u591a\u5bf9\u591a\u5173\u7cfb<br \/>\n    \/**<br \/>\n     * \u914d\u7f6e\u591a\u5bf9\u591a\u7684\u6620\u5c04\u5173\u7cfb<br \/>\n     *      1. \u58f0\u660e\u8868\u5173\u7cfb\u7684\u914d\u7f6e<br \/>\n     *          &#064; ManyToMany(targetEntity &#061; Role.class)  \/\/ \u591a\u5bf9\u591a<br \/>\n     *              targetEntity \u4ee3\u8868\u5bf9\u65b9\u7684\u5b9e\u4f53\u7c7b\u5b57\u8282\u7801<br \/>\n     *      2. \u914d\u7f6e\u4e2d\u95f4\u8868&#xff08;\u5305\u542b\u4e24\u4e2a\u5916\u952e&#xff09;<br \/>\n     *           &#064; JoinTable<br \/>\n     *              name \u914d\u7f6e\u4e2d\u95f4\u8868\u540d\u79f0<br \/>\n     *             joinColumns\u7684\u6570\u7ec4 \u914d\u7f6e\u5f53\u524d\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u7684\u5916\u952e<br \/>\n     *                  &#064; JoinColumn<br \/>\n     *                      name\u5916\u952e\u540d<br \/>\n     *                      referencedColumnName\u53c2\u7167\u4e3b\u8868\u7684\u4e3b\u952e\u540d<br \/>\n     *             inverseJoinColumns\u7684\u6570\u7ec4 \u914d\u7f6e\u5bf9\u65b9\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u7684\u5916\u952e<br \/>\n     *                  &#064; JoinColumn<br \/>\n     *                      name\u5916\u952e\u540d<br \/>\n     *                      referencedColumnName\u53c2\u7167\u4e3b\u8868\u7684\u4e3b\u952e\u540d<br \/>\n     *\/<br \/>\n    &#064;ManyToMany(targetEntity &#061; Role.class)<br \/>\n    &#064;JoinTable(name &#061; &#034;sys_user_role&#034;, \/\/ \u914d\u7f6e\u4e2d\u95f4\u8868\u540d\u79f0<br \/>\n            joinColumns &#061; {&#064;JoinColumn(name &#061; &#034;sys_user_id&#034;, referencedColumnName &#061; &#034;user_id&#034;)}, \/\/ \u914d\u7f6e\u5f53\u524d\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u4e2d\u7684\u5916\u952e&#xff0c;name\u968f\u4fbf&#xff0c;referencedColumnName\u53c2\u7167\u5f53\u524d\u5bf9\u8c61\u4e3b\u952e<br \/>\n            inverseJoinColumns &#061; {&#064;JoinColumn(name &#061; &#034;sys_role_id&#034;, referencedColumnName &#061; &#034;role_id&#034;)}  \/\/ \u914d\u7f6e\u5bf9\u65b9\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u7684\u5916\u952e&#xff0c;name\u968f\u4fbf&#xff0c;referencedColumnName\u53c2\u7167\u5f53\u524d\u5bf9\u8c61\u4e3b\u952e<br \/>\n    )<br \/>\n    private Set&lt;Role&gt; roles &#061; new HashSet&lt;&gt;();<\/p>\n<p>    &#064;Override<br \/>\n    public String toString() {<br \/>\n        return &#034;User{&#034; &#043;<br \/>\n                &#034;userId&#061;&#034; &#043; userId &#043;<br \/>\n                &#034;, userName&#061;&#039;&#034; &#043; userName &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, age&#061;&#034; &#043; age &#043;<br \/>\n                &#039;}&#039;;<br \/>\n    }<br \/>\n}<\/p>\n<p>package top.onefine.domain;<\/p>\n<p>import lombok.Getter;<br \/>\nimport lombok.Setter;<\/p>\n<p>import javax.persistence.*;<br \/>\nimport java.util.HashSet;<br \/>\nimport java.util.Set;<\/p>\n<p>&#064;Entity<br \/>\n&#064;Table(name &#061; &#034;sys_role&#034;)<br \/>\n&#064;Getter<br \/>\n&#064;Setter<br \/>\npublic class Role {<br \/>\n    &#064;Id<br \/>\n    &#064;GeneratedValue(strategy &#061; GenerationType.IDENTITY)<br \/>\n    &#064;Column(name &#061; &#034;role_id&#034;)<br \/>\n    private Long roleId;<br \/>\n    &#064;Column(name &#061; &#034;role_name&#034;)<br \/>\n    private String roleName;<\/p>\n<p>    \/\/ \u914d\u7f6e\u89d2\u8272\u5230\u7528\u6237\u7684\u591a\u5bf9\u591a\u5173\u7cfb<br \/>\n    &#064;ManyToMany(targetEntity &#061; User.class)  \/\/ \u58f0\u660e\u591a\u5bf9\u591a\u7684\u5173\u7cfb<br \/>\n    &#064;JoinTable(name &#061; &#034;sys_user_role&#034;, \/\/ \u914d\u7f6e\u4e2d\u95f4\u8868\u540d\u79f0<br \/>\n            joinColumns &#061; {&#064;JoinColumn(name &#061; &#034;sys_role_id&#034;, referencedColumnName &#061; &#034;role_id&#034;)}, \/\/ \u914d\u7f6e\u5f53\u524d\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u4e2d\u7684\u5916\u952e&#xff0c;name\u968f\u4fbf&#xff0c;referencedColumnName\u53c2\u7167\u5f53\u524d\u5bf9\u8c61\u4e3b\u952e<br \/>\n            inverseJoinColumns &#061; {&#064;JoinColumn(name &#061; &#034;sys_user_id&#034;, referencedColumnName &#061; &#034;user_id&#034;)}  \/\/ \u914d\u7f6e\u5bf9\u65b9\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u7684\u5916\u952e&#xff0c;name\u968f\u4fbf&#xff0c;referencedColumnName\u53c2\u7167\u5f53\u524d\u5bf9\u8c61\u4e3b\u952e<br \/>\n    )<br \/>\n    \/\/ \u653e\u5f03\u4e3b\u952e\u7ef4\u62a4\u6743<br \/>\n\/\/    &#064;ManyToMany(mappedBy &#061; &#034;roles&#034;)<br \/>\n    private Set&lt;User&gt; users &#061; new HashSet&lt;&gt;();<\/p>\n<p>    &#064;Override<br \/>\n    public String toString() {<br \/>\n        return &#034;User{&#034; &#043;<br \/>\n                &#034;roleId&#061;&#034; &#043; roleId &#043;<br \/>\n                &#034;, roleName&#061;&#039;&#034; &#043; roleName &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#039;}&#039;;<br \/>\n    }<br \/>\n}<\/p>\n<h5>4.4 \u6620\u5c04\u7684\u6ce8\u89e3\u8bf4\u660e<\/h5>\n<p>&#064;ManyToMany \u00a0\u00a0 \u00a0\u4f5c\u7528&#xff1a;\u7528\u4e8e\u6620\u5c04\u591a\u5bf9\u591a\u5173\u7cfb \u00a0\u00a0 \u00a0\u5c5e\u6027&#xff1a; \u00a0\u00a0 \u00a0\u00a0\u00a0 \u00a0cascade&#xff1a;\u914d\u7f6e\u7ea7\u8054\u64cd\u4f5c\u3002 \u00a0\u00a0 \u00a0\u00a0\u00a0 \u00a0fetch&#xff1a;\u914d\u7f6e\u662f\u5426\u91c7\u7528\u5ef6\u8fdf\u52a0\u8f7d\u3002 \u00a0 \u00a0 \u00a0\u00a0 \u00a0targetEntity&#xff1a;\u914d\u7f6e\u76ee\u6807\u7684\u5b9e\u4f53\u7c7b\u3002\u6620\u5c04\u591a\u5bf9\u591a\u7684\u65f6\u5019\u4e0d\u7528\u5199\u3002<\/p>\n<p>&#064;JoinTable \u00a0 \u00a0 \u4f5c\u7528&#xff1a;\u9488\u5bf9\u4e2d\u95f4\u8868\u7684\u914d\u7f6e \u00a0 \u00a0 \u5c5e\u6027&#xff1a; \u00a0 \u00a0 \u00a0\u00a0 \u00a0nam&#xff1a;\u914d\u7f6e\u4e2d\u95f4\u8868\u7684\u540d\u79f0 \u00a0 \u00a0 \u00a0\u00a0 \u00a0joinColumns&#xff1a;\u4e2d\u95f4\u8868\u7684\u5916\u952e\u5b57\u6bb5\u5173\u8054\u5f53\u524d\u5b9e\u4f53\u7c7b\u6240\u5bf9\u5e94\u8868\u7684\u4e3b\u952e\u5b57\u6bb5\u00a0\u00a0 \u00a0\u00a0\u00a0 \u00a0\u00a0\u00a0 \u00a0 \u00a0\u00a0\u00a0 \u00a0\u00a0\u00a0 \u00a0\u00a0\u00a0 \u00a0 \u00a0 \u00a0 \u00a0\u00a0 \u00a0inverseJoinColumn&#xff1a;\u4e2d\u95f4\u8868\u7684\u5916\u952e\u5b57\u6bb5\u5173\u8054\u5bf9\u65b9\u8868\u7684\u4e3b\u952e\u5b57\u6bb5 \u00a0 \u00a0 \u00a0\u00a0 \u00a0 &#064;JoinColumn \u00a0 \u00a0 \u4f5c\u7528&#xff1a;\u7528\u4e8e\u5b9a\u4e49\u4e3b\u952e\u5b57\u6bb5\u548c\u5916\u952e\u5b57\u6bb5\u7684\u5bf9\u5e94\u5173\u7cfb\u3002 \u00a0 \u00a0 \u5c5e\u6027&#xff1a; \u00a0 \u00a0 \u00a0\u00a0 \u00a0name&#xff1a;\u6307\u5b9a\u5916\u952e\u5b57\u6bb5\u7684\u540d\u79f0 \u00a0 \u00a0 \u00a0\u00a0 \u00a0referencedColumnName&#xff1a;\u6307\u5b9a\u5f15\u7528\u4e3b\u8868\u7684\u4e3b\u952e\u5b57\u6bb5\u540d\u79f0 \u00a0 \u00a0 \u00a0\u00a0 \u00a0unique&#xff1a;\u662f\u5426\u552f\u4e00\u3002\u9ed8\u8ba4\u503c\u4e0d\u552f\u4e00 \u00a0 \u00a0 \u00a0\u00a0 \u00a0nullable&#xff1a;\u662f\u5426\u5141\u8bb8\u4e3a\u7a7a\u3002\u9ed8\u8ba4\u503c\u5141\u8bb8\u3002 \u00a0 \u00a0 \u00a0\u00a0 \u00a0insertable&#xff1a;\u662f\u5426\u5141\u8bb8\u63d2\u5165\u3002\u9ed8\u8ba4\u503c\u5141\u8bb8\u3002 \u00a0 \u00a0 \u00a0\u00a0 \u00a0updatable&#xff1a;\u662f\u5426\u5141\u8bb8\u66f4\u65b0\u3002\u9ed8\u8ba4\u503c\u5141\u8bb8\u3002 \u00a0 \u00a0 \u00a0\u00a0 \u00a0columnDefinition&#xff1a;\u5217\u7684\u5b9a\u4e49\u4fe1\u606f\u3002<\/p>\n<h5>4.5 \u591a\u5bf9\u591a\u7684\u64cd\u4f5c<\/h5>\n<h6>4.5.1 \u4fdd\u5b58<\/h6>\n<p>src\\\\main\\\\resources\\\\applicationContext.xml\u4e2d&#xff1a;<\/p>\n<p>&lt;bean&gt;<br \/>\n&lt;property name&#061;&#034;jpaProperties&#034;&gt;<br \/>\n        &lt;props&gt;<br \/>\n            &lt;prop key&#061;&#034;hibernate.hbm2ddl.auto&#034;&gt;create&lt;\/prop&gt;<br \/>\n        &lt;\/props&gt;<br \/>\n    &lt;\/property&gt;<br \/>\n&lt;\/bean&gt;<\/p>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\dao\\\\UserDao.java&#xff1a;<\/p>\n<p>package top.onefine.dao;<\/p>\n<p>import org.springframework.data.jpa.repository.JpaRepository;<br \/>\nimport org.springframework.data.jpa.repository.JpaSpecificationExecutor;<br \/>\nimport top.onefine.domain.User;<\/p>\n<p>public interface UserDao extends JpaRepository&lt;User, Long&gt;, JpaSpecificationExecutor&lt;User&gt; {<br \/>\n}<\/p>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\dao\\\\RoleDao.java&#xff1a;<\/p>\n<p>package top.onefine.dao;<\/p>\n<p>import org.springframework.data.jpa.repository.JpaRepository;<br \/>\nimport org.springframework.data.jpa.repository.JpaSpecificationExecutor;<br \/>\nimport top.onefine.domain.Role;<\/p>\n<p>public interface RoleDao extends JpaRepository&lt;Role, Long&gt;, JpaSpecificationExecutor&lt;Role&gt; {<br \/>\n}<\/p>\n<p>\u6817\u5b501&#xff1a;<\/p>\n<p>package top.onefine.test;<\/p>\n<p>import org.junit.Test;<br \/>\nimport org.junit.runner.RunWith;<br \/>\nimport org.springframework.beans.factory.annotation.Autowired;<br \/>\nimport org.springframework.test.annotation.Rollback;<br \/>\nimport org.springframework.test.context.ContextConfiguration;<br \/>\nimport org.springframework.test.context.junit4.SpringJUnit4ClassRunner;<br \/>\nimport org.springframework.transaction.annotation.Transactional;<br \/>\nimport top.onefine.dao.RoleDao;<br \/>\nimport top.onefine.dao.UserDao;<br \/>\nimport top.onefine.domain.Role;<br \/>\nimport top.onefine.domain.User;<\/p>\n<p>&#064;SuppressWarnings(&#034;All&#034;)<br \/>\n&#064;RunWith(SpringJUnit4ClassRunner.class)<br \/>\n&#064;ContextConfiguration(locations &#061; &#034;classpath:applicationContext.xml&#034;)<br \/>\npublic class Many2ManyTest {<\/p>\n<p>    &#064;Autowired<br \/>\n    private UserDao userDao;<\/p>\n<p>    &#064;Autowired<br \/>\n    private RoleDao roleDao;<\/p>\n<p>    \/\/ \u4fdd\u5b58\u4e00\u4e2a\u7528\u6237&#xff0c;\u4fdd\u5b58\u4e00\u4e2a\u89d2\u8272<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional<br \/>\n    &#064;Rollback(false)<br \/>\n    public void testAdd() {<br \/>\n        User user &#061; new User();<br \/>\n        user.setUserName(&#034;one fine&#034;);<br \/>\n        Role role &#061; new Role();<br \/>\n        role.setRoleName(&#034;Java \u5de5\u7a0b\u5e08&#034;);<\/p>\n<p>        userDao.save(user);<br \/>\n        roleDao.save(role);<br \/>\n    }<br \/>\n}<\/p>\n<p>\u7ed3\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table sys_user_role drop foreign key FK1ef5794xnbirtsnudta6p32on<br \/>\nHibernate: alter table sys_user_role drop foreign key FKsbjvgfdwwy5rfbiag1bwh9x2b<br \/>\nHibernate: drop table if exists sys_role<br \/>\nHibernate: drop table if exists sys_user<br \/>\nHibernate: drop table if exists sys_user_role<br \/>\nHibernate: create table sys_role (role_id bigint not null auto_increment, role_name varchar(255), primary key (role_id))<br \/>\nHibernate: create table sys_user (user_id bigint not null auto_increment, user_age integer, user_name varchar(255), primary key (user_id))<br \/>\nHibernate: create table sys_user_role (sys_user_id bigint not null, sys_role_id bigint not null, primary key (sys_role_id, sys_user_id))<br \/>\nHibernate: alter table sys_user_role add constraint FK1ef5794xnbirtsnudta6p32on foreign key (sys_role_id) references sys_role (role_id)<br \/>\nHibernate: alter table sys_user_role add constraint FKsbjvgfdwwy5rfbiag1bwh9x2b foreign key (sys_user_id) references sys_user (user_id)<br \/>\nHibernate: insert into sys_user (user_age, user_name) values (?, ?)<br \/>\nHibernate: insert into sys_role (role_name) values (?)<\/p>\n<p>\u6817\u5b502&#xff1a;<\/p>\n<p>\/\/ \u4fdd\u5b58\u4e00\u4e2a\u7528\u6237&#xff0c;\u4fdd\u5b58\u4e00\u4e2a\u89d2\u8272<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional<br \/>\n    &#064;Rollback(false)<br \/>\n    public void testAdd() {<br \/>\n        User user &#061; new User();<br \/>\n        user.setUserName(&#034;one fine&#034;);<br \/>\n        Role role &#061; new Role();<br \/>\n        role.setRoleName(&#034;Java \u5de5\u7a0b\u5e08&#034;);<\/p>\n<p>        \/\/ \u914d\u7f6e\u7528\u6237\u5230\u89d2\u8272\u5173\u7cfb&#xff0c;\u53ef\u4ee5\u5bf9\u4e2d\u95f4\u8868\u4e2d\u7684\u6570\u636e\u8fdb\u884c\u7ef4\u62a4<br \/>\n        user.getRoles().add(role);<\/p>\n<p>        userDao.save(user);<br \/>\n        roleDao.save(role);<br \/>\n    }<\/p>\n<p>\u7ed3\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table sys_user_role drop foreign key FK1ef5794xnbirtsnudta6p32on<br \/>\nHibernate: alter table sys_user_role drop foreign key FKsbjvgfdwwy5rfbiag1bwh9x2b<br \/>\nHibernate: drop table if exists sys_role<br \/>\nHibernate: drop table if exists sys_user<br \/>\nHibernate: drop table if exists sys_user_role<br \/>\nHibernate: create table sys_role (role_id bigint not null auto_increment, role_name varchar(255), primary key (role_id))<br \/>\nHibernate: create table sys_user (user_id bigint not null auto_increment, user_age integer, user_name varchar(255), primary key (user_id))<br \/>\nHibernate: create table sys_user_role (sys_user_id bigint not null, sys_role_id bigint not null, primary key (sys_role_id, sys_user_id))<br \/>\nHibernate: alter table sys_user_role add constraint FK1ef5794xnbirtsnudta6p32on foreign key (sys_role_id) references sys_role (role_id)<br \/>\nHibernate: alter table sys_user_role add constraint FKsbjvgfdwwy5rfbiag1bwh9x2b foreign key (sys_user_id) references sys_user (user_id)<br \/>\nHibernate: insert into sys_user (user_age, user_name) values (?, ?)<br \/>\nHibernate: insert into sys_role (role_name) values (?)<br \/>\nHibernate: insert into sys_user_role (sys_user_id, sys_role_id) values (?, ?)<\/p>\n<p>\u6817\u5b503&#xff1a;<\/p>\n<p>&#064;Test<br \/>\n    &#064;Transactional<br \/>\n    &#064;Rollback(false)<br \/>\n    public void testAdd() {<br \/>\n        User user &#061; new User();<br \/>\n        user.setUserName(&#034;one fine&#034;);<br \/>\n        Role role &#061; new Role();<br \/>\n        role.setRoleName(&#034;Java \u5de5\u7a0b\u5e08&#034;);<\/p>\n<p>        \/\/ \u914d\u7f6e\u89d2\u8272\u5230\u7528\u6237\u5173\u7cfb&#xff0c;\u53ef\u4ee5\u5bf9\u4e2d\u95f4\u8868\u4e2d\u7684\u6570\u636e\u8fdb\u884c\u7ef4\u62a4<br \/>\n        role.getUsers().add(user);<\/p>\n<p>        userDao.save(user);<br \/>\n        roleDao.save(role);<br \/>\n    }<\/p>\n<p>\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table sys_user_role drop foreign key FK1ef5794xnbirtsnudta6p32on<br \/>\nHibernate: alter table sys_user_role drop foreign key FKsbjvgfdwwy5rfbiag1bwh9x2b<br \/>\nHibernate: drop table if exists sys_role<br \/>\nHibernate: drop table if exists sys_user<br \/>\nHibernate: drop table if exists sys_user_role<br \/>\nHibernate: create table sys_role (role_id bigint not null auto_increment, role_name varchar(255), primary key (role_id))<br \/>\nHibernate: create table sys_user (user_id bigint not null auto_increment, user_age integer, user_name varchar(255), primary key (user_id))<br \/>\nHibernate: create table sys_user_role (sys_user_id bigint not null, sys_role_id bigint not null, primary key (sys_role_id, sys_user_id))<br \/>\nHibernate: alter table sys_user_role add constraint FK1ef5794xnbirtsnudta6p32on foreign key (sys_role_id) references sys_role (role_id)<br \/>\nHibernate: alter table sys_user_role add constraint FKsbjvgfdwwy5rfbiag1bwh9x2b foreign key (sys_user_id) references sys_user (user_id)<br \/>\nHibernate: insert into sys_user (user_age, user_name) values (?, ?)<br \/>\nHibernate: insert into sys_role (role_name) values (?)<br \/>\nHibernate: insert into sys_user_role (sys_role_id, sys_user_id) values (?, ?)<\/p>\n<p>\u6817\u5b504&#xff1a;<\/p>\n<p>\/\/ \u4fdd\u5b58\u4e00\u4e2a\u7528\u6237&#xff0c;\u4fdd\u5b58\u4e00\u4e2a\u89d2\u8272<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional<br \/>\n    &#064;Rollback(false)<br \/>\n    public void testAdd() {<br \/>\n        User user &#061; new User();<br \/>\n        user.setUserName(&#034;one fine&#034;);<br \/>\n        Role role &#061; new Role();<br \/>\n        role.setRoleName(&#034;Java \u5de5\u7a0b\u5e08&#034;);<\/p>\n<p>        \/\/ \u914d\u7f6e\u7528\u6237\u5230\u89d2\u8272\u5173\u7cfb&#xff0c;\u53ef\u4ee5\u5bf9\u4e2d\u95f4\u8868\u4e2d\u7684\u6570\u636e\u8fdb\u884c\u7ef4\u62a41:1<br \/>\n        user.getRoles().add(role);<\/p>\n<p>        \/\/ \u914d\u7f6e\u89d2\u8272\u5230\u7528\u6237\u5173\u7cfb&#xff0c;\u53ef\u4ee5\u5bf9\u4e2d\u95f4\u8868\u4e2d\u7684\u6570\u636e\u8fdb\u884c\u7ef4\u62a41:1<br \/>\n        role.getUsers().add(user);<\/p>\n<p>        userDao.save(user);<br \/>\n        roleDao.save(role);<br \/>\n    }<\/p>\n<p>\u6267\u884c\u629b\u51fa\u5f02\u5e38&#xff0c;\u4e3b\u952e\u51b2\u7a81&#xff1a;<\/p>\n<p><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"636\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100257-68022351f39b3.png\" width=\"1200\" \/><\/p>\n<p><img loading=\"lazy\" decoding=\"async\" alt=\"\" height=\"183\" src=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100258-68022352705ce.png\" width=\"1200\" \/><\/p>\n<p>\u5728\u591a\u5bf9\u591a&#xff08;\u4fdd\u5b58&#xff09;\u4e2d&#xff0c;\u5982\u679c\u53cc\u5411\u90fd\u8bbe\u7f6e\u5173\u7cfb&#xff0c;\u610f\u5473\u7740\u53cc\u65b9\u90fd\u7ef4\u62a4\u4e2d\u95f4\u8868&#xff0c;\u90fd\u4f1a\u5f80\u4e2d\u95f4\u8868\u63d2\u5165\u6570\u636e&#xff0c;\u4e2d\u95f4\u8868\u76842\u4e2a\u5b57\u6bb5\u53c8\u4f5c\u4e3a\u8054\u5408\u4e3b\u952e&#xff0c;\u6240\u4ee5\u62a5\u9519&#xff0c;\u4e3b\u952e\u91cd\u590d&#xff0c;\u89e3\u51b3\u4fdd\u5b58\u5931\u8d25\u7684\u95ee\u9898&#xff1a;\u53ea\u9700\u8981\u5728\u4efb\u610f\u4e00\u65b9\u653e\u5f03\u5bf9\u4e2d\u95f4\u8868\u7684\u7ef4\u62a4\u6743\u5373\u53ef&#xff0c;\u63a8\u8350\u5728\u88ab\u52a8\u7684\u4e00\u65b9\u653e\u5f03&#xff0c;\u88ab\u9009\u62e9\u7684\u653e\u5f03&#xff0c;\u8fd9\u91cc\u662f\u89d2\u8272\u88ab\u7528\u6237\u9009\u62e9&#xff0c;\u6240\u4ee5\u89d2\u8272\u653e\u5f03\u7ef4\u62a4\u6743&#xff0c;\u914d\u7f6e\u5982\u4e0b&#xff1a;<\/p>\n<p>\/\/    \/\/ \u914d\u7f6e\u89d2\u8272\u5230\u7528\u6237\u7684\u591a\u5bf9\u591a\u5173\u7cfb<br \/>\n\/\/    &#064;ManyToMany(targetEntity &#061; User.class)  \/\/ \u58f0\u660e\u591a\u5bf9\u591a\u7684\u5173\u7cfb<br \/>\n\/\/    &#064;JoinTable(name &#061; &#034;sys_user_role&#034;, \/\/ \u914d\u7f6e\u4e2d\u95f4\u8868\u540d\u79f0<br \/>\n\/\/            joinColumns &#061; {&#064;JoinColumn(name &#061; &#034;sys_role_id&#034;, referencedColumnName &#061; &#034;role_id&#034;)}, \/\/ \u914d\u7f6e\u5f53\u524d\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u4e2d\u7684\u5916\u952e&#xff0c;name\u968f\u4fbf&#xff0c;referencedColumnName\u53c2\u7167\u5f53\u524d\u5bf9\u8c61\u4e3b\u952e<br \/>\n\/\/            inverseJoinColumns &#061; {&#064;JoinColumn(name &#061; &#034;sys_user_id&#034;, referencedColumnName &#061; &#034;user_id&#034;)}  \/\/ \u914d\u7f6e\u5bf9\u65b9\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u7684\u5916\u952e&#xff0c;name\u968f\u4fbf&#xff0c;referencedColumnName\u53c2\u7167\u5f53\u524d\u5bf9\u8c61\u4e3b\u952e<br \/>\n\/\/    )<br \/>\n    \/\/ \u653e\u5f03\u4e3b\u952e\u7ef4\u62a4\u6743&#xff0c;\u89e3\u51b3\u4fdd\u5b58\u4e2d\u4e3b\u952e\u51b2\u7a81\u7684\u95ee\u9898<br \/>\n    &#064;ManyToMany(mappedBy &#061; &#034;roles&#034;)<br \/>\n    private Set&lt;User&gt; users &#061; new HashSet&lt;&gt;();<\/p>\n<p>\u91cd\u65b0\u6267\u884c&#xff0c;\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table sys_user_role drop foreign key FK1ef5794xnbirtsnudta6p32on<br \/>\nHibernate: alter table sys_user_role drop foreign key FKsbjvgfdwwy5rfbiag1bwh9x2b<br \/>\nHibernate: drop table if exists sys_role<br \/>\nHibernate: drop table if exists sys_user<br \/>\nHibernate: drop table if exists sys_user_role<br \/>\nHibernate: create table sys_role (role_id bigint not null auto_increment, role_name varchar(255), primary key (role_id))<br \/>\nHibernate: create table sys_user (user_id bigint not null auto_increment, user_age integer, user_name varchar(255), primary key (user_id))<br \/>\nHibernate: create table sys_user_role (sys_user_id bigint not null, sys_role_id bigint not null, primary key (sys_user_id, sys_role_id))<br \/>\nHibernate: alter table sys_user_role add constraint FK1ef5794xnbirtsnudta6p32on foreign key (sys_role_id) references sys_role (role_id)<br \/>\nHibernate: alter table sys_user_role add constraint FKsbjvgfdwwy5rfbiag1bwh9x2b foreign key (sys_user_id) references sys_user (user_id)<br \/>\nHibernate: insert into sys_user (user_age, user_name) values (?, ?)<br \/>\nHibernate: insert into sys_role (role_name) values (?)<br \/>\nHibernate: insert into sys_user_role (sys_user_id, sys_role_id) values (?, ?)<\/p>\n<h6>\u6817\u5b505&#xff0c;\u7ea7\u8054\u6dfb\u52a0&#xff1a;<\/h6>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\domain\\\\User.java\u4e2d&#xff1a;<\/p>\n<p>&#064;ManyToMany(targetEntity &#061; Role.class, cascade &#061; CascadeType.ALL)<br \/>\n    &#064;JoinTable(name &#061; &#034;sys_user_role&#034;, \/\/ \u914d\u7f6e\u4e2d\u95f4\u8868\u540d\u79f0<br \/>\n            joinColumns &#061; {&#064;JoinColumn(name &#061; &#034;sys_user_id&#034;, referencedColumnName &#061; &#034;user_id&#034;)}, \/\/ \u914d\u7f6e\u5f53\u524d\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u4e2d\u7684\u5916\u952e&#xff0c;name\u968f\u4fbf&#xff0c;referencedColumnName\u53c2\u7167\u5f53\u524d\u5bf9\u8c61\u4e3b\u952e<br \/>\n            inverseJoinColumns &#061; {&#064;JoinColumn(name &#061; &#034;sys_role_id&#034;, referencedColumnName &#061; &#034;role_id&#034;)}  \/\/ \u914d\u7f6e\u5bf9\u65b9\u5bf9\u8c61\u5728\u4e2d\u95f4\u8868\u7684\u5916\u952e&#xff0c;name\u968f\u4fbf&#xff0c;referencedColumnName\u53c2\u7167\u5f53\u524d\u5bf9\u8c61\u4e3b\u952e<br \/>\n    )<br \/>\n    private Set&lt;Role&gt; roles &#061; new HashSet&lt;&gt;();<\/p>\n<p>src\\\\test\\\\java\\\\top\\\\onefine\\\\test\\\\Many2ManyTest.java\u4e2d&#xff1a;<\/p>\n<p>\/\/ \u6d4b\u8bd5\u7ea7\u8054\u6dfb\u52a0&#xff1a;\u4fdd\u5b58\u4e00\u4e2a\u7528\u6237\u7684\u540c\u65f6\u4fdd\u5b58\u7528\u6237\u7684\u5173\u8054\u89d2\u8272<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional<br \/>\n    &#064;Rollback(false)<br \/>\n    public void testCasCadeAdd() {<br \/>\n        User user &#061; new User();<br \/>\n        user.setUserName(&#034;one fine&#034;);<br \/>\n        Role role &#061; new Role();<br \/>\n        role.setRoleName(&#034;Java \u5de5\u7a0b\u5e08&#034;);<\/p>\n<p>        \/\/ \u914d\u7f6e\u7528\u6237\u5230\u89d2\u8272\u5173\u7cfb&#xff0c;\u53ef\u4ee5\u5bf9\u4e2d\u95f4\u8868\u4e2d\u7684\u6570\u636e\u8fdb\u884c\u7ef4\u62a4<br \/>\n        user.getRoles().add(role);<\/p>\n<p>        \/\/ \u914d\u7f6e\u89d2\u8272\u5230\u7528\u6237\u5173\u7cfb&#xff0c;\u53ef\u4ee5\u5bf9\u4e2d\u95f4\u8868\u4e2d\u7684\u6570\u636e\u8fdb\u884c\u7ef4\u62a4<br \/>\n        role.getUsers().add(user);<\/p>\n<p>        userDao.save(user);<br \/>\n    }<\/p>\n<p>\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: alter table sys_user_role drop foreign key FK1ef5794xnbirtsnudta6p32on<br \/>\nHibernate: alter table sys_user_role drop foreign key FKsbjvgfdwwy5rfbiag1bwh9x2b<br \/>\nHibernate: drop table if exists sys_role<br \/>\nHibernate: drop table if exists sys_user<br \/>\nHibernate: drop table if exists sys_user_role<br \/>\nHibernate: create table sys_role (role_id bigint not null auto_increment, role_name varchar(255), primary key (role_id))<br \/>\nHibernate: create table sys_user (user_id bigint not null auto_increment, user_age integer, user_name varchar(255), primary key (user_id))<br \/>\nHibernate: create table sys_user_role (sys_user_id bigint not null, sys_role_id bigint not null, primary key (sys_user_id, sys_role_id))<br \/>\nHibernate: alter table sys_user_role add constraint FK1ef5794xnbirtsnudta6p32on foreign key (sys_role_id) references sys_role (role_id)<br \/>\nHibernate: alter table sys_user_role add constraint FKsbjvgfdwwy5rfbiag1bwh9x2b foreign key (sys_user_id) references sys_user (user_id)<br \/>\nHibernate: insert into sys_user (user_age, user_name) values (?, ?)<br \/>\nHibernate: insert into sys_role (role_name) values (?)<br \/>\nHibernate: insert into sys_user_role (sys_user_id, sys_role_id) values (?, ?)<\/p>\n<h6>4.5.2 \u5220\u9664<\/h6>\n<p>src\\\\main\\\\resources\\\\applicationContext.xml\u4e2d&#xff1a;<\/p>\n<p>&lt;bean&gt;<br \/>\n&lt;property name&#061;&#034;jpaProperties&#034;&gt;<br \/>\n    &lt;props&gt;<br \/>\n        &lt;prop key&#061;&#034;hibernate.hbm2ddl.auto&#034;&gt;update&lt;\/prop&gt;<br \/>\n    &lt;\/props&gt;<br \/>\n&lt;\/property&gt;<br \/>\n&lt;\/bean&gt;<\/p>\n<p>\u7ea7\u8054\u5220\u9664&#xff1a;<\/p>\n<p>\/\/ \u6d4b\u8bd5\u7ea7\u8054\u5220\u9664&#xff1a;\u5220\u9664id\u4e3a1\u7684\u5ba2\u6237&#xff08;\u4e0a\u4e2a\u6817\u5b50\u4fdd\u5b58\u7684\u6570\u636e&#xff09;&#xff0c;\u540c\u65f6\u5220\u9664\u4ed6\u7684\u5173\u8054\u5bf9\u8c61<br \/>\n\/**<br \/>\n * \u5220\u9664\u64cd\u4f5c<br \/>\n * \u5728\u591a\u5bf9\u591a\u7684\u5220\u9664\u65f6&#xff0c;\u53cc\u5411\u7ea7\u8054\u5220\u9664\u6839\u672c\u4e0d\u80fd\u914d\u7f6e<br \/>\n * \u7981\u7528<br \/>\n *\u5982\u679c\u914d\u4e86\u7684\u8bdd&#xff0c;\u5982\u679c\u6570\u636e\u4e4b\u95f4\u6709\u76f8\u4e92\u5f15\u7528\u5173\u7cfb&#xff0c;\u53ef\u80fd\u4f1a\u6e05\u7a7a\u6240\u6709\u6570\u636e<br \/>\n *\/<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional<br \/>\n    &#064;Rollback(false)<br \/>\n    public void testCasCadeRemove() {<br \/>\n        \/\/ 1. \u67e5\u8be2\u5ba2\u62371<br \/>\n        User user &#061; userDao.findOne(1L);<br \/>\n        \/\/ 2. \u5220\u9664\u5ba2\u62371<br \/>\n        userDao.delete(user);<br \/>\n    }<\/p>\n<p>\u6548\u679c&#xff1a;<\/p>\n<p>Hibernate: select user0_.user_id as user_id1_1_0_, user0_.user_age as user_age2_1_0_, user0_.user_name as user_nam3_1_0_ from sys_user user0_ where user0_.user_id&#061;?<br \/>\nHibernate: select roles0_.sys_user_id as sys_user1_2_0_, roles0_.sys_role_id as sys_role2_2_0_, role1_.role_id as role_id1_0_1_, role1_.role_name as role_nam2_0_1_ from sys_user_role roles0_ inner join sys_role role1_ on roles0_.sys_role_id&#061;role1_.role_id where roles0_.sys_user_id&#061;?<br \/>\nHibernate: delete from sys_user_role where sys_user_id&#061;?<br \/>\nHibernate: delete from sys_role where role_id&#061;?<br \/>\nHibernate: delete from sys_user where user_id&#061;?<\/p>\n<h4>\u4e94\u3001Spring Data JPA\u4e2d\u7684\u591a\u8868\u67e5\u8be2<\/h4>\n<h5>5.1 \u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2<\/h5>\n<p>\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2\u5373\u901a\u8fc7\u4e00\u4e2a\u5bf9\u8c61&#xff0c;\u67e5\u8be2\u6b64\u5bf9\u8c61\u5173\u8054\u7684\u6240\u6709\u5bf9\u8c61\u3002<\/p>\n<p>\u5bf9\u8c61\u56fe\u5bfc\u822a\u68c0\u7d22\u65b9\u5f0f\u662f\u6839\u636e\u5df2\u7ecf\u52a0\u8f7d\u7684\u5bf9\u8c61&#xff0c;\u5bfc\u822a\u5230\u4ed6\u7684\u5173\u8054\u5bf9\u8c61\u3002\u5b83\u5229\u7528\u7c7b\u4e0e\u7c7b\u4e4b\u95f4\u7684\u5173\u7cfb\u6765\u68c0\u7d22\u5bf9\u8c61\u3002\u4f8b\u5982&#xff1a;\u6211\u4eec\u901a\u8fc7ID\u67e5\u8be2\u65b9\u5f0f\u67e5\u51fa\u4e00\u4e2a\u5ba2\u6237&#xff0c;\u53ef\u4ee5\u8c03\u7528Customer\u7c7b\u4e2d\u7684getLinkMans()\u65b9\u6cd5\u6765\u83b7\u53d6\u8be5\u5ba2\u6237\u7684\u6240\u6709\u8054\u7cfb\u4eba\u3002\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2\u7684\u4f7f\u7528\u8981\u6c42\u662f&#xff1a;\u4e24\u4e2a\u5bf9\u8c61\u4e4b\u95f4\u5fc5\u987b\u5b58\u5728\u5173\u8054\u5173\u7cfb\u3002<\/p>\n<p>\u67e5\u8be2\u4e00\u4e2a\u5ba2\u6237&#xff0c;\u83b7\u53d6\u8be5\u5ba2\u6237\u4e0b\u7684\u6240\u6709\u8054\u7cfb\u4eba \u00a0<\/p>\n<p>&#064;Autowired<br \/>\nprivate CustomerDao customerDao;<\/p>\n<p>&#064;Test<br \/>\n\/\/\u7531\u4e8e\u662f\u5728java\u4ee3\u7801\u4e2d\u6d4b\u8bd5&#xff0c;\u4e3a\u4e86\u89e3\u51b3no session\u95ee\u9898&#xff0c;\u5c06\u64cd\u4f5c\u914d\u7f6e\u5230\u540c\u4e00\u4e2a\u4e8b\u52a1\u4e2d<br \/>\n&#064;Transactional<br \/>\npublic void testFind() {<br \/>\nCustomer customer &#061; customerDao.findOne(5l);<br \/>\nSet&lt;LinkMan&gt; linkMans &#061; customer.getLinkMans();\/\/\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2<br \/>\nfor(LinkMan linkMan : linkMans) {<br \/>\n  System.out.println(linkMan);<br \/>\n}<br \/>\n}<\/p>\n<p>\u67e5\u8be2\u4e00\u4e2a\u8054\u7cfb\u4eba&#xff0c;\u83b7\u53d6\u8be5\u8054\u7cfb\u4eba\u7684\u6240\u6709\u5ba2\u6237<\/p>\n<p>&#064;Autowired<br \/>\nprivate LinkManDao linkManDao;<\/p>\n<p>&#064;Test<br \/>\npublic void testFind() {<br \/>\nLinkMan linkMan &#061; linkManDao.findOne(4l);<br \/>\nCustomer customer &#061; linkMan.getCustomer(); \/\/\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2<br \/>\nSystem.out.println(customer);<br \/>\n}<\/p>\n<p>\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2\u7684\u95ee\u9898\u5206\u6790<\/p>\n<p>\u95ee\u98981&#xff1a;\u6211\u4eec\u67e5\u8be2\u5ba2\u6237\u65f6&#xff0c;\u8981\u4e0d\u8981\u628a\u8054\u7cfb\u4eba\u67e5\u8be2\u51fa\u6765&#xff1f;<\/p>\n<p>\u5206\u6790&#xff1a;\u5982\u679c\u6211\u4eec\u4e0d\u67e5\u7684\u8bdd&#xff0c;\u5728\u7528\u7684\u65f6\u5019\u8fd8\u8981\u81ea\u5df1\u5199\u4ee3\u7801&#xff0c;\u8c03\u7528\u65b9\u6cd5\u53bb\u67e5\u8be2\u3002\u5982\u679c\u6211\u4eec\u67e5\u51fa\u6765\u7684&#xff0c;\u4e0d\u4f7f\u7528\u65f6\u53c8\u4f1a\u767d\u767d\u7684\u6d6a\u8d39\u4e86\u670d\u52a1\u5668\u5185\u5b58\u3002<\/p>\n<p>\u89e3\u51b3&#xff1a;\u91c7\u7528\u5ef6\u8fdf\u52a0\u8f7d\u7684\u601d\u60f3\u3002\u901a\u8fc7\u914d\u7f6e\u7684\u65b9\u5f0f\u6765\u8bbe\u5b9a\u5f53\u6211\u4eec\u5728\u9700\u8981\u4f7f\u7528\u65f6&#xff0c;\u53d1\u8d77\u771f\u6b63\u7684\u67e5\u8be2\u3002<\/p>\n<p>\u914d\u7f6e\u65b9\u5f0f&#xff1a;<\/p>\n<p>\/**<br \/>\n * \u5728\u5ba2\u6237\u5bf9\u8c61\u7684&#064;OneToMany\u6ce8\u89e3\u4e2d\u6dfb\u52a0fetch\u5c5e\u6027<br \/>\n * FetchType.EAGER&#xff1a;\u7acb\u5373\u52a0\u8f7d<br \/>\n * FetchType.LAZY&#xff1a;\u5ef6\u8fdf\u52a0\u8f7d<br \/>\n *\/<br \/>\n&#064;OneToMany(mappedBy&#061;&#034;customer&#034;,fetch&#061;FetchType.EAGER)<br \/>\nprivate Set&lt;LinkMan&gt; linkMans &#061; new HashSet&lt;&gt;(0);<\/p>\n<p>\u95ee\u98982&#xff1a;\u6211\u4eec\u67e5\u8be2\u8054\u7cfb\u4eba\u65f6&#xff0c;\u8981\u4e0d\u8981\u628a\u5ba2\u6237\u67e5\u8be2\u51fa\u6765&#xff1f;<\/p>\n<p>\u5206\u6790&#xff1a;\u4f8b\u5982&#xff1a;\u67e5\u8be2\u8054\u7cfb\u4eba\u8be6\u60c5\u65f6&#xff0c;\u80af\u5b9a\u4f1a\u770b\u770b\u8be5\u8054\u7cfb\u4eba\u7684\u6240\u5c5e\u5ba2\u6237\u3002\u5982\u679c\u6211\u4eec\u4e0d\u67e5\u7684\u8bdd&#xff0c;\u5728\u7528\u7684\u65f6\u5019\u8fd8\u8981\u81ea\u5df1\u5199\u4ee3\u7801&#xff0c;\u8c03\u7528\u65b9\u6cd5\u53bb\u67e5\u8be2\u3002\u5982\u679c\u6211\u4eec\u67e5\u51fa\u6765\u7684\u8bdd&#xff0c;\u4e00\u4e2a\u5bf9\u8c61\u4e0d\u4f1a\u6d88\u8017\u592a\u591a\u7684\u5185\u5b58\u3002\u800c\u4e14\u591a\u6570\u60c5\u51b5\u4e0b\u6211\u4eec\u90fd\u662f\u8981\u4f7f\u7528\u7684\u3002<\/p>\n<p>\u89e3\u51b3&#xff1a; \u91c7\u7528\u7acb\u5373\u52a0\u8f7d\u7684\u601d\u60f3\u3002\u901a\u8fc7\u914d\u7f6e\u7684\u65b9\u5f0f\u6765\u8bbe\u5b9a&#xff0c;\u53ea\u8981\u67e5\u8be2\u4ece\u8868\u5b9e\u4f53&#xff0c;\u5c31\u628a\u4e3b\u8868\u5b9e\u4f53\u5bf9\u8c61\u540c\u65f6\u67e5\u51fa\u6765<\/p>\n<p>\u914d\u7f6e\u65b9\u5f0f<\/p>\n<p>\/**<br \/>\n * \u5728\u8054\u7cfb\u4eba\u5bf9\u8c61\u7684&#064;ManyToOne\u6ce8\u89e3\u4e2d\u6dfb\u52a0fetch\u5c5e\u6027<br \/>\n * FetchType.EAGER&#xff1a;\u7acb\u5373\u52a0\u8f7d<br \/>\n * FetchType.LAZY&#xff1a;\u5ef6\u8fdf\u52a0\u8f7d<br \/>\n *\/<br \/>\n&#064;ManyToOne(targetEntity&#061;Customer.class,fetch&#061;FetchType.EAGER)<br \/>\n&#064;JoinColumn(name&#061;&#034;cst_lkm_id&#034;,referencedColumnName&#061;&#034;cust_id&#034;)<br \/>\nprivate Customer customer;<\/p>\n<h6>\u6817\u5b50&#xff0c;\u4f7f\u7528\u7b2c\u4e09\u7ae0&#xff08;\u4e00\u5bf9\u591a&#xff09;\u7684\u914d\u7f6e<\/h6>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\domain\\\\Customer.java&#xff1a;<\/p>\n<p>package top.onefine.domain;<\/p>\n<p>import lombok.*;<\/p>\n<p>import javax.persistence.*;<br \/>\nimport java.util.HashSet;<br \/>\nimport java.util.Set;<\/p>\n<p>\/**<br \/>\n * 1. \u5b9e\u4f53\u7c7b\u548c\u8868\u7684\u6620\u5c04\u5173\u7cfb<br \/>\n *      -&#064;Eitity<br \/>\n *      -&#064;Table<br \/>\n * 2. \u7c7b\u4e2d\u5c5e\u6027\u548c\u6570\u636e\u5e93\u8868\u4e2d\u5b57\u6bb5\u7684\u6620\u5c04\u5173\u7cfb<br \/>\n *      -&#064;Id \u4e3b\u952e<br \/>\n *      -&#064;GeneratedValue \u4e3b\u952e\u751f\u6210\u7b56\u7565<br \/>\n *      -&#064;Column<br \/>\n *\/<br \/>\n&#064;Entity<br \/>\n&#064;Table(name &#061; &#034;cst_customer&#034;)<br \/>\n&#064;Getter<br \/>\n&#064;Setter<br \/>\n&#064;NoArgsConstructor<br \/>\npublic class Customer {<br \/>\n    &#064;Id<br \/>\n    &#064;GeneratedValue(strategy &#061; GenerationType.IDENTITY)<br \/>\n    &#064;Column(name &#061; &#034;cust_id&#034;)<br \/>\n    private Long custId;<br \/>\n    &#064;Column(name &#061; &#034;cust_address&#034;)<br \/>\n    private String custAddress;<br \/>\n    &#064;Column(name &#061; &#034;cust_industry&#034;)<br \/>\n    private String custIndustry;<br \/>\n    &#064;Column(name &#061; &#034;cust_level&#034;)<br \/>\n    private String custLevel;<br \/>\n    &#064;Column(name &#061; &#034;cust_name&#034;)<br \/>\n    private String custName;<br \/>\n    &#064;Column(name &#061; &#034;cust_phone&#034;)<br \/>\n    private String custPhone;<br \/>\n    &#064;Column(name &#061; &#034;cust_source&#034;)<br \/>\n    private String custSource;<\/p>\n<p>    \/\/ \u914d\u7f6e\u5ba2\u6237\u548c\u8054\u7cfb\u4eba\u4e4b\u95f4\u7684\u5173\u7cfb&#xff08;\u4e00\u5bf9\u591a\u5173\u7cfb&#xff09;<br \/>\n    \/*<br \/>\n        \u4f7f\u7528\u6ce8\u89e3\u7684\u5f62\u5f0f\u914d\u7f6e\u591a\u8868\u5173\u7cfb&#xff1a;<br \/>\n            1. \u58f0\u660e\u5173\u7cfb<br \/>\n                &#8211; &#064;OneToMany&#xff1a;\u914d\u7f6e\u4e00\u5bf9\u591a\u5173\u7cfb<br \/>\n                    targetEntity&#xff1a;\u5bf9\u65b9\u5bf9\u8c61\u7684\u5b57\u8282\u7801\u5bf9\u8c61<br \/>\n            2. \u914d\u7f6e\u5916\u952e&#xff08;\u6216\u4e2d\u95f4\u8868&#xff09;<br \/>\n                &#8211; &#064;JoinColumn&#xff1a;\u914d\u7f6e\u5916\u952e<br \/>\n                    name&#xff1a;\u4ece\u8868 \u5916\u952e\u5b57\u6bb5\u540d\u79f0<br \/>\n                    referencedColumnName&#xff1a;\u53c2\u7167\u7684 \u4e3b\u8868 \u7684\u4e3b\u952e\u5b57\u6bb5\u540d\u79f0<\/p>\n<p>        \u6ce8&#xff1a;\u5728\u5ba2\u6237\u5b9e\u4f53\u7c7b\u4e0a&#xff08;\u4e00\u7684\u4e00\u65b9&#xff09;\u6dfb\u52a0\u4e86\u5916\u952e\u7684\u914d\u7f6e&#xff0c;\u6240\u4ee5\u5bf9\u4e8e\u5ba2\u6237\u800c\u8a00&#xff0c;\u4e5f\u5177\u5907\u4e86\u7ef4\u62a4\u5916\u952e\u7684\u4f5c\u7528<\/p>\n<p>     *\/<br \/>\n\/\/    &#064;OneToMany(targetEntity &#061; LinkMan.class)<br \/>\n\/\/    &#064;JoinColumn(name &#061; &#034;lkm_cust_id&#034;, referencedColumnName &#061; &#034;cust_id&#034;)<br \/>\n    \/*<br \/>\n        \u653e\u5f03\u5916\u952e\u7ef4\u62a4\u6743<br \/>\n            mappedBy: \u5bf9\u65b9\u914d\u7f6e\u5173\u7cfb\u7684\u5c5e\u6027\u540d\u79f0<br \/>\n                \u8868\u793a\u53c2\u7167\u5bf9\u65b9\u7684\u5c5e\u6027\u6765\u505a<\/p>\n<p>            cascade:\u914d\u7f6e\u7ea7\u8054\u64cd\u4f5c&#xff0c;\u53ef\u4ee5\u914d\u7f6e\u5230\u8bbe\u7f6e\u591a\u8868\u7684\u6620\u5c04\u5173\u7cfb\u7684\u6ce8\u89e3\u4e0a<br \/>\n            * CascadeType.MERGE\u7ea7\u8054\u66f4\u65b0<br \/>\n            * CascadeType.PERSIST\u7ea7\u8054\u4fdd\u5b58&#xff1a;<br \/>\n            * CascadeType.REFRESH \u7ea7\u8054\u5237\u65b0&#xff1a;<br \/>\n            * CascadeType.REMOVE\u7ea7\u8054\u5220\u9664&#xff1a;<br \/>\n            * CascadeType.ALL\u5305\u542b\u4ee5\u4e0a\u6240\u6709&#xff0c;\u63a8\u8350\u914d\u7f6e<\/p>\n<p>            fetch:\u914d\u7f6e\u5173\u8054\u5bf9\u8c61\u7684\u52a0\u8f7d\u65b9\u5f0f<br \/>\n                FetchType.EAGER \u7acb\u5373\u52a0\u8f7d &#8212; \u4e0d\u63a8\u8350<br \/>\n                FetchType.LAZY  \u5ef6\u8fdf\u52a0\u8f7d &#8212; \u9ed8\u8ba4<br \/>\n     *\/<br \/>\n    &#064;OneToMany(mappedBy &#061; &#034;customer&#034;, cascade &#061; CascadeType.ALL\/*, fetch &#061; FetchType.EAGER*\/)<br \/>\n    private Set&lt;LinkMan&gt; linkMans &#061; new HashSet&lt;&gt;();<\/p>\n<p>    \/\/ \u6ce8\u610f\u4e0d\u542b\u96c6\u5408<br \/>\n    &#064;Override<br \/>\n    public String toString() {<br \/>\n        return &#034;Customer{&#034; &#043;<br \/>\n                &#034;custId&#061;&#034; &#043; custId &#043;<br \/>\n                &#034;, custAddress&#061;&#039;&#034; &#043; custAddress &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custIndustry&#061;&#039;&#034; &#043; custIndustry &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custLevel&#061;&#039;&#034; &#043; custLevel &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custName&#061;&#039;&#034; &#043; custName &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custPhone&#061;&#039;&#034; &#043; custPhone &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, custSource&#061;&#039;&#034; &#043; custSource &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#039;}&#039;;<br \/>\n    }<br \/>\n}<\/p>\n<p>src\\\\main\\\\java\\\\top\\\\onefine\\\\domain\\\\LinkMan.java&#xff1a;<\/p>\n<p>package top.onefine.domain;<\/p>\n<p>import lombok.*;<\/p>\n<p>import javax.persistence.*;<\/p>\n<p>&#064;Entity<br \/>\n&#064;Table(name &#061; &#034;cst_linkman&#034;)<br \/>\n\/\/&#064;Data<br \/>\n&#064;Getter<br \/>\n&#064;Setter<br \/>\n\/\/&#064;ToString<br \/>\n&#064;NoArgsConstructor<br \/>\npublic class LinkMan {<br \/>\n    &#064;Id<br \/>\n    &#064;GeneratedValue(strategy &#061; GenerationType.IDENTITY)<br \/>\n    &#064;Column(name &#061; &#034;lkm_id&#034;)<br \/>\n    private Long lkmId;  \/\/ \u8054\u7cfb\u4eba\u7f16\u53f7<br \/>\n    &#064;Column(name &#061; &#034;lkm_name&#034;)<br \/>\n    private String lkmName;  \/\/ \u8054\u7cfb\u4eba\u59d3\u540d<br \/>\n    &#064;Column(name &#061; &#034;lkm_gender&#034;)<br \/>\n    private String lkmGender;  \/\/ \u8054\u7cfb\u4eba\u6027\u522b  \/\/ \u5bf9\u5e94\u6570\u636e\u5e93\u8868\u4e2d\u5b57\u6bb5char(1)<br \/>\n    &#064;Column(name &#061; &#034;lkm_phone&#034;)<br \/>\n    private String lkmPhone;  \/\/ \u8054\u7cfb\u4eba\u529e\u516c\u7535\u8bdd<br \/>\n    &#064;Column(name &#061; &#034;lkm_mobile&#034;)<br \/>\n    private String lkmMobile;  \/\/ \u8054\u7cfb\u4eba\u624b\u673a<br \/>\n    &#064;Column(name &#061; &#034;lkm_email&#034;)<br \/>\n    private String lkmEmail;  \/\/ \u8054\u7cfb\u4eba\u90ae\u7bb1<br \/>\n    &#064;Column(name &#061; &#034;lkm_position&#034;)<br \/>\n    private String lkmPosition;  \/\/ \u8054\u7cfb\u4eba\u804c\u4f4d<br \/>\n    &#064;Column(name &#061; &#034;lkm_memo&#034;)<br \/>\n    private String lkmMemo;  \/\/ \u8054\u7cfb\u4eba\u5907\u6ce8<\/p>\n<p>    \/\/ \u914d\u7f6e\u8054\u7cfb\u4eba\u5230\u5ba2\u6237\u7684\u591a\u5bf9\u4e00\u5173\u7cfb<br \/>\n    \/*<br \/>\n        \u4f7f\u7528\u6ce8\u89e3\u7684\u5f62\u5f0f\u914d\u7f6e\u591a\u5bf9\u4e00\u5173\u7cfb<br \/>\n            1. \u914d\u7f6e\u8868\u5173\u7cfb<br \/>\n                &#8211; &#064;ManyToOne&#xff1a;\u914d\u7f6e\u591a\u5bf9\u4e00\u5173\u7cfb<br \/>\n                    targetEntity&#xff1a;\u5bf9\u65b9\u5bf9\u8c61\u7684\u5b57\u8282\u7801\u5bf9\u8c61<br \/>\n            2. \u914d\u7f6e\u5916\u952e&#xff08;\u6216\u4e2d\u95f4\u8868&#xff09;<\/p>\n<p>        \u6ce8&#xff1a;\u914d\u7f6e\u5916\u952e\u7684\u8fc7\u7a0b&#xff0c;\u914d\u7f6e\u5230\u4e86\u591a\u7684\u4e00\u65b9&#xff0c;\u5c31\u4f1a\u5728\u591a\u7684\u4e00\u65b9\u7ef4\u62a4\u5916\u952e<\/p>\n<p>        fetch:\u914d\u7f6e\u5173\u8054\u5bf9\u8c61\u7684\u52a0\u8f7d\u65b9\u5f0f<br \/>\n                FetchType.EAGER \u7acb\u5373\u52a0\u8f7d &#8212; \u9ed8\u8ba4<br \/>\n                FetchType.LAZY  \u5ef6\u8fdf\u52a0\u8f7d<br \/>\n     *\/<br \/>\n    &#064;ManyToOne(targetEntity &#061; Customer.class\/*, fetch &#061; FetchType.LAZY*\/)<br \/>\n    &#064;JoinColumn(name &#061; &#034;lkm_cust_id&#034;, referencedColumnName &#061; &#034;cust_id&#034;)<br \/>\n    private Customer customer;<\/p>\n<p>    \/\/ \u6ce8\u610f\u4e0d\u542bcustomer<br \/>\n    &#064;Override<br \/>\n    public String toString() {<br \/>\n        return &#034;LinkMan{&#034; &#043;<br \/>\n                &#034;lkmId&#061;&#034; &#043; lkmId &#043;<br \/>\n                &#034;, lkmName&#061;&#039;&#034; &#043; lkmName &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, lkmGender&#061;&#039;&#034; &#043; lkmGender &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, lkmPhone&#061;&#039;&#034; &#043; lkmPhone &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, lkmMobile&#061;&#039;&#034; &#043; lkmMobile &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, lkmEmail&#061;&#039;&#034; &#043; lkmEmail &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, lkmPosition&#061;&#039;&#034; &#043; lkmPosition &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#034;, lkmMemo&#061;&#039;&#034; &#043; lkmMemo &#043; &#039;\\\\&#039;&#039; &#043;<br \/>\n                &#039;}&#039;;<br \/>\n    }<br \/>\n}<\/p>\n<p>src\\\\test\\\\java\\\\top\\\\onefine\\\\dao\\\\ObjectQueryTest.java&#xff1a;<\/p>\n<p>package top.onefine.dao;<\/p>\n<p>import org.junit.Test;<br \/>\nimport org.junit.runner.RunWith;<br \/>\nimport org.springframework.beans.factory.annotation.Autowired;<br \/>\nimport org.springframework.test.annotation.Rollback;<br \/>\nimport org.springframework.test.context.ContextConfiguration;<br \/>\nimport org.springframework.test.context.junit4.SpringJUnit4ClassRunner;<br \/>\nimport org.springframework.transaction.annotation.Transactional;<br \/>\nimport top.onefine.domain.Customer;<br \/>\nimport top.onefine.domain.LinkMan;<\/p>\n<p>import java.util.Set;<\/p>\n<p>&#064;SuppressWarnings(&#034;All&#034;)<br \/>\n&#064;RunWith(SpringJUnit4ClassRunner.class)<br \/>\n&#064;ContextConfiguration(locations &#061; &#034;classpath:applicationContext.xml&#034;)<br \/>\npublic class ObjectQueryTest {<\/p>\n<p>    &#064;Autowired<br \/>\n    private CustomerDao customerDao;<\/p>\n<p>    &#064;Autowired<br \/>\n    private LinkManDao linkManDao;<\/p>\n<p>    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u89e3\u51b3&#xff1a;could not initialize proxy &#8211; no Session \u95ee\u9898<br \/>\n    public void testQuery1() {<br \/>\n        \/\/ 1. \u67e5\u8be2\u5ba2\u6237<br \/>\n        Customer user &#061; customerDao.getOne(3L);  \/\/ \u5ef6\u8fdf\u52a0\u8f7d<br \/>\n        \/\/ 2. \u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2&#xff0c;\u67e5\u8be2\u6b64\u5ba2\u6237\u4e0b\u7684\u6240\u6709\u8054\u7cfb\u4eba<br \/>\n        Set&lt;LinkMan&gt; linkMans &#061; user.getLinkMans();<br \/>\n        for (LinkMan linkMan : linkMans) {<br \/>\n            System.out.println(linkMan);<br \/>\n        }<br \/>\n    }<\/p>\n<p>    \/**<br \/>\n     * \u4e00\u7684\u4e00\u65b9<br \/>\n     * \u6ce8\u610f&#xff1a;\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2 \u9ed8\u8ba4\u4f7f\u7528\u7684\u662f\u5ef6\u8fdf\u52a0\u8f7d \u7684\u5f62\u5f0f\u67e5\u8be2\u7684<br \/>\n     *      \u8c03\u7528getLinkMans\u65b9\u6cd5\u5e76\u4e0d\u4f1a\u7acb\u5373\u53d1\u9001\u67e5\u8be2&#xff0c;\u800c\u662f\u5728\u4f7f\u7528\u5173\u8054\u5bf9\u8c61\u7684\u65f6\u5019\u624d\u4f1a\u67e5\u8be2&#xff0c;\u6240\u4ee5\u662f\u5ef6\u8fdf\u52a0\u8f7d&#xff01;<br \/>\n     *<br \/>\n     * \u82e5\u9700\u8981\u5c06\u5ef6\u8fdf\u52a0\u8f7d\u6539\u4e3a\u7acb\u5373\u52a0\u8f7d&#xff08;\u4e0d\u63a8\u8350\u4f7f\u7528&#xff09;&#xff0c;\u9700\u8981\u4fee\u6539\u914d\u7f6e Customer\u4e2d\u8bbe\u7f6e<br \/>\n     *      fetch,\u9700\u8981\u914d\u7f6e\u5230\u591a\u8868\u6620\u5c04\u5173\u7cfb\u7684\u6ce8\u89e3\u4e0a<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u89e3\u51b3&#xff1a;could not initialize proxy &#8211; no Session \u95ee\u9898<br \/>\n    public void testQuery2() {<br \/>\n        \/\/ 1. \u67e5\u8be2\u5ba2\u6237<br \/>\n        Customer user &#061; customerDao.findOne(3L);  \/\/ \u7acb\u5373\u52a0\u8f7d<br \/>\n        \/\/ 2. \u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2&#xff0c;\u67e5\u8be2\u6b64\u5ba2\u6237\u4e0b\u7684\u6240\u6709\u8054\u7cfb\u4eba<br \/>\n        Set&lt;LinkMan&gt; linkMans &#061; user.getLinkMans();<br \/>\n\/\/        System.out.println(linkMans.size());<br \/>\n        System.out.println(linkMans);<br \/>\n    }<\/p>\n<p>    \/\/ \u4ece\u8054\u7cfb\u4eba\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2\u6240\u5c5e\u5ba2\u6237<br \/>\n    \/** \u591a\u7684\u4e00\u65b9<br \/>\n     * \u6ce8\u610f&#xff1a;\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2 \u9ed8\u8ba4\u4f7f\u7528\u7684\u662f\u7acb\u5373\u52a0\u8f7d \u7684\u5f62\u5f0f\u67e5\u8be2\u7684<br \/>\n     *      \u8c03\u7528getCustomer\u65b9\u6cd5\u4f1a\u7acb\u5373\u53d1\u9001\u67e5\u8be2<br \/>\n     *<br \/>\n     * \u82e5\u9700\u8981\u5c06\u5ef6\u8fdf\u52a0\u8f7d\u6539\u4e3a\u7acb\u5373\u52a0\u8f7d&#xff08;\u4e0d\u63a8\u8350\u4f7f\u7528&#xff09;&#xff0c;\u9700\u8981\u4fee\u6539\u914d\u7f6e LinkMan\u4e2d\u8bbe\u7f6e<br \/>\n     *      fetch,\u9700\u8981\u914d\u7f6e\u5230\u591a\u8868\u6620\u5c04\u5173\u7cfb\u7684\u6ce8\u89e3\u4e0a<br \/>\n     *\/<br \/>\n    &#064;Test<br \/>\n    &#064;Transactional  \/\/ \u89e3\u51b3&#xff1a;could not initialize proxy &#8211; no Session \u95ee\u9898<br \/>\n    public void testQuery3() {<br \/>\n        \/\/ 1. \u67e5\u8be2\u8054\u7cfb\u4eba<br \/>\n        LinkMan linkMan &#061; linkManDao.findOne(4L);<br \/>\n        assert linkMan !&#061; null;<br \/>\n        \/\/ 2. \u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2&#xff0c;\u67e5\u8be2\u6b64\u8054\u7cfb\u4eba\u5bf9\u5e94\u7684\u5ba2\u6237<br \/>\n        Customer customer &#061; linkMan.getCustomer();<\/p>\n<p>        System.out.println(customer);<br \/>\n    }<br \/>\n}<\/p>\n<p>\u5176\u4ed6\u4e0d\u53d8&#xff0c;\u53c2\u7167\u7b2c\u4e09\u7ae0&#xff1a; src\\\\main\\\\java\\\\top\\\\onefine\\\\dao\\\\CustomerDao.java src\\\\main\\\\java\\\\top\\\\onefine\\\\dao\\\\LinkManDao.java src\\\\main\\\\resources\\\\applicationContext.xml pom.xml<\/p>\n<p>\u603b\u7ed3&#xff1a;<\/p>\n<p>\u5bf9\u8c61\u5bfc\u822a\u67e5\u8be2&#xff1a;\u67e5\u8be2\u4e00\u4e2a\u5bf9\u8c61\u7684\u540c\u65f6&#xff0c;\u901a\u8fc7\u6b64\u5bf9\u8c61\u67e5\u8be2\u4ed6\u7684\u5173\u8054\u5bf9\u8c61<\/p>\n<ul>\n<li>\n<p>\u4ece\u4e00\u65b9\u67e5\u8be2\u591a\u65b9&#xff1b;\u9ed8\u8ba4&#xff1a;\u4f7f\u7528\u5ef6\u8fdf\u52a0\u8f7d&#xff0c;\u52a1\u5fc5<\/p>\n<\/li>\n<li>\n<p>\u4ece\u591a\u65b9\u67e5\u8be2\u4e00\u65b9&#xff1b;\u9ed8\u8ba4&#xff1a;\u4f7f\u7528\u7acb\u5373\u52a0\u8f7d<\/p>\n<\/li>\n<\/ul>\n<h5>5.2 \u4f7f\u7528Specification\u67e5\u8be2<\/h5>\n<p>\/**<br \/>\n * Specification\u7684\u591a\u8868\u67e5\u8be2<br \/>\n *\/<br \/>\n&#064;Test<br \/>\npublic void testFind() {<br \/>\nSpecification&lt;LinkMan&gt; spec &#061; new Specification&lt;LinkMan&gt;() {<br \/>\npublic Predicate toPredicate(Root&lt;LinkMan&gt; root, CriteriaQuery&lt;?&gt; query, CriteriaBuilder cb) {<br \/>\n\/\/Join\u4ee3\u8868\u94fe\u63a5\u67e5\u8be2&#xff0c;\u901a\u8fc7root\u5bf9\u8c61\u83b7\u53d6<br \/>\n\/\/\u521b\u5efa\u7684\u8fc7\u7a0b\u4e2d&#xff0c;\u7b2c\u4e00\u4e2a\u53c2\u6570\u4e3a\u5173\u8054\u5bf9\u8c61\u7684\u5c5e\u6027\u540d\u79f0&#xff0c;\u7b2c\u4e8c\u4e2a\u53c2\u6570\u4e3a\u8fde\u63a5\u67e5\u8be2\u7684\u65b9\u5f0f&#xff08;left&#xff0c;inner&#xff0c;right&#xff09;<br \/>\n\/\/JoinType.LEFT : \u5de6\u5916\u8fde\u63a5,JoinType.INNER&#xff1a;\u5185\u8fde\u63a5,JoinType.RIGHT&#xff1a;\u53f3\u5916\u8fde\u63a5<br \/>\nJoin&lt;LinkMan, Customer&gt; join &#061; root.join(&#034;customer&#034;,JoinType.INNER);<br \/>\nreturn cb.like(join.get(&#034;custName&#034;).as(String.class),&#034;\u4f20\u667a\u64ad\u5ba21&#034;);<br \/>\n}<br \/>\n};<br \/>\nList&lt;LinkMan&gt; list &#061; linkManDao.findAll(spec);<br \/>\nfor (LinkMan linkMan : list) {<br \/>\nSystem.out.println(linkMan);<br \/>\n}<br \/>\n}<\/p><\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb3k\u6b21\uff0c\u70b9\u8d5e19\u6b21\uff0c\u6536\u85cf24\u6b21\u3002\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d\uff0c\u6211\u4eec\u6570\u636e\u5e93\u7684\u8868\u96be\u514d\u4f1a\u6709\u76f8\u4e92\u7684\u5173\u8054\u5173\u7cfb\uff0c\u5728\u64cd\u4f5c\u8868\u7684\u65f6\u5019\u5c31\u6709\u53ef\u80fd\u4f1a\u6d89\u53ca\u5230\u591a\u5f20\u8868\u7684\u64cd\u4f5c\u3002\u6709\u65f6\u6211\u4eec\u5728\u67e5\u8be2\u67d0\u4e2a\u5b9e\u4f53\u7684\u65f6\u5019\uff0c\u7ed9\u5b9a\u7684\u6761\u4ef6\u662f\u4e0d\u56fa\u5b9a\u7684\uff0c\u8fd9\u65f6\u5c31\u9700\u8981\u52a8\u6001\u6784\u5efa\u76f8\u5e94\u7684\u67e5\u8be2\u8bed\u53e5\uff0c\u5728Spring Data JPA\u4e2d\u53ef\u4ee5\u901a\u8fc7JpaSpecificationExecutor\u63a5\u53e3\u67e5\u8be2\u3002\u591a\u5bf9\u591a\u5173\u7cfb\u4e2d\uff1a\u7528\u4e2d\u95f4\u8868\uff08\u7b2c\u4e09\u7ae0\u8868\uff09\u6765\u63cf\u8ff0\u8fd9\u79cd\u5173\u7cfb\uff0c\u4e2d\u95f4\u8868\u4e2d\u81f3\u5c11\u5e94\u8be5\u7531\u4e24\u4e2a\u5b57\u6bb5\u7ec4\u6210\uff0c\u8fd9\u4e24\u4e2a\u5b57\u6bb5\u4f5c\u4e3a\u5916\u952e\u6307\u5411\u4e24\u5f20\u8868\u7684\u4e3b\u952e\uff0c\u4e14\u8fd9\u4e24\u4e2a\u5b57\u6bb5\u53c8\u7ec4\u6210\u4e86\u8054\u5408\u4e3b\u952e\u3002\u5728\u4e00\u5bf9\u591a\u5173\u7cfb\u4e2d\uff0c\u6211\u4eec\u4e60\u60ef\u628a\u4e00\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4e3b\u8868\uff0c\u628a\u591a\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4ece\u8868\u3002_jpa specification\u591a\u8868\u67e5\u8be2<\/p>\n","protected":false},"author":2,"featured_media":10559,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[99,100,43],"topic":[],"class_list":["post-10566","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-server","tag-java","tag-100","tag-43"],"yoast_head":"<!-- This site is optimized with the Yoast SEO plugin v20.3 - https:\/\/yoast.com\/wordpress\/plugins\/seo\/ -->\n<title>SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.wsisp.com\/helps\/10566.html\" \/>\n<meta property=\"og:locale\" content=\"zh_CN\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"og:description\" content=\"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb3k\u6b21\uff0c\u70b9\u8d5e19\u6b21\uff0c\u6536\u85cf24\u6b21\u3002\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d\uff0c\u6211\u4eec\u6570\u636e\u5e93\u7684\u8868\u96be\u514d\u4f1a\u6709\u76f8\u4e92\u7684\u5173\u8054\u5173\u7cfb\uff0c\u5728\u64cd\u4f5c\u8868\u7684\u65f6\u5019\u5c31\u6709\u53ef\u80fd\u4f1a\u6d89\u53ca\u5230\u591a\u5f20\u8868\u7684\u64cd\u4f5c\u3002\u6709\u65f6\u6211\u4eec\u5728\u67e5\u8be2\u67d0\u4e2a\u5b9e\u4f53\u7684\u65f6\u5019\uff0c\u7ed9\u5b9a\u7684\u6761\u4ef6\u662f\u4e0d\u56fa\u5b9a\u7684\uff0c\u8fd9\u65f6\u5c31\u9700\u8981\u52a8\u6001\u6784\u5efa\u76f8\u5e94\u7684\u67e5\u8be2\u8bed\u53e5\uff0c\u5728Spring Data JPA\u4e2d\u53ef\u4ee5\u901a\u8fc7JpaSpecificationExecutor\u63a5\u53e3\u67e5\u8be2\u3002\u591a\u5bf9\u591a\u5173\u7cfb\u4e2d\uff1a\u7528\u4e2d\u95f4\u8868\uff08\u7b2c\u4e09\u7ae0\u8868\uff09\u6765\u63cf\u8ff0\u8fd9\u79cd\u5173\u7cfb\uff0c\u4e2d\u95f4\u8868\u4e2d\u81f3\u5c11\u5e94\u8be5\u7531\u4e24\u4e2a\u5b57\u6bb5\u7ec4\u6210\uff0c\u8fd9\u4e24\u4e2a\u5b57\u6bb5\u4f5c\u4e3a\u5916\u952e\u6307\u5411\u4e24\u5f20\u8868\u7684\u4e3b\u952e\uff0c\u4e14\u8fd9\u4e24\u4e2a\u5b57\u6bb5\u53c8\u7ec4\u6210\u4e86\u8054\u5408\u4e3b\u952e\u3002\u5728\u4e00\u5bf9\u591a\u5173\u7cfb\u4e2d\uff0c\u6211\u4eec\u4e60\u60ef\u628a\u4e00\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4e3b\u8868\uff0c\u628a\u591a\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4ece\u8868\u3002_jpa specification\u591a\u8868\u67e5\u8be2\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.wsisp.com\/helps\/10566.html\" \/>\n<meta property=\"og:site_name\" content=\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\" \/>\n<meta property=\"article:published_time\" content=\"2025-04-18T10:02:59+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100257-6802235172933.png\" \/>\n<meta name=\"author\" content=\"admin\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"\u4f5c\u8005\" \/>\n\t<meta name=\"twitter:data1\" content=\"admin\" \/>\n\t<meta name=\"twitter:label2\" content=\"\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4\" \/>\n\t<meta name=\"twitter:data2\" content=\"41 \u5206\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\/\/schema.org\",\"@graph\":[{\"@type\":\"WebPage\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/10566.html\",\"url\":\"https:\/\/www.wsisp.com\/helps\/10566.html\",\"name\":\"SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"isPartOf\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\"},\"datePublished\":\"2025-04-18T10:02:59+00:00\",\"dateModified\":\"2025-04-18T10:02:59+00:00\",\"author\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\"},\"breadcrumb\":{\"@id\":\"https:\/\/www.wsisp.com\/helps\/10566.html#breadcrumb\"},\"inLanguage\":\"zh-Hans\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\/\/www.wsisp.com\/helps\/10566.html\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/10566.html#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"\u9996\u9875\",\"item\":\"https:\/\/www.wsisp.com\/helps\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#website\",\"url\":\"https:\/\/www.wsisp.com\/helps\/\",\"name\":\"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3\",\"description\":\"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b\",\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}\"},\"query-input\":\"required name=search_term_string\"}],\"inLanguage\":\"zh-Hans\"},{\"@type\":\"Person\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41\",\"name\":\"admin\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"zh-Hans\",\"@id\":\"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/\",\"url\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"contentUrl\":\"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery\",\"caption\":\"admin\"},\"sameAs\":[\"http:\/\/wp.wsisp.com\"],\"url\":\"https:\/\/www.wsisp.com\/helps\/author\/admin\"}]}<\/script>\n<!-- \/ Yoast SEO plugin. -->","yoast_head_json":{"title":"SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.wsisp.com\/helps\/10566.html","og_locale":"zh_CN","og_type":"article","og_title":"SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","og_description":"\u6587\u7ae0\u6d4f\u89c8\u9605\u8bfb3k\u6b21\uff0c\u70b9\u8d5e19\u6b21\uff0c\u6536\u85cf24\u6b21\u3002\u5728\u5b9e\u9645\u5f00\u53d1\u4e2d\uff0c\u6211\u4eec\u6570\u636e\u5e93\u7684\u8868\u96be\u514d\u4f1a\u6709\u76f8\u4e92\u7684\u5173\u8054\u5173\u7cfb\uff0c\u5728\u64cd\u4f5c\u8868\u7684\u65f6\u5019\u5c31\u6709\u53ef\u80fd\u4f1a\u6d89\u53ca\u5230\u591a\u5f20\u8868\u7684\u64cd\u4f5c\u3002\u6709\u65f6\u6211\u4eec\u5728\u67e5\u8be2\u67d0\u4e2a\u5b9e\u4f53\u7684\u65f6\u5019\uff0c\u7ed9\u5b9a\u7684\u6761\u4ef6\u662f\u4e0d\u56fa\u5b9a\u7684\uff0c\u8fd9\u65f6\u5c31\u9700\u8981\u52a8\u6001\u6784\u5efa\u76f8\u5e94\u7684\u67e5\u8be2\u8bed\u53e5\uff0c\u5728Spring Data JPA\u4e2d\u53ef\u4ee5\u901a\u8fc7JpaSpecificationExecutor\u63a5\u53e3\u67e5\u8be2\u3002\u591a\u5bf9\u591a\u5173\u7cfb\u4e2d\uff1a\u7528\u4e2d\u95f4\u8868\uff08\u7b2c\u4e09\u7ae0\u8868\uff09\u6765\u63cf\u8ff0\u8fd9\u79cd\u5173\u7cfb\uff0c\u4e2d\u95f4\u8868\u4e2d\u81f3\u5c11\u5e94\u8be5\u7531\u4e24\u4e2a\u5b57\u6bb5\u7ec4\u6210\uff0c\u8fd9\u4e24\u4e2a\u5b57\u6bb5\u4f5c\u4e3a\u5916\u952e\u6307\u5411\u4e24\u5f20\u8868\u7684\u4e3b\u952e\uff0c\u4e14\u8fd9\u4e24\u4e2a\u5b57\u6bb5\u53c8\u7ec4\u6210\u4e86\u8054\u5408\u4e3b\u952e\u3002\u5728\u4e00\u5bf9\u591a\u5173\u7cfb\u4e2d\uff0c\u6211\u4eec\u4e60\u60ef\u628a\u4e00\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4e3b\u8868\uff0c\u628a\u591a\u7684\u4e00\u65b9\u79f0\u4e4b\u4e3a\u4ece\u8868\u3002_jpa specification\u591a\u8868\u67e5\u8be2","og_url":"https:\/\/www.wsisp.com\/helps\/10566.html","og_site_name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","article_published_time":"2025-04-18T10:02:59+00:00","og_image":[{"url":"https:\/\/www.wsisp.com\/helps\/wp-content\/uploads\/2025\/04\/20250418100257-6802235172933.png"}],"author":"admin","twitter_card":"summary_large_image","twitter_misc":{"\u4f5c\u8005":"admin","\u9884\u8ba1\u9605\u8bfb\u65f6\u95f4":"41 \u5206"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"WebPage","@id":"https:\/\/www.wsisp.com\/helps\/10566.html","url":"https:\/\/www.wsisp.com\/helps\/10566.html","name":"SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2 - \u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","isPartOf":{"@id":"https:\/\/www.wsisp.com\/helps\/#website"},"datePublished":"2025-04-18T10:02:59+00:00","dateModified":"2025-04-18T10:02:59+00:00","author":{"@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41"},"breadcrumb":{"@id":"https:\/\/www.wsisp.com\/helps\/10566.html#breadcrumb"},"inLanguage":"zh-Hans","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.wsisp.com\/helps\/10566.html"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/www.wsisp.com\/helps\/10566.html#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"\u9996\u9875","item":"https:\/\/www.wsisp.com\/helps"},{"@type":"ListItem","position":2,"name":"SpringDataJPA\uff08\u4e09\uff09\uff1a\u591a\u8868\u64cd\u4f5c\uff0c\u590d\u6742\u67e5\u8be2"}]},{"@type":"WebSite","@id":"https:\/\/www.wsisp.com\/helps\/#website","url":"https:\/\/www.wsisp.com\/helps\/","name":"\u7f51\u7855\u4e92\u8054\u5e2e\u52a9\u4e2d\u5fc3","description":"\u9999\u6e2f\u670d\u52a1\u5668_\u9999\u6e2f\u4e91\u670d\u52a1\u5668\u8d44\u8baf_\u670d\u52a1\u5668\u5e2e\u52a9\u6587\u6863_\u670d\u52a1\u5668\u6559\u7a0b","potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/www.wsisp.com\/helps\/?s={search_term_string}"},"query-input":"required name=search_term_string"}],"inLanguage":"zh-Hans"},{"@type":"Person","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/358e386c577a3ab51c4493330a20ad41","name":"admin","image":{"@type":"ImageObject","inLanguage":"zh-Hans","@id":"https:\/\/www.wsisp.com\/helps\/#\/schema\/person\/image\/","url":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","contentUrl":"https:\/\/gravatar.wp-china-yes.net\/avatar\/?s=96&d=mystery","caption":"admin"},"sameAs":["http:\/\/wp.wsisp.com"],"url":"https:\/\/www.wsisp.com\/helps\/author\/admin"}]}},"_links":{"self":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/10566","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/comments?post=10566"}],"version-history":[{"count":0,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/posts\/10566\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media\/10559"}],"wp:attachment":[{"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/media?parent=10566"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/categories?post=10566"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/tags?post=10566"},{"taxonomy":"topic","embeddable":true,"href":"https:\/\/www.wsisp.com\/helps\/wp-json\/wp\/v2\/topic?post=10566"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}