MyBatis执行流程包括加载配置文件、创建SqlSessionFactory、通过SqlSessionFactory获取SqlSession,然后执行SQL映射文件中定义的SQL语句,并返回结果。
在MyBatis中执行SQL语句,可以通过以下步骤:
1、配置数据源
在MyBatis的配置文件(mybatis-config.xml)中,需要配置数据源,使用MySQL数据库,可以配置如下:
<configuration> <environments default="development"> <environment id="development"> <transactionManager type="JDBC"/> <dataSource type="POOLED"> <property name="driver" value="com.mysql.jdbc.Driver"/> <property name="url" value="jdbc:mysql://localhost:3306/mydb"/> <property name="username" value="root"/> <property name="password" value="123456"/> </dataSource> </environment> </environments> </configuration>
2、创建映射文件
创建一个映射文件(UserMapper.xml),在该文件中编写SQL语句和对应的Java对象。
<?xml version="1.0" encoding="UTF-8"?> <!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd"> <mapper namespace="com.example.mapper.UserMapper"> <select id="getUserById" resultType="com.example.entity.User"> SELECT * FROM user WHERE id = {id} </select> </mapper>
3、创建Java对象
创建一个Java对象(User.java),用于映射数据库表的字段。
public class User { private Integer id; private String name; private Integer age; // getter和setter方法 }
4、创建接口
创建一个接口(UserMapper.java),用于调用映射文件中的SQL语句。
package com.example.mapper; import com.example.entity.User; import org.apache.ibatis.annotations.Param; public interface UserMapper { User getUserById(@Param("id") Integer id); }
5、调用接口方法执行SQL语句
在Java代码中,通过SqlSession对象调用接口方法来执行SQL语句。
import com.example.mapper.UserMapper; import com.example.entity.User; import org.apache.ibatis.session.SqlSession; import org.apache.ibatis.session.SqlSessionFactory; public class Main { public static void main(String[] args) { SqlSessionFactory sqlSessionFactory = ...; // 获取SqlSessionFactory实例 try (SqlSession sqlSession = sqlSessionFactory.openSession()) { UserMapper userMapper = sqlSession.getMapper(UserMapper.class); User user = userMapper.getUserById(1); System.out.println(user); } } }
相关问题与解答:
Q1:如何在MyBatis中执行插入、更新和删除操作?
A1:在映射文件中编写对应的插入、更新和删除SQL语句,然后在接口中定义相应的方法。
<insert id="insertUser" parameterType="com.example.entity.User"> INSERT INTO user (name, age) VALUES ({name}, {age}) </insert> <update id="updateUser" parameterType="com.example.entity.User"> UPDATE user SET name={name}, age={age} WHERE id={id} </update> <delete id="deleteUserById" parameterType="java.lang.Integer"> DELETE FROM user WHERE id={id} </delete>
Q2:如何在MyBatis中执行存储过程?
A2:在映射文件中编写调用存储过程的SQL语句,然后在接口中定义相应的方法。
<select id="callSomeProcedure" statementType="CALLABLE"> { call some_procedure({param1, mode=IN, jdbcType=VARCHAR}, {param2, mode=OUT, jdbcType=VARCHAR}) } </select>
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。