mybatis入门第一章
mybatis简介
mybatis基于java的持久层框架(开源),它内部封装了jdbc操作的细节,mybatis通过注解或者xml文件的方式将各种statement配置起来,并通过java对象和statement中的sql的动态参数进行映射生成最终执行的sql语句,最终由mybatis执行sql语句并将结果映射为java对象并返回,使用orm思想实现结果集的封装,
Object Relational Mapping 对象关系映射。
将数据库中的字段与实体类的属性对应起来
例如:数据库字段 实体类属性
id id
user_name userName
passwors password
mybatis配置文件
<?xml version="1.0" encoding="UTF-8" ?>pojo类
package com.softeem.mybatis.pojo;
public class User {
private Integer id;
//注意,数据库中的字段为user_name,类中的属性为userName,采用驼峰命名法
private String userName;
private Integer age;
private String sex;
private String work;
public User() {
}
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;
}
public Integer getAge() {
return age;
}
public void setAge(Integer age) {
this.age = age;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public String getWork() {
return work;
}
public void setWork(String work) {
this.work = work;
}
@Override
public String toString() {
return "User{" +
"id=" + id +
", userName='" + userName + '\'' +
", age=" + age +
", sex='" + sex + '\'' +
", work='" + work + '\'' +
'}';
}
}
接口方法
import com.softeem.mybatis.pojo.User;
//mybatis不允许方法重载
public interface UserMapper {
public abstract User getUserByid(int id);
}
与接口对应的映射文件
<?xml version="1.0" encoding="UTF-8" ?> select id,user_name userName,age,sex,work from user where id = #{id}测试
@Test
public void Test01(){
// 加载配置文件。通过配置文件得到工厂
String resource = “my_batis.xml”;
InputStream inputStream = null;
SqlSessionFactory sqlSessionFactory = null;
try {
inputStream = Resources.getResourceAsStream(resource);
// 工厂
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
// 通过工厂得到Sqlsession操作数据库
SqlSession session = sqlSessionFactory.openSession();
UserMapper userMapper = session.getMapper(UserMapper.class);
User u = userMapper.getUserByid(5);
System.out.println(u);
} catch (IOException e) {
e.printStackTrace();
}
}
以上是全部代码,执行结果