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

简介: 版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/SunnyYoona/article/details/50663860 MyBatis提供了多种元素来配置不同类型的语句,如 SELECT,INSERT,UPDATE,DELETE。
版权声明:本文为博主原创文章,未经博主允许不得转载。 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》
下载: 点击打开链接


目录
相关文章
|
3月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
5月前
|
SQL XML Java
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
文章介绍了MyBatis中高级查询的一对多和多对一映射处理,包括创建数据库表、抽象对应的实体类、使用resultMap中的association和collection标签进行映射处理,以及如何实现级联查询和分步查询。此外,还补充了延迟加载的设置和用法。
mybatis复习04高级查询 一对多,多对一的映射处理,collection和association标签的使用
|
7月前
|
SQL Java 数据库连接
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
idea中配置mybatis 映射文件模版及 mybatis plus 自定义sql
170 3
|
8月前
|
SQL XML Java
后端数据库开发JDBC编程Mybatis之用基于XML文件的方式映射SQL语句实操
后端数据库开发JDBC编程Mybatis之用基于XML文件的方式映射SQL语句实操
102 3
|
9月前
|
SQL Java 数据库连接
【Mybatis】深入学习MyBatis:概述、主要特性以及配置与映射
【Mybatis】深入学习MyBatis:概述、主要特性以及配置与映射
【Mybatis】深入学习MyBatis:概述、主要特性以及配置与映射
若依修改,集成mybatisplus报错,若依集成mybatisplus,总是找不到映射是怎么回事只要是用mp的方法就找报,改成mybatisPlus配置一定要改
若依修改,集成mybatisplus报错,若依集成mybatisplus,总是找不到映射是怎么回事只要是用mp的方法就找报,改成mybatisPlus配置一定要改
|
9月前
|
算法 BI 数据库
MyBatisPlus查询条件设置、映射匹配兼容性、id生成策略、多数据操作
MyBatisPlus查询条件设置、映射匹配兼容性、id生成策略、多数据操作
509 3
|
9月前
|
SQL Java 数据库连接
15:MyBatis对象关系与映射结构-Java Spring
15:MyBatis对象关系与映射结构-Java Spring
150 4
|
9月前
|
XML Java 数据库连接
java对象有集合mybatis如何映射
java对象有集合mybatis如何映射
69 4
|
9月前
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)
Mybatis+mysql动态分页查询数据案例——配置映射文件(HouseDaoMapper.xml)