spring mvc、meven结合mybatis

mybatis可以说是一个很不错的数据库操作库,相比于hibernate来说,mybatis更加灵活,需要自己写sql语句来实现数据库的操作,但是可以把全部的数据库操作语句都放在一起管理,这样就避免了我们将要去代码里面找到sql语句,然后在执行相应的优化和修改的步骤,而且hibernate不能自己配置sql语句,对于小型项目来说,可能是很不错的选择,但是当我们需要自己优化项目的时候,就会出现捉襟见肘的局面,所以自学了一下mybatis框架的使用。

在集成了springmvc的meven项目框架中,想要加入mybatis还是很方便的,只需要在pom.xml里面加入mybatis的依赖,同时也要加入mysql-connector-java的依赖,因为我们使用的mysql数据库,所以需要这个数据库连接的管理,但是我在使用的时候,发现eclipse中的meven找不到mybatis的依赖,这个时候可以自己去mybatis的官网里面下载mybatis的jar包,在项目中引入依赖

http://blog.mybatis.org/里面下载依赖就好,这里下载的是3.4.4版本的jar包

在src/main/resources下面加入mybatis-config.xml的mybatis依赖配置,这里有一份简单的配置

  
  
  
    
    
        
    
    
      
         
            
            
            
            
                
                  
                  
                  
                  
              
          
      
    
    
        
        
    

比如一个mapper文件,就是上面配置的对于User模型的mapper

mybatis/UserMapper.xml





    
        
        
        
        
    
    
        
        INSERT INTO tb_user(name,sex,age) VALUES(#{name},#{sex},#{age})
    
    
        UPDATE tb_user SET name=#{name},sex=#{sex},age=#{age} WHERE id=#{id}
    
    
    
    
        DELETE FROM tb_user WHERE id=#{id}
    

在我们的数据库操作中只需要简单的开启一个事务连接,调用相应的mapper方法,就可以对数据库进行操作了

//获取相应的mybatis配置
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        
SqlSession session = sqlSessionFactory.openSession();

// 创建一个要操作的数据实例
UserTest user = new UserTest("小明2", "男", 28);
// 调用相应的mapper来进行相应的数据库操作
session.insert("uc.meven.test2.UserMapper.save", user);
// 提交事务
session.commit();
// 关闭连接
session.close();

这样我们就可以简单的实现我们的数据库操作了

一般我们都会将操作方式再封装一层,通过接口类的方式来实现对mapper的调用,如上面的对User的操作,实现一个UserMapper的接口类

package uc.meven.test2;

import uc.meven.test2.modal.UserTest;

public interface UserMapper {
    UserTest select(int id);
}

注意这里的接口包名和接口名要和我们在UserMapper.xml中声明的命名空间一样,不然会找不到相应的mapper对象

然后在进行数据库操作的时候,直接获取这个接口类就好

InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

SqlSession session = sqlSessionFactory.openSession();

// 获取相应的mapper接口类
UserMapper um = session.getMapper(UserMapper.class);
// 直接调用接口类里面声明的方法和我们在UserMapper.xml中的数据库操作对应
UserTest user = um.select(1);
// 提交事务
session.commit();
// 关闭连接
session.close();

这样也能实现我们想要的结果

或者我们也可以将sql语句以注解的方式写在相应的接口类方法上,如上面的

package uc.meven.test2.mapper;


import org.apache.ibatis.annotations.Select;

import uc.meven.test2.modal.UserTest;

public interface UserMapper {
    @Select("SELECT * FROM tb_user WHERE id=#{id}")
    UserTest select(int id);
}

这个时候,我们需要把我们的mapper.xml文件中相应的sql操作语句去掉,不然会出现重复定义的问题,但是那个maper.xml文件还是需要的,也就是说我们的sql语句可以写在注解或者是xml文件中,两者二选一就好

你可能感兴趣的:(spring mvc、meven结合mybatis)