mapper.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 namespace="com.zx.mybatis.mapper.StudentMapper">
<resultMap id="myStudent" type="Student">
<id column="id" property="id"/>
<result column="user_name" property="name"/>
<result column="age" property="age"/>
<result column="score" property="score"/>
</resultMap>
<select id="selectStuByAgeAndScore" resultMap="myStudent">
select id, user_name, age, score from student
<where>
<if test="age!=null">
and age = #{age}
</if>
<if test="score!=null">
and score = #{score}
</if>
</where>
</select>
</mapper>
dao接口代码:
package com.zx.mybatis.mapper;
import java.util.List;
import java.util.Map;
import com.zx.mybatis.entity.Student;
public interface StudentMapper {
public List<Student> selectStuByAgeAndScore(Map<String,Object> map);
}
java测试代码:
package com.zx.mybatis.test;
import java.io.IOException;
import java.io.InputStream;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Set;
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 org.junit.Test;
import com.zx.mybatis.entity.Student;
import com.zx.mybatis.mapper.StudentMapper;
import com.zx.mybatis.util.MybatisUtil;
public class Test1 {
@Test
public void Test09() {
SqlSession sqlSession = MybatisUtil.getSqlSession();
StudentMapper sd = sqlSession.getMapper(StudentMapper.class);
int age = 23;
double score = 90.01;
Map<String, Object> map = new HashMap<>();
map.put("age", age);
map.put("score", score);
List<Student> stus = sd.selectStuByAgeAndScore(map);
for(Student s : stus) {
System.out.println(s);
}
sqlSession.close();
}
}
java实体类代码:
package com.zx.mybatis.entity;
public class Student {
private int id;
private String name;
private int age;
private double score;
public Student() {
super();
}
public Student(int id, String name, int age, double score) {
super();
this.id = id;
this.name = name;
this.age = age;
this.score = score;
}
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;
}
public double getScore() {
return score;
}
public void setScore(double score) {
this.score = score;
}
@Override
public String toString() {
return "Student [id=" + id + ", name=" + name + ", age=" + age + ", score=" + score + "]";
};
}
java工具类代码:
package com.zx.mybatis.util;
import java.io.IOException;
import java.io.InputStream;
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 MybatisUtil {
private static String resource = "mybatis.xml";
private static SqlSessionFactory sqlSessionFactory = null;
public static SqlSession getSqlSession() {
if(sqlSessionFactory==null) {
try {
InputStream inputStream = Resources.getResourceAsStream(resource);
sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
} catch (IOException e) {
e.printStackTrace();
}
}
return sqlSessionFactory.openSession();
}
}
jdbc.properties代码:
jdbc.driver=oracle.jdbc.OracleDriver
jdbc.url=jdbc:oracle:thin:@localhost:1521:orcl
jdbc.username=zhangyi
jdbc.password=123456
mybatis.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>
<properties
resource="com/zx/mybatis/properties/jdbc.properties"></properties>
<settings>
<setting name="logImpl" value="LOG4J" />
</settings>
<typeAliases>
<package name="com.zx.mybatis.entity" />
</typeAliases>
<environments default="zy">
<environment id="zy">
<transactionManager type="JDBC"></transactionManager>
<dataSource type="POOLED">
<property name="driver" value="${jdbc.driver}" />
<property name="url" value="${jdbc.url}" />
<property name="username" value="${jdbc.username}" />
<property name="password" value="${jdbc.password}" />
</dataSource>
</environment>
</environments>
<mappers>
<package name="com.zx.mybatis.mapper"/>
</mappers>
</configuration>