全网最详细的Mybatis介绍和基本使用

org.mybatis

mybatis

3.5.4

mysql

mysql-connector-java

5.1.47

3、创建对应的数据表

4、创建与表对应的实体类对象

  • emp.java

public class Emp {

private Integer id;

private String username;

public Integer getId() {

return id;

}

public void setId(Integer id) {

this.id = id;

}

public String getUsername() {

return username;

}

public void setUsername(String username) {

this.username = username;

}

@Override

public String toString() {

return “Emp{” +

“id=” + id +

“, username='” + username + ‘’’ +

‘}’;

}

}

5、创建对应的Mapper接口

  • EmpMapper.java

public interface EmpMapper {

// 根据id查询Emp实体

//@Select(“select * from emp where id=#{id}”)

Emp selectEmp(Integer id);

// 插入

Integer insertEmp(Emp emp);

// 更新

Integer updateEmp(Emp emp);

// 删除

Integer deleteEmp(Integer id);

}

6、编写配置文件

  • mybatis-config.xml
<?xml version="1.0" encoding="UTF-8" ?>

  • EmpMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>

select * from Emp where id = #{id}

INSERT INTO

mybatis.emp ( username)

VALUES (#{username});

UPDATE EMP

SET username=#{username}

WHERE id=#{id}

DELETE FROM emp

WHERE id=#{id}

7、编写测试类

  • MyTest.java

/***

  • MyBatis 搭建步骤:

  • 1.添加pom依赖 (mybatis的核心jar包和数据库版本对应版本的驱动jar包)

  • 2.新建数据库和表

  • 3.添加mybatis全局配置文件 (可以从官网中复制)

  • 4.修改mybatis全局配置文件中的 数据源配置信息

  • 5.添加数据库表对应的POJO对象(相当于我们以前的实体类)

  • 6.添加对应的PojoMapper.xml (里面就维护所有的sql)

  •  修改namespace:  如果是StatementId没有特殊的要求
    
  •                  如果是接口绑定的方式必须等于接口的完整限定名
    
  •  修改对应的id(唯一)、resultType 对应返回的类型如果是POJO需要制定完整限定名
    
  • 7.修改mybatis全局配置文件:修改Mapper

*/

public class MybatisTest {

SqlSessionFactory sqlSessionFactory;

@Before

public void before(){

// 从 XML 中构建 SqlSessionFactory

String resource = “mybatis.xml”;

InputStream inputStream = null;

try {

inputStream = Resources.getResourceAsStream(resource);

} catch (IOException e) {

e.printStackTrace();

}

sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

}

/**

  • 基于StatementId的方式去执行SQL

  •  <mapper resource="EmpMapper.xml"/>
    
  • @throws IOException

*/

@Test

public void test01() {

try (SqlSession session = sqlSessionFactory.openSession()) {

Emp emp = (Emp) session.selectOne(“cn.tulingxueyuan.pojo.EmpMapper.selectEmp”, 1);

System.out.println(emp);

}

}

/**

  • 基于接口绑定的方式

  • 1.新建数据访问层的接口: POJOMapper

  • 2.添加mapper中对应的操作的方法

  •  1.方法名要和mapper中对应的操作的节点的id要一致
    
  •  2.返回类型要和mapper中对应的操作的节点的resultType要一致
    
  •  3.mapper中对应的操作的节点的参数必须要在方法的参数中声明
    
  • 3.Mapper.xml 中的namespace必须要和接口的完整限定名要一致

  • 4.修改mybatis全局配置文件中的mappers,采用接口绑定的方式:

  •    <mapper class="com.mybatis.EmpMapper"></mapper>
    
  • 5.一定要将mapper.xml和接口放在同一级目录中,只需要在resources新建和接口同样结构的文件夹就行了,生成就会合并在一起

  • @throws IOException

*/

@Test

public void test02(){

try (SqlSession session = sqlSessionFactory.openSession()) {

EmpMapper mapper = session.getMapper(EmpMapper.class);

Emp emp = mapper.selectEmp(1);

System.out.println(emp);

}

}

/**

  • 基于注解的方式

  • 1.在接口方法上面写上对应的注解

*@Select(“select * from emp where id=#{id}”)

  • 注意:

  •  注解可以和xml共用, 但是不能同时存在方法对应的xml的id
    

*/

@Test

public void test03(){

try (SqlSession session = sqlSessionFactory.openSession()) {

EmpMapper mapper = session.getMapper(EmpMapper.class);

Emp emp = mapper.selectEmp(1);

System.out.println(emp);

}

}

}

4、增删改查的基本操作


  • EmpMapper.java

public interface EmpMapper {

public Emp findEmpByEmpno(Integer empno);

public int updateEmp(Emp emp);

public int deleteEmp(Integer empno);

public int insertEmp(Emp emp);

}

  • EmpMapper.xml
<?xml version="1.0" encoding="UTF-8" ?>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值