2.mybatis入門實例 連接數據庫進行查詢


1.新建項目,添加mybatis和mysql的jar包

2.在mysql中新建表user[id,name,age]

CREATE TABLE `users` (
   `id` int(11) NOT NULL auto_increment,
   `NAME` varchar(50) default NULL,
   `age` int(11) default NULL,
   PRIMARY KEY  (`id`)
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8

3.新建User類,與db的表對應

public class User {
    
    public User() {
    }
    public User(int id, String name, int age) {
        super();
        this.id = id;
        this.name = name;
        this.age = age;
    }
    private int id;
    private String name;
    private int age;
    public int getId() {
        return id;
    }
    public void setId(int id) {
        this.id = id;
    }
    public String getName() {
        return name;
    }
    public void setName(String name) {
        this.name = name;
    }
    public int getAge() {
        return age;
    }
    public void setAge(int age) {
        this.age = age;
    }
    @Override
    public String toString() {
        return "User [id=" + id + ", name=" + name + ", age=" + age + "]";
    }
    
}

4.在src目錄下面新建mybatis的配置文件conf.xml

<?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>
    <!-- 
        development:開發模式
        work:工作模式
     -->
    <environments default="development">
        <environment id="development">
            <transactionManager type="JDBC" />
            <dataSource type="POOLED">
                <property name="driver" value="com.mysql.jdbc.Driver" />
                <property name="url" value="jdbc:mysql://localhost:3306/mybatis?autoReconnect=true&amp;useUnicode=true&amp;characterEncoding=utf8" />
                <property name="username" value="root" />
                <property name="password" value="root" />
            </dataSource>
        </environment>
    </environments>
    
</configuration>

5.新建userMapper.xml,添加數據庫操作語句

<?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的標簽,在此要在Window-Preference-Xml Catalog中配置mybatis-3-mapper.dtd,
    key=-//mybatis.org//DTD Mapper 3.0//EN
 -->
<mapper namespace="com.mlxs.mybatis.test.userMapper">
    
    <select id="getUser" parameterType="int" resultType="com.mlxs.mybatis.test1.User">
        select * from users where id=#{id}
    </select>
    
    <!-- 添加,參數是一個user對象 -->
    <insert id="addUser" parameterType="com.mlxs.mybatis.test1.User">
        insert into users(name,age) values(#{name},#{age})
    </insert>
    <!-- 更新,參數是一個user對象 -->
    <insert id="updateUser" parameterType="com.mlxs.mybatis.test1.User">
        update users set name=#{name}, age=#{age} where id=#{id}
    </insert>
    <!-- 添加,參數是一個user對象 -->
    <insert id="deleteUser" parameterType="int">
        delete from users where id=#{id}
    </insert>
    
    <!-- 返回一個list,resultType="包名+類名":必須在類中有個無參的構造函數,不然會報錯:
            java.lang.NoSuchMethodException: com.mlxs.mybatis.test1.User.<init>() 
            Caused by: java.lang.NoSuchMethodException: com.mlxs.mybatis.test1.User.<init>()
            at java.lang.Class.getConstructor0(Class.java:2706)
            at java.lang.Class.getDeclaredConstructor(Class.java:1985)
            at org.apache.ibatis.reflection.factory.DefaultObjectFactory.instantiateClass(DefaultObjectFactory.java:57)        
    -->
    <select id="selectAllUsers" resultType="com.mlxs.mybatis.test1.User">
        select * from users
    </select>
</mapper>

將mapper配置文件添加到mybatis的配置文件conf.xml的mappers標簽中:

<!-- 在conf.xml文件中注冊Mapper.xml文件和Mapper類 -->
    <mappers>
        <mapper resource="com/mlxs/mybatis/test1/userMapper.xml" />
        
    </mappers>

6.添加測試類,獲取一個user的信息

import java.io.IOException;
import java.io.InputStream;
import java.io.Reader;

import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;




public class _Test1SelectOne {
    public static void main(String[] args) throws IOException {
        //加載mybatis的xml文件(同時加載加載關聯的映射文件)
        //1.使用類加載器加載mybatis的配置文件
//        InputStream config = _Test1SelectOne.class.getClassLoader().getResourceAsStream("conf.xml");
        //2.使用mybatis的Resources類加載
        Reader config = Resources.getResourceAsReader("conf.xml");
        //創建sqlSessionFactory
        SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(config);
        //創建sqlSession,執行mapper.xml中的sql語句
        SqlSession sqlSession = sessionFactory.openSession();
        //執行映射文件中的sql(namespace + select的id)
        String sql = "com.mlxs.mybatis.test.userMapper.getUser";
        User user = sqlSession.selectOne(sql, "1");//查詢id=1
        //關閉session
        sqlSession.close();
        System.out.println(user);
    }
}

7.結果

User [id=1, name=Tom, age=12]

 

8.測試 增刪改查,導入junit包,添加測試類

import java.util.List;

import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.junit.Test;

import com.mlxs.mybatis.util.MyBatisUtil;


public class _Test2UserCrud {
    
    @Test
    public void addUser(){
        SqlSessionFactory sessionFactory = MyBatisUtil.getSessionFactory();
        SqlSession sqlSession = sessionFactory.openSession();
        String statement = "com.mlxs.mybatis.test.userMapper.addUser";
        int count = sqlSession.insert(statement, new User(0, "add1", 10));
        sqlSession.commit();
        sqlSession.close();
        System.out.println("add count:"+count);
    }
    @Test
    public void updateUser(){
        SqlSessionFactory sessionFactory = MyBatisUtil.getSessionFactory();
        SqlSession sqlSession = sessionFactory.openSession();
        String statement = "com.mlxs.mybatis.test.userMapper.updateUser";
        int count = sqlSession.update(statement, new User(3, "update2", 100));
        sqlSession.commit();
        sqlSession.close();
        System.out.println("update count:"+count);
    }
    @Test
    public void delUser(){
        SqlSessionFactory sessionFactory = MyBatisUtil.getSessionFactory();
        boolean autoCommit = true;//自動提交,不需手動commit
        SqlSession sqlSession = sessionFactory.openSession(autoCommit);
        String statement = "com.mlxs.mybatis.test.userMapper.deleteUser";
        int count = sqlSession.delete(statement, 4);
        sqlSession.close();
        System.out.println("del count:"+count);
    }
    @Test
    public void selectAll(){
        SqlSessionFactory sessionFactory = MyBatisUtil.getSessionFactory();
        boolean autoCommit = true;//自動提交,不需手動commit
        SqlSession sqlSession = sessionFactory.openSession(autoCommit);
        String statement = "com.mlxs.mybatis.test.userMapper.selectAllUsers";
        List<User> userList = sqlSession.selectList(statement);
        sqlSession.close();
        System.out.println(userList);
    }
}

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM