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

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》
下载: 点击打开链接


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@SmartSi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值