Github
中文文档
maven仓库:
2.搭建环境org.mybatis mybatis 3.5.6
- 连接数据库(Database)导入maven依赖(pom.xml)
4.0.0 org.example mybatis pom 1.0-SNAPSHOT mb01 8 8 mysql mysql-connector-java 5.1.46 org.mybatis mybatis 3.5.6 junit junit 4.12 src/main/resources ***.xml true src/main/java ***.xml true
- SqlSession(MybatisUtils)
package com.kuang.utiles;
import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import java.io.IOException;
import java.io.InputStream;
public class MybatisUtils {
static SqlSessionFactory sqlSessionFactory;
//这里使用static代码块的原因是想让代码一运行就创建一个SqlSessionFactory实例
static{
String resources = "mybatis-config.xml";
InputStream inputStream = null;
try {
inputStream = Resources.getResourceAsStream(resources);
} catch (IOException e) {
e.printStackTrace();
}
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
}
//获取SqlSession的方法,每当需要执行SQL语句的时候都要调用这个方法
public static SqlSession getSqlSession(){
return sqlSessionFactory.openSession();
}
}
- Mybatis核心配置文件(UserMapper.xml)
- 实体类(User)、接口(UserMapper)、Mapper文件(UserMapper.xml)
package com.kuang.pojo;
public class User {
private int id;
private String name;
private String pwd;
public User() {
}
public User(int id, String name, String pwd) {
this.id = id;
this.name = name;
this.pwd = pwd;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName() {
this.name = name;
}
public String getPwd() {
return pwd;
}
public void setPwd(String pwd) {
this.pwd = pwd;
}
}
package com.kuang.dao;
import com.kuang.pojo.User;
import java.util.List;
public interface UserMapper {
public List getUserList();
}
- 测试(UserMapperTest)
package com.kuang.dao;
import com.kuang.pojo.User;
import com.kuang.utils.MybatisUtils;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;
import java.util.List;
public class UserMapperTest {
@Test
public void Test(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
List userList = mapper.getUserList();
for (User user : userList) {
System.out.print(user.getId());
System.out.print(user.getName().toString());
System.out.println(user.getPwd().toString());
}
}
}
总结:
- 连接数据库导入jar包(maven依赖)SqlSessionMybatis核心配置文件实体类、接口、Mapper文件(代替实现类)test
借鉴笔记
3.增删改查(掌握查)
注意标签顺序(有个表)
1.编写一个db.properties文件
driver=com.mysql.jdbc.Driver url=jdbc:mysql://localhost:3306/mybatis?useSSL=true&useUnicode=true&characterEncoding=utf8 username=root password=420138
2.在mybatis核心配置文件中加在外部配置文件来连接数据库
${xxx} 表示的是:调用某个变量,该变量的名称就是{xxx}里面的"xxx"。
4. typeAliases(定义别名)类型别名是为java类型这只一个短的名字。
意义在于用来减少过长类名的冗余
1.类配置别名
即自定义别名,使用typeAlias标签配置别名,type别名填写全限类定名,alias填写别名,将二者映射在一起。
2.包配置别名
也可以指定一个包名,MyBatis 会在包名下面搜索需要的Java Bean,比如:扫描实体类的包,它的默认别名就为这个类的类名,首字母小写!
在实体类比较少的时候,使用第一种方式。如果实体类十分多,建议使用第二种。
第一种可以DIY别名,第二种则·不行·,如果非要改,需要在实体类上增加注解
@Alias("user")
public class User {}
5.映射器——mappers
映射器是Mybatis中十分重要的,其完成的是注册*Mapper.xml,使得系统能够扫描到对应的xml文件。
三选一,建议1
参考笔记
plugins插件,有数据库就能够自动生成mybatis代码,完成增删改查功能,偷懒用
结果集映射顾名思义就是对结果集进行一系列的处理,得到我们想要的数据。在SQL查询,尤其是复杂查询中,所得出来结果的列名在映射实体类中并不存在,导致在Java业务层中无法得到对应数据,这种情况就需要结果集映射来完成,简单来说就是为结果列名取别名,使得查询出来的结果类名能够对应上实体类上的属性名。
User.java
package com.kuang.pojo;
public class User {
private int id;
private String name;
private String password;//pwd改名password
public User() {
}
public User(int id, String name, String password) {
this.id = id;
this.name = name;
this.password = password;
}
//省略一些GetterSetter和toString
UserMapper.java文件
public interface UserMapper {
//根据id查询用户
User getUserById(int id);
}
UserMapper.xml
UserMapperTest.java
public class UserMapperTest {
@Test
public void Test(){
SqlSession sqlSession = MybatisUtils.getSqlSession();
UserMapper mapper = sqlSession.getMapper(UserMapper.class);
User user = mapper.getUserById(3);
System.out.println(user);
sqlSession.close();
}
}
结果集映射主要解决的是当前查询语句所查询出来的表的列名和属性名不一致的问题,并非是数据库列名和属性名不一致的问题,这点要注意
https://www.kuangstudy.com/bbs/1489949706024325122
mybatis使用注解开发可以不创建xml查询文件,但是弊端也很明显,对于较为复杂的SQL语句会显得接口变得十分臃肿,且无法完成复杂的SQL语句
直接把.UserMapper.xml删掉
//UserMapper.java
package com.kuang.dao;
import com.kuang.pojo.User;
import org.apache.ibatis.annotations.Select;
import java.util.List;
public interface UserMapper {
@Select("select * from mybatis.user")
List getUserList();
}
https://www.kuangstudy.com/bbs/1499684790428209154
Mybatis Projecr
123:mb01
456:mb02
7:mb03



