[MyBatis日记](4)映射语句

  1. 云栖社区>
  2. 博客>
  3. 正文

[MyBatis日记](4)映射语句

sjf0115 2016-02-14 19:31:57 浏览353
展开阅读全文
版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/50663860
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 自动生成主键
在上述的INSERT语句中,我们可以自动生成(auto-generated)主键的列ID插入值。我们可以使用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中和列名称匹配的属性进行填充
假如说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》


网友评论

登录后评论
0/500
评论
sjf0115
+ 关注