MyBatis提供了多种元素来配置不同类型的语句,如 SELECT,INSERT,UPDATE,DELETE。
1. INSERT语句
虽然之前我们接触过SELECT语句的映射,但是MyBatis真正强大的功能,在于映射SELECT查询方面的灵活性。我们还是先从简单的语句着手。
1.1 基本形式
一个INSERT SQL语句可以在<insert>元素映射器XML配置文件中配置:
<insert id="insertStudent" parameterType="com.sjf.bean.Student">
INSERT INTO student (ID,name,age,school) VALUES(#{ID},#{name},#{age},#{school})
</insert>
这里id为insertStudent,在命名空间com.sjf.mapper.StudentMapper中唯一标示。paramterType属性对应返回值类型,是一个完全限定类名com.sjf.bean.Student。
我们可以使用命名空间(namespace)和 语句 id 来调用映射语句,如下面代码所示:
/**
* 创建学生信息
* @param student
*/
public void insertStudent(Student student){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
String statement = "com.sjf.mapper.StudentMapper.insertStudent";
session.insert(statement, student);
session.commit();
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
映射器Mapper接口以类型安全的方式调用,映射器接口如下面代码所示:
package com.sjf.mapper;
import com.sjf.bean.Student;
/**
* Student映射器接口
* @author sjf0115
*
*/
public interface StudentMapper {
/**
* 创建一个学生信息
* @param student
*/
int insertStudent(Student student);
}
我们可以使用下面的代码调用:
/**
* 创建学生信息
* @param student
*/
public void insertStudent(Student student){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
StudentMapper studentMapper = session.getMapper(StudentMapper.class);
studentMapper.insertStudent(student);
session.commit();
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
1.2 自动生成主键
使用useGenerateKeys 和 keyProperty 属性让数据库生成auto_increment列的值。
<insert id="insertStudent" parameterType="com.sjf.bean.Student" useGeneratedKeys="true" keyProperty="ID">
INSERT INTO student (name,age,school) VALUES(#{name},#{age},#{school})
</insert>
在这个例子中ID列值将会被MySQL数据库自动生成,并且生成的值会被设置到student对象的ID属性上。
2. UPDATE语句
一个UPDATE SQL语句可以在<update>元素在映射器XML配置中配置:
<update id="updateStudentByID" parameterType="com.sjf.bean.Student">
UPDATE student SET name = #{name}, age = #{age}, school = #{school} WHERE ID = #{ID}
</update>
我们可以使用命名空间(namespace)和 语句 id 来调用映射语句,如下面代码所示:
/**
* 根据学生ID修改学生信息
* @param student
*/
public void updateStudentByID(Student student){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
String statement = "com.sjf.mapper.StudentMapper.updateStudentByID";
session.update(statement, student);
session.commit();
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
映射器Mapper接口以类型安全的方式调用,映射器接口如下面代码所示:
package com.sjf.mapper;
import com.sjf.bean.Student;
/**
* Student映射器接口
* @author sjf0115
*
*/
public interface StudentMapper {
/**
* 根据学生ID修改学生信息
* @param student
* @return
*/
int updateStudentByID(Student student);
}
我们可以使用下面的代码调用:
/**
* 根据学生ID修改学生信息
* @param student
*/
public void updateStudentByID(Student student){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
StudentMapper studentMapper = session.getMapper(StudentMapper.class);
studentMapper.updateStudentByID(student);
session.commit();
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
3. DELETE语句
一个DELETE语句可以使用<delete>元素在映射器XML配置文件中配置:
<delete id="deleteStudentByID" parameterType="int">
DELETE FROM Student WHERE ID = #{ID}
</delete>
我们可以使用命名空间(namespace)和 语句 id 来调用映射语句,如下面代码所示:
/**
* 根据学生ID删除学生信息
* @param student
*/
public void deleteStudentByID(int ID){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
String statement = "com.sjf.mapper.StudentMapper.deleteStudentByID";
session.delete(statement,ID);
session.commit();
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
映射器Mapper接口以类型安全的方式调用,映射器接口如下面代码所示:
package com.sjf.mapper;
import com.sjf.bean.Student;
/**
* Student映射器接口
* @author sjf0115
*
*/
public interface StudentMapper {
/**
* 根据学生ID删除学生信息
* @param ID
* @return
*/
int deleteStudentByID(int ID);
}
我们可以使用下面的代码调用:
/**
* 根据学生ID删除学生信息
* @param student
*/
public void deleteStudentByID(int ID){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
StudentMapper studentMapper = session.getMapper(StudentMapper.class);
studentMapper.deleteStudentByID(ID);
session.commit();
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
4. SELECT语句
4.1 返回单一结果
一个SELECT语句可以使用<select>元素在映射器XML配置文件中配置:
<select id="getStudentByID" parameterType="int" resultType="com.sjf.bean.Student">
select * from Student where ID = #{ID}
</select>
我们可以使用命名空间(namespace)和 语句 id 来调用映射语句,如下面代码所示:
/**
* 根据ID获取学生信息
* @return
*/
public Student getStudentByID(int ID){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
String statement = "com.sjf.mapper.StudentMapper.getStudentByID";
Student stu = session.selectOne(statement,ID);
return stu;
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
映射器Mapper接口以类型安全的方式调用,映射器接口如下面代码所示:
package com.sjf.mapper;
import com.sjf.bean.Student;
/**
* Student映射器接口
* @author sjf0115
*
*/
public interface StudentMapper {
/**
* 根据学生ID获取学生信息
* @param ID
* @return
*/
Student getStudentByID(int ID);
}
我们可以使用下面的代码调用:
/**
* 根据ID获取学生信息
* @return
*/
public Student getStudentByID(int ID){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
StudentMapper studentMapper = session.getMapper(StudentMapper.class);
Student stu = studentMapper.getStudentByID(ID);
return stu;
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
注意:
如果Student类中属性名称与数据库中对应的列名称不相同,在查询填充时不会自动填充,即属性值不会被列值填充。这是因为MyBatis自动对JavaBean中和列名称匹配的属性进行填充。 |
<select id="getStudentByID" parameterType="int" resultType="com.sjf.bean.Student">
select stu_id as ID, name, age, school from Student where stu_id = #{ID}
</select>
ID是Studnet JavaBean的一个属性名称,与之对应的列名称是stu_id。
4.2 返回多条结果
现在让我们看一下如何执行返回多条结果的SELECT查询:
<select id="getAllStudents" resultType="com.sjf.bean.Student">
SELECT ID,name,age,school FROM Student
</select>
我们可以使用命名空间(namespace)和 语句 id 来调用映射语句,如下面代码所示:
/**
* 获取全部学生信息
* @return
*/
public List<Student> getAllStudents(){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
String statement = "com.sjf.mapper.StudentMapper.getAllStudents";
List<Student> students = session.selectList(statement);
session.commit();
return students;
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
映射器Mapper接口以类型安全的方式调用,映射器接口如下面代码所示:
package com.sjf.mapper;
import java.util.List;
import com.sjf.bean.Student;
/**
* Student映射器接口
* @author sjf0115
*
*/
public interface StudentMapper {
/**
* 获取全部学生信息
* @return
*/
List<Student> getAllStudents();
}
我们可以使用下面的代码调用:
/**
* 获取全部学生信息
* @return
*/
public List<Student> getAllStudents(){
SqlSession session = MyBatisSqlSessionFactory.getSqlSession();
try{
StudentMapper studentMapper = session.getMapper(StudentMapper.class);
List<Student> students = studentMapper.getAllStudents();
session.commit();
return students;
}
finally{
if(session != null){
session.close();
}//if
}//finally
}
程序地址: 点击打开链接
参考:《Java Persistence with MyBatis 3》
下载: 点击打开链接