一区二区三区在线-一区二区三区亚洲视频-一区二区三区亚洲-一区二区三区午夜-一区二区三区四区在线视频-一区二区三区四区在线免费观看

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - MyBatis中SqlSession實現增刪改查案例

MyBatis中SqlSession實現增刪改查案例

2020-08-24 10:42garfieldzf Java教程

這篇文章主要介紹了MyBatis中SqlSession實現增刪改查案例,非常不錯,具有參考借鑒價值,需要的朋友可以參考下

前言

     開博客這是第一次寫系列文章,從內心上講是有點擔心自己寫不好,寫不全,畢竟是作為java/mybatis學習的過程想把學習的路線和遇到的問題都總結下來,也讓知識點在腦海里能形成一個體系。

開發環境

    idea2016、mybatis3、SQLServer2012

pom.xml、mybatis.xml、log4j.properties

   先貼上pom.xml是因為他直接和搭建開發環境和測試環境有關系,mybatis.xml則是連接數據庫,log4j.properties在學習階段配置上有助于我們觀察SQL的執行情況。

1、pom.xml

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<dependencies>
 <dependency>
  <groupId>org.mybatis</groupId>
  <artifactId>mybatis</artifactId>
  <version>3.4.2</version>
 </dependency>
 <dependency>
  <groupId>com.microsoft.sqlserver</groupId>
  <artifactId>sqljdbc4</artifactId>
  <version>4.0</version>
 </dependency>
 <dependency>
  <groupId>commons-dbcp</groupId>
  <artifactId>commons-dbcp</artifactId>
  <version>1.4</version>
 </dependency>
 <dependency>
  <groupId>junit</groupId>
  <artifactId>junit</artifactId>
  <version>4.10</version>
 </dependency>
 <dependency>
  <groupId>log4j</groupId>
  <artifactId>log4j</artifactId>
  <version>1.2.17</version>
 </dependency>
 </dependencies>

2、mybatis.xml

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE configuration
  PUBLIC "-//mybatis.org//DTD Config 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-config.dtd">
<configuration>
 
 <!-- MyBatis針對SqlServer進行的配置 -->
 <typeAliases>
  <typeAlias alias="User" type="com.autohome.model.User"/>
  <typeAlias alias="Teacher" type="com.autohome.model.Teacher" />
  <typeAlias alias="Student" type="com.autohome.model.Student" />
 </typeAliases>
 <environments default="development">
  <environment id="development">
   <transactionManager type="JDBC"/>
   <dataSource type="POOLED">
    <property name="driver" value="com.microsoft.sqlserver.jdbc.SQLServerDriver"/>
    <property name="url" value="jdbc:sqlserver://localhost:1433;DatabaseName=test"/>
    <property name="username" value="sa"/>
    <property name="password" value="0"/>
   </dataSource>
  </environment>
 </environments>
 
 
 <mappers>
  <mapper resource="mapper/User.xml"/>
  <mapper resource="mapper/Student.xml"/>
 </mappers>
</configuration>

3、log4j.properties

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
### Log4j配置 ###
### 與Spring結合需要在web.xml中指定此文件位置,并添加監聽器 ###
#定義log4j的輸出級別和輸出目的地(目的地可以自定義名稱,和后面的對應)
#[ level ] , appenderName1 , appenderName2
log4j.rootLogger=DEBUG,console,file
 
#-----------------------------------#
#1 定義日志輸出目的地為控制臺
log4j.appender.console = org.apache.log4j.ConsoleAppender
log4j.appender.console.Target = System.out
log4j.appender.console.Threshold=DEBUG
####可以靈活地指定日志輸出格式,下面一行是指定具體的格式 ###
#%c: 輸出日志信息所屬的類目,通常就是所在類的全名
#%m: 輸出代碼中指定的消息,產生的日志具體信息
#%n: 輸出一個回車換行符,Windows平臺為"/r/n",Unix平臺為"/n"輸出日志信息換行
log4j.appender.console.layout = org.apache.log4j.PatternLayout
log4j.appender.console.layout.ConversionPattern=[%c]-%m%n
 
#-----------------------------------#
#2 文件大小到達指定尺寸的時候產生一個新的文件
log4j.appender.file = org.apache.log4j.RollingFileAppender
#日志文件輸出目錄
log4j.appender.file.File=log/tibet.log
#定義文件最大大小
log4j.appender.file.MaxFileSize=10mb
###輸出日志信息###
#最低級別
log4j.appender.file.Threshold=ERROR
log4j.appender.file.layout=org.apache.log4j.PatternLayout
log4j.appender.file.layout.ConversionPattern=[%p][%d{yy-MM-dd}][%c]%m%n
 
#-----------------------------------#
#3 druid
log4j.logger.druid.sql=INFO
log4j.logger.druid.sql.DataSource=info
log4j.logger.druid.sql.Connection=info
log4j.logger.druid.sql.Statement=info
log4j.logger.druid.sql.ResultSet=info
 
#4 mybatis 顯示SQL語句部分
log4j.logger.org.mybatis=DEBUG
#log4j.logger.cn.tibet.cas.dao=DEBUG
#log4j.logger.org.mybatis.common.jdbc.SimpleDataSource=DEBUG#
#log4j.logger.org.mybatis.common.jdbc.ScriptRunner=DEBUG#
#log4j.logger.org.mybatis.sqlmap.engine.impl.SqlMapClientDelegate=DEBUG#
#log4j.logger.java.sql.Connection=DEBUG
log4j.logger.java.sql=DEBUG
log4j.logger.java.sql.Statement=DEBUG
log4j.logger.java.sql.ResultSet=DEBUG
log4j.logger.java.sql.PreparedStatement=DEBUG

配置mapper.xml

   mapper.xml在mybatis.xml是專職處理sql的一個環節,各種映射和實現都在這里處理

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper
  PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
  "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.autohome.mapper.User">
 <!-- 查詢全部用戶 -->
 <select id="queryUsers" resultType="com.autohome.model.User">
  select * from t_userinfo
 </select>
 <!-- 按照ID查詢 -->
 <select id="queryUserById" parameterType="int" resultType="com.autohome.model.User">
  select * from t_userinfo where id=#{id}
 </select>
 <select id="queryUserByAddress" resultType="com.autohome.model.User">
  select * from t_userinfo where name=#{name,javaType=String,jdbcType=VARCHAR} and address=#{address}
 </select>
 <!-- 添加用戶 -->
 <insert id="insertUsers" parameterType="com.autohome.model.User">
  insert into t_userinfo (name,address) values(#{name},#{address})
 </insert>
 <!-- 修改用戶 -->
 <update id="updateUsers" parameterType="com.autohome.model.User">
  update t_userinfo set name=#{name},address=#{address} where id=#{id}
 </update>
 <!-- 刪除用戶 -->
 <delete id="deleteUsers" parameterType="int">
  delete t_userinfo where id=#{id}
 </delete>
</mapper>

建立單元測試

1、準備工作,我建立的是控制臺程序,所以在使用sqlsession前先創建sqlsessionfactory。當然,還要加載log4j.properties

?
1
2
3
4
5
6
7
8
9
10
11
12
SqlSessionFactory sqlSessionFactory=null;
 @Before
 public void BeforeClass(){
  try {
   InputStream is=Resources.getResourceAsStream("log4j.properties");
   PropertyConfigurator.configure(is);
   Reader reader = Resources.getResourceAsReader("mybatis.xml");
   sqlSessionFactory= new SqlSessionFactoryBuilder().build(reader);
  } catch (IOException e) {
   e.printStackTrace();
  }
 }

2、queryUsers

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
@Test
  public void queryUsers() throws Exception {
    //線程不安全類型,放在方法體內
    SqlSession sqlSession=null;
    try {
      sqlSession=sqlSessionFactory.openSession();
      List<User> list = sqlSession.selectList("com.autohome.mapper.User.queryUsers");
      System.out.println("size:"+list.size());
    } catch (Exception e) {
      e.printStackTrace();
    }finally {
      sqlSession.close();
    }
  }

3、queryUserById

?
1
2
3
4
5
6
7
8
9
10
11
12
13
@Test
  public void queryUserById() {
    SqlSession sqlSession=null;
    try{
      sqlSession=sqlSessionFactory.openSession();
      User user = sqlSession.selectOne("com.autohome.mapper.User.queryUserById",2);
      System.out.println("id:"+user.getId()+",name:"+user.getName()+","+user.getAddress());
    }catch(Exception e){
      e.printStackTrace();
    }finally {
      sqlSession.close();
    }
  }

4、insertUser

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
@Test
  public void insertUser(){
    SqlSession sqlSession=null;
    try{
      sqlSession=sqlSessionFactory.openSession();
      User user =new User();
      user.setName("kobe");
      user.setAddress("usa");
      int result = sqlSession.insert("com.autohome.mapper.User.insertUsers",user);
      sqlSession.commit();
      if(result>0){
        System.out.println("insert success....");
      }else{
        System.out.println("insert error....");
      }
    }catch(Exception e){
      e.printStackTrace();
    }finally {
      sqlSession.close();
    }
  }

5、updateUser

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
@Test
 public void updateUser(){
   SqlSession sqlSession=null;
   try{
     sqlSession=sqlSessionFactory.openSession();
     User user =new User();
     user.setId(36);
     user.setName("kobe");
     user.setAddress("usa");
     int result = sqlSession.update("com.autohome.mapper.User.updateUsers",user);
     sqlSession.commit();
     if(result>0){
       System.out.println("update success....");
     }else{
       System.out.println("update error....");
     }
   }catch(Exception e){
     e.printStackTrace();
   }finally {
     sqlSession.close();
   }
 }

6、deleteUser

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
@Test
  public void deleteUser(){
    SqlSession sqlSession=null;
    try{
      sqlSession=sqlSessionFactory.openSession();
      int result = sqlSession.delete("com.autohome.mapper.User.deleteUsers",49);
      sqlSession.commit();
      if(result>0){
        System.out.println("delete success....");
      }else{
        System.out.println("delete error....");
      }
    }catch(Exception e){
      e.printStackTrace();
    }finally {
      sqlSession.close();
    }
  }

總結

      添加、修改、刪除的操作要調用sqlsession.commit(),不然數據無法入庫的,我剛開始就忘記了這個。

以上所述是小編給大家介紹的MyBatis中SqlSession實現增刪改查案例,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

原文鏈接:http://www.cnblogs.com/sword-successful/p/6504222.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 精品国语对白精品自拍视 | hezyo加勒比一区二区三区 | 欧美日韩亚洲高清不卡一区二区三区 | 包臀裙女教师波多野结衣 | 国产精品久久久久影院色老大 | 男人的天堂久久 | 日韩成本大片35分钟免费播放 | 精品精品久久宅男的天堂 | 亚洲高清影院 | 乳环调教 | 五月天婷婷精品免费视频 | 污小说免费| 国产精品99在线观看 | 美女漫画网 | 美国美女hd18 | 999热在线精品观看全部 | 花唇肿胀无法合拢双性 | 91粉色视频在线导航 | 和日本免费不卡在线v | 高清不卡日本v在线二区 | 女同学用白丝脚玩我的故事 | chinese老太grandma | 午夜伦伦电影理论片费看 | 亚洲国产在线播放 | 久久综合色超碰人人 | 2018亚洲男人天堂 | 亚洲国产精品无圣光一区二区 | 精品一区二区三区在线视频观看 | 成人福利免费在线观看 | 国产高清国内精品福利 | 亚洲欧美国产另类 | 视频在线观看一区二区 | 精品视频 九九九 | 日产精品卡一卡2卡三卡乱码工厂 | 九九国产视频 | 青草视频网站 | 欧美精品一区二区三区免费 | 亚洲视频高清 | 秋霞鲁丝影院久久人人综合 | 色偷偷影院 | 国产伊人网 |