{"id":1947,"date":"2021-01-14T11:35:58","date_gmt":"2021-01-14T03:35:58","guid":{"rendered":"https:\/\/www.yusian.com\/blog\/?p=1947"},"modified":"2021-01-15T17:19:53","modified_gmt":"2021-01-15T09:19:53","slug":"mybatis%e7%9a%84%e7%ae%80%e5%8d%95%e5%85%a5%e9%97%a8","status":"publish","type":"post","link":"https:\/\/www.yusian.com\/blog\/java\/2021\/01\/14\/1135581947.html","title":{"rendered":"MyBatis\u7684\u7b80\u5355\u5165\u95e8"},"content":{"rendered":"<h3>1\u3001\u4ec0\u4e48\u662fMyBatis\uff0c\u89e3\u51b3\u4ec0\u4e48\u95ee\u9898\uff1f<\/h3>\n<ol>\n<li>\u5982\u96f7\u8d2f\u8033\u7684<strong>SSM<\/strong>\u6846\u67b6\u96c6\u6700\u540e\u7684<code>M<\/code>\u6307\u7684\u5c31\u662f<code>MyBatis<\/code>\uff1b<\/li>\n<li>\u7b80\u5355\u4e00\u70b9\u8bf4\uff0cMyBatis\u5c31\u662f\u80fd\u8ba9\u4f60\u7528\u6700\u7b80\u5355\u7684\u65b9\u6cd5\u64cd\u4f5c\u6570\u636e\u5e93\uff1b<\/li>\n<li>\u518d\u6df1\u5165\u4e00\u70b9\u8bb2\uff0cMyBatis\u5c06\u4ee5\u524d\u7684jdbc\u64cd\u4f5c\u8fdb\u884c\u4e86\u518d\u6b21\u5c01\u88c5\uff1b<\/li>\n<li>\u7b80\u5355\u5230\u4ec0\u4e48\u7a0b\u5ea6\u4e86\u5462\uff1f\u7b80\u5355\u5230\u4e86sql\u8bed\u53e5\u4ece\u4ee3\u7801\u4e2d\u5206\u79bb\u5199\u5230\u914d\u7f6e\u6587\u4ef6\u4e2d\u5c31\u884c\u4e86\uff1b<\/li>\n<\/ol>\n<h3>2\u3001\u5982\u4f55\u4f7f\u7528MyBatis<\/h3>\n<ol>\n<li>\u64cd\u4f5c\u6570\u636e\u5e93\u662f\u5728Dao\u5c42\uff0c\u5373\u5404\u79cdXxxDao\u7684\u63a5\u53e3+\u5b9e\u73b0\u7c7b\uff0cMyBatis\u53ea\u9700\u8981\u6211\u4eec\u5b9a\u4e49\u63a5\u53e3\uff0c\u4ed6\u80fd\u5e2e\u6211\u4eec\u5b9e\u73b0\uff1b<\/li>\n<li>\u9996\u5148\u8981\u7406\u89e3MyBatis\u7684\u601d\u8def\uff0c<code>SqlSessionFactoryBuilder<\/code>&#8211;><code>SqlSessionFactory<\/code>&#8211;><code>SqlSession<\/code><\/li>\n<li>\u6709\u4e86SqlSession\uff0c\u901a\u8fc7SqlSession\u7684getMapper\u65b9\u6cd5\u5f97\u5230\u63a5\u53e3\u7684\u4ee3\u7406\u5b9e\u73b0\u7c7b\uff1b<\/li>\n<li>\u63a5\u53e3\u5b9a\u4e49\u7684\u5404\u79cd\u65b9\u6cd5\u5c31\u90fd\u53ef\u4ee5\u76f4\u63a5\u8c03\u7528\u4e86\uff0c\u5f97\u5230\u6211\u4eec\u60f3\u8981\u7684\u6570\u636e\uff1b<\/li>\n<\/ol>\n<h3>3\u3001\u4ee3\u7801\u5b9e\u73b0<\/h3>\n<h4>3.1\u3001xml\u65b9\u5f0f<\/h4>\n<ol>\n<li>\u521b\u5efa\u4e00\u4e2aMaven\u9879\u76ee,\u53c2\u8003\u5b98\u65b9\u6587\u6863:<a class=\"wp-editor-md-post-content-link\" href=\"https:\/\/mybatis.org\/mybatis-3\/zh\/getting-started.html\">https:\/\/mybatis.org\/mybatis-3\/zh\/getting-started.html<\/a>\n<pre data-language=XML><code class=\"language-markup line-numbers\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\"?&gt;\n&lt;project xmlns=\"http:\/\/maven.apache.org\/POM\/4.0.0\"\n        xmlns:xsi=\"http:\/\/www.w3.org\/2001\/XMLSchema-instance\"\n        xsi:schemaLocation=\"http:\/\/maven.apache.org\/POM\/4.0.0 http:\/\/maven.apache.org\/xsd\/maven-4.0.0.xsd\"&gt;\n   &lt;modelVersion&gt;4.0.0&lt;\/modelVersion&gt;\n\n   &lt;groupId&gt;com.yusian&lt;\/groupId&gt;\n   &lt;artifactId&gt;sian-batis&lt;\/artifactId&gt;\n   &lt;version&gt;1.0-SNAPSHOT&lt;\/version&gt;\n   &lt;packaging&gt;jar&lt;\/packaging&gt;\n\n   &lt;dependencies&gt;\n       &lt;dependency&gt;\n           &lt;groupId&gt;org.mybatis&lt;\/groupId&gt;\n           &lt;artifactId&gt;mybatis&lt;\/artifactId&gt;\n           &lt;version&gt;3.5.6&lt;\/version&gt;\n       &lt;\/dependency&gt;\n       &lt;dependency&gt;\n           &lt;groupId&gt;mysql&lt;\/groupId&gt;\n           &lt;artifactId&gt;mysql-connector-java&lt;\/artifactId&gt;\n           &lt;version&gt;5.1.49&lt;\/version&gt;\n       &lt;\/dependency&gt;\n\n       &lt;dependency&gt;\n           &lt;groupId&gt;junit&lt;\/groupId&gt;\n           &lt;artifactId&gt;junit&lt;\/artifactId&gt;\n           &lt;version&gt;4.12&lt;\/version&gt;\n           &lt;scope&gt;test&lt;\/scope&gt;\n       &lt;\/dependency&gt;\n   &lt;\/dependencies&gt;\n   &lt;properties&gt;\n       &lt;maven.compiler.source&gt;8&lt;\/maven.compiler.source&gt;\n       &lt;maven.compiler.target&gt;8&lt;\/maven.compiler.target&gt;\n   &lt;\/properties&gt;\n\n&lt;\/project&gt;\n<\/code><\/pre>\n<\/li>\n<li>\u51c6\u5907\u6570\u636e\u5e93\u53ca\u76f8\u5173\u8868, \u5982:mybatis\u5e93\u4e2d\u6709\u4e00\u4e2atab_user\u8868,\u8be5\u8868\u53ea\u6709id,username,password\u4e09\u4e2a\u5b57\u6bb5<\/p>\n<\/li>\n<li>\n<p>\u51c6\u5907\u5b9e\u4f53\u7c7bUser<\/p>\n<pre><code class=\"language-java line-numbers\">package com.yusian.domain;\n\nimport java.io.Serializable;\n\npublic class User implements Serializable {\n   private Integer id;\n   private String username;\n   private String password;\n\n   public Integer getId() {\n       return id;\n   }\n\n   public void setId(Integer id) {\n       this.id = id;\n   }\n\n   public String getUsername() {\n       return username;\n   }\n\n   public void setUsername(String username) {\n       this.username = username;\n   }\n\n   public String getPassword() {\n       return password;\n   }\n\n   public void setPassword(String password) {\n       this.password = password;\n   }\n\n   @Override\n   public String toString() {\n       return \"User{\" +\n               \"id='\" + id + '\\'' +\n               \", username='\" + username + '\\'' +\n               \", password='\" + password + '\\'' +\n               '}';\n   }\n}\n\n<\/code><\/pre>\n<\/li>\n<li>\u51c6\u5907\u63a5\u53e3UserDao,\u63a5\u53e3\u4e2d\u6709\u4e00\u4e2afindAll\u7684\u65b9\u6cd5\u67e5\u8be2\u6240\u6709\u7528\u6237\u6570\u636e\n<pre><code class=\"language-java line-numbers\">package com.yusian.dao;\n\nimport com.yusian.domain.User;\nimport org.apache.ibatis.annotations.Select;\n\nimport java.util.List;\n\npublic interface UserDao {\n   \/**\n    * \u83b7\u53d6\u6240\u6709\u7528\u6237\u5217\u8868\n    * @return\n    *\/\n   List&lt;User&gt; findAll();\n}\n\n<\/code><\/pre>\n<\/li>\n<li>\u5728Resources\u7684\u6839\u76ee\u5f55\u4e0b\u521b\u5efaSqlMapConfig.xml\u6587\u4ef6\n<pre data-language=XML><code class=\"language-markup line-numbers\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\" ?&gt;\n&lt;!DOCTYPE configuration\n       PUBLIC \"-\/\/mybatis.org\/\/DTD Config 3.0\/\/EN\"\n       \"http:\/\/mybatis.org\/dtd\/mybatis-3-config.dtd\"&gt;\n&lt;configuration&gt;\n   &lt;environments default=\"development\"&gt;\n       &lt;environment id=\"development\"&gt;\n           &lt;transactionManager type=\"JDBC\"\/&gt;\n           &lt;dataSource type=\"POOLED\"&gt;\n               &lt;property name=\"driver\" value=\"com.mysql.jdbc.Driver\"\/&gt;\n               &lt;property name=\"url\" value=\"jdbc:mysql:\/\/\u6570\u636e\u5e93\u5730\u5740:3306\/mybatis?useSSL=false\"\/&gt;\n               &lt;property name=\"username\" value=\"root\"\/&gt;\n               &lt;property name=\"password\" value=\"******\"\/&gt;\n           &lt;\/dataSource&gt;\n       &lt;\/environment&gt;\n   &lt;\/environments&gt;\n   &lt;!--\u6307\u5b9a\u6620\u5c04\u914d\u7f6e\u6587\u4ef6\u7684\u4f4d\u7f6e--&gt;\n   &lt;mappers&gt;\n       &lt;mapper resource=\"com\/yusian\/dao\/UserDao.xml\"\/&gt;\n   &lt;\/mappers&gt;\n&lt;\/configuration&gt;\n<\/code><\/pre>\n<\/li>\n<li>\u5728Resources\u76ee\u5f55\u4e0b\u521b\u5efacom\/yusian\/dao\u4e09\u5c42\u76ee\u5f55,\u518d\u521b\u5efaUserDao.xml\u6587\u4ef6\n<pre data-language=XML><code class=\"language-markup line-numbers\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\" ?&gt;\n&lt;!DOCTYPE mapper\n       PUBLIC \"-\/\/mybatis.org\/\/DTD Mapper 3.0\/\/EN\"\n       \"http:\/\/mybatis.org\/dtd\/mybatis-3-mapper.dtd\"&gt;\n&lt;mapper namespace=\"com.yusian.dao.UserDao\"&gt;\n   &lt;select id=\"findAll\" resultType=\"com.yusian.domain.User\"&gt;\n       select * from tab_user\n   &lt;\/select&gt;\n&lt;\/mapper&gt;\n<\/code><\/pre>\n<\/li>\n<li>\u6d4b\u8bd5\n<pre><code class=\"language-java line-numbers\">public class MyBatisTest {\n   public static void main(String[] args) throws Exception{\n       \/\/ 1\u3001\u521b\u5efaSqlSessionFactoryBuilder\n       SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder();\n       \/\/ 2\u3001\u52a0\u8f7d\u914d\u7f6e\u6587\u4ef6\u751f\u6210SqlSessionFactory\u5bf9\u8c61\n       InputStream is = Resources.getResourceAsStream(\"SqlMapConfig.xml\");\n       SqlSessionFactory factory = builder.build(is);\n       \/\/ 3\u3001factory\u751f\u6210SqlSession\u5bf9\u8c61\n       SqlSession sqlSession = factory.openSession();\n       \/\/ 4\u3001SqlSession\u751f\u6210\u4ee3\u7406\u5b9e\u73b0\u7c7b\n       UserDao userDao = sqlSession.getMapper(UserDao.class);\n       \/\/ 5\u3001\u64cd\u4f5c\u6570\u636e\u5e93\u83b7\u53d6\u6570\u636e\n       List&lt;User&gt; users = userDao.findAll();\n       for (User user : users) {\n           System.out.println(user);\n       }\n       \/\/ 6\u3001\u91ca\u653e\u8d44\u6e90\n       is.close();\n       sqlSession.close();\n   }\n}\n<\/code><\/pre>\n<\/li>\n<\/ol>\n<h4>3.2\u3001\u6ce8\u89e3\u65b9\u5f0f<\/h4>\n<p>\u6ce8\u89e3\u7684\u65b9\u5f0f\u4e0exml\u7684\u533a\u522b\u5728\u4e8e:<\/p>\n<ol>\n<li>\u5220\u9664xml\u6587\u4ef6,\u5426\u5219\u4f1a\u6709\u5e72\u6270,MyBais\u4f1a\u4f18\u5148\u52a0\u8f7dxml\u6587\u4ef6;<\/p>\n<\/li>\n<li>\n<p>SqlMapConfig.xml\u6587\u4ef6\u4e2d\u6700\u540e\u9762\u7684<code>&lt;mapper&gt;<\/code>\u6807\u7b7e\u4e2dresource\u5c5e\u6027\u6539\u6210class\u5c5e\u6027<\/p>\n<pre data-language=XML><code class=\"language-markup line-numbers\">&lt;?xml version=\"1.0\" encoding=\"UTF-8\" ?&gt;\n&lt;!DOCTYPE configuration\n       PUBLIC \"-\/\/mybatis.org\/\/DTD Config 3.0\/\/EN\"\n       \"http:\/\/mybatis.org\/dtd\/mybatis-3-config.dtd\"&gt;\n&lt;configuration&gt;\n   &lt;environments default=\"development\"&gt;\n       &lt;environment id=\"development\"&gt;\n           &lt;transactionManager type=\"JDBC\"\/&gt;\n           &lt;dataSource type=\"POOLED\"&gt;\n               &lt;property name=\"driver\" value=\"com.mysql.jdbc.Driver\"\/&gt;\n               &lt;property name=\"url\" value=\"jdbc:mysql:\/\/\u6570\u636e\u5e93\u5730\u5740:3306\/mybatis?useSSL=false\"\/&gt;\n               &lt;property name=\"username\" value=\"root\"\/&gt;\n               &lt;property name=\"password\" value=\"******\"\/&gt;\n           &lt;\/dataSource&gt;\n       &lt;\/environment&gt;\n   &lt;\/environments&gt;\n   &lt;!--\u6307\u5b9a\u6620\u5c04\u914d\u7f6e\u6587\u4ef6\u7684\u4f4d\u7f6e--&gt;\n   &lt;mappers&gt;\n       &lt;mapper class=\"com.yusian.dao.UserDao\"\/&gt;\n   &lt;\/mappers&gt;\n&lt;\/configuration&gt;\n<\/code><\/pre>\n<\/li>\n<li>\u63a5\u53e3\u7c7b\u4e2d\u65b9\u6cd5\u4e0a\u6dfb\u52a0Select\u6ce8\u91ca,\u6ce8\u91ca\u5c5e\u6027\u4e3asql\u8bed\u53e5\n<pre><code class=\"language-java line-numbers\">package com.yusian.dao;\n\nimport com.yusian.domain.User;\nimport org.apache.ibatis.annotations.Select;\n\nimport java.util.List;\n\npublic interface UserDao {\n   \/**\n    * \u83b7\u53d6\u6240\u6709\u7528\u6237\u5217\u8868\n    * @return\n    *\/\n   @Select(\"select * from tab_user\")\n   List&lt;User&gt; findAll();\n}\n\n<\/code><\/pre>\n<\/li>\n<li>\n<p>\u5176\u4ed6\u90fd\u4e00\u6837,\u6ca1\u6709\u533a\u522b<\/p>\n<\/li>\n<\/ol>\n","protected":false},"excerpt":{"rendered":"<p>1\u3001\u4ec0\u4e48\u662fMyBatis\uff0c\u89e3\u51b3\u4ec0\u4e48\u95ee\u9898\uff1f \u5982\u96f7\u8d2f\u8033\u7684SSM\u6846\u67b6\u96c6\u6700\u540e\u7684M\u6307\u7684\u5c31\u662fMyBatis\uff1b \u7b80\u5355\u4e00\u70b9\u8bf4\uff0cMyBatis\u5c31\u662f\u80fd\u8ba9\u4f60\u7528\u6700\u7b80\u5355\u7684\u65b9\u6cd5\u64cd\u4f5c\u6570\u636e\u5e93\uff1b \u518d\u6df1\u5165\u4e00\u70b9\u8bb2\uff0cMyBatis\u5c06\u4ee5\u524d\u7684jdbc\u64cd\u4f5c\u8fdb\u884c\u4e86\u518d\u6b21\u5c01\u88c5\uff1b \u7b80\u5355\u5230\u4ec0\u4e48\u7a0b\u5ea6\u4e86\u5462\uff1f\u7b80\u5355\u5230\u4e86sql\u8bed\u53e5\u4ece\u4ee3\u7801\u4e2d\u5206\u79bb\u5199\u5230\u914d\u7f6e\u6587\u4ef6\u4e2d\u5c31\u884c\u4e86\uff1b 2\u3001\u5982\u4f55\u4f7f\u7528MyBatis \u64cd\u4f5c\u6570\u636e\u5e93\u662f\u5728Dao\u5c42\uff0c\u5373\u5404\u79cdXxxDao\u7684\u63a5\u53e3+\u5b9e\u73b0\u7c7b\uff0cMyBatis\u53ea\u9700\u8981\u6211\u4eec\u5b9a\u4e49\u63a5\u53e3\uff0c\u4ed6\u80fd\u5e2e\u6211\u4eec\u5b9e\u73b0\uff1b \u9996\u5148\u8981\u7406\u89e3MyBatis\u7684\u601d\u8def\uff0cSqlSessionFactoryBuilder&#8211;>SqlSessionFactory&#8211;>SqlSession \u6709\u4e86SqlSession\uff0c\u901a\u8fc7SqlSession\u7684getMapper\u65b9\u6cd5\u5f97\u5230\u63a5\u53e3\u7684\u4ee3\u7406\u5b9e\u73b0\u7c7b\uff1b \u63a5\u53e3\u5b9a\u4e49\u7684\u5404\u79cd\u65b9\u6cd5\u5c31\u90fd\u53ef\u4ee5\u76f4\u63a5\u8c03\u7528\u4e86\uff0c\u5f97\u5230\u6211\u4eec\u60f3\u8981\u7684\u6570\u636e\uff1b 3\u3001\u4ee3\u7801\u5b9e\u73b0 3.1\u3001xml\u65b9\u5f0f \u521b\u5efa\u4e00\u4e2aMaven\u9879\u76ee,\u53c2\u8003\u5b98\u65b9\u6587\u6863:https:\/\/mybatis.org\/mybatis-3\/zh\/getting-started.html &lt;?xml version=&#8221;1.0&#8243; encoding=&#8221;UTF-8&#8243;?&gt; &lt;project xmlns=&#8221;http:\/\/maven.apache.org\/POM\/4.0.0&#8243; xmlns:xsi=&#8221;http:\/\/www.w3.org\/2001\/XMLSchema-instance&#8221; xsi:schemaLocation=&#8221;http:\/\/maven.apache.org\/POM\/4.0.0 http:\/\/maven.apache.org\/xsd\/maven-4.0.0.xsd&#8221;&gt; &lt;modelVersion&gt;4.0.0&lt;\/modelVersion&gt; &lt;groupId&gt;com.yusian&lt;\/groupId&gt; &lt;artifactId&gt;sian-batis&lt;\/artifactId&gt; &lt;version&gt;1.0-SNAPSHOT&lt;\/version&gt; &lt;packaging&gt;jar&lt;\/packaging&gt; &lt;dependencies&gt; &lt;dependency&gt; &lt;groupId&gt;org.mybatis&lt;\/groupId&gt; &lt;artifactId&gt;mybatis&lt;\/artifactId&gt; &lt;version&gt;3.5.6&lt;\/version&gt; &lt;\/dependency&gt; &lt;dependency&gt; &lt;groupId&gt;mysql&lt;\/groupId&gt; &lt;artifactId&gt;mysql-connector-java&lt;\/artifactId&gt; &lt;version&gt;5.1.49&lt;\/version&gt; &lt;\/dependency&gt; &lt;dependency&gt; &lt;groupId&gt;junit&lt;\/groupId&gt; &lt;artifactId&gt;junit&lt;\/artifactId&gt; &lt;version&gt;4.12&lt;\/version&gt; &lt;scope&gt;test&lt;\/scope&gt; &lt;\/dependency&gt; &lt;\/dependencies&gt; &lt;properties&gt; &lt;maven.compiler.source&gt;8&lt;\/maven.compiler.source&gt; &lt;maven.compiler.target&gt;8&lt;\/maven.compiler.target&gt; &lt;\/properties&gt; &lt;\/project&gt; \u51c6\u5907\u6570\u636e\u5e93\u53ca\u76f8\u5173\u8868, \u5982:mybatis\u5e93\u4e2d\u6709\u4e00\u4e2atab_user\u8868,\u8be5\u8868\u53ea\u6709id,username,password\u4e09\u4e2a\u5b57\u6bb5 \u51c6\u5907\u5b9e\u4f53\u7c7bUser package com.yusian.domain; import [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[35],"tags":[344],"class_list":["post-1947","post","type-post","status-publish","format-standard","hentry","category-java","tag-mybatis"],"_links":{"self":[{"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/posts\/1947","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/comments?post=1947"}],"version-history":[{"count":0,"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/posts\/1947\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/media?parent=1947"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/categories?post=1947"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.yusian.com\/blog\/wp-json\/wp\/v2\/tags?post=1947"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}