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》


下载: 点击打开链接