`

Mybatis获取SqlSession

阅读更多

从SqlSessionFactory中获取SqlSession

现在,我们已经知道如何获取SqlSessionFactory对象了,基于同样的启示,我们就可以获得SqlSession的实例了。SqlSession对象完全包含以数据库为背景的所有执行SQL操作的方法。你可以用SqlSession实例来直接执行已映射的SQL语句。例如:

SqlSession session = sqlMapper.openSession();

try {

Blog blog = (Blog) session.selectOne(

"org.mybatis.example.BlogMapper.selectBlog", 101);

} finally {

session.close();

}

这种方法起到的作用,和我们使用之前的MyBatis版本是相似的,现在有一种更简洁的方法。使用合理描述参数和SQL语句返回值的接口(比如BlogMapper.class),这样现在就可以执行更简单,更安全的代码,没有容易发生的字符串文字和转换的错误。

 

 

例如:

SqlSession session = sqlSessionFactory.openSession();

try {

BlogMapper mapper = session.getMapper(BlogMapper.class);

Blog blog = mapper.selectBlog(101);

} finally {

session.close();

}

现在我们来探究一下这里到底执行了什么。

 

探究已映射的SQL语句

这里你也许想知道通过SqlSession和Mapper对象到底执行了什么操作。已映射的SQL语句是一个很大的主题,而且这个主题会贯穿本文档的大部分内容。为了给出一个宏观的概念,这里有一些示例。

上面提到的任何一个示例,语句是通过XML或注解定义的。我们先来看看XML。使用基于XML的映射语言,在过去的几年中使得MyBatis非常流行,它为MyBatis提供所有的特性设置。如果你以前用过MyBatis,这个概念就应该很熟悉了,但是XML映射文件也有很多的改进,后面我们会详细来说。这里给出一个基于XML映射语句的示例,这些语句应该可以满足上述示例中SqlSession对象的调用。

 

<?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="org.mybatis.example.BlogMapper">

<select id="selectBlog" parameterType="int" resultType="Blog">

select * from Blog where id = #{id}

</select>

</mapper>

 

这个简单的例子中看起来有很多额外的东西,但是也相当简洁了。如果你喜欢,你可以在一个单独的XML映射文件中定义很多的映射语句,除XML头部和文档类型声明之外,你可以得到很多方便之处。在文件的剩余部分是很好的自我解释。在命名空间“com.mybatis.example.BlogMapper”中,它定义了一个名为“selectBlog”的映射语句,这样它允许你使用完全限定名“org.mybatis.example.BlogMapper.selectBlog”来调用映射语句,我们下面示例中所有的写法也是这样的。

Blog blog = (Blog) session.selectOne(

"org.mybatis.example.BlogMapper.selectBlog", 101);

 

要注意这个使用完全限定名调用Java对象的方法是相似的,这样做是有原因的。这个命名可以直接映射相同命名空间下的映射器类,使用一个名称,参数和返回值和已映射的查询语句都一样的方法即可。这就允许你非常容易地调用映射器接口中的方法,这和你前面看到的是一样的,下面这个示例中它又出现了。

BlogMapper mapper = session.getMapper(BlogMapper.class);

Blog blog = mapper.selectBlog(101);

第二种方式有很多的优点,首先它不是基于文字的,那就更安全了。第二,如果你的IDE有代码补全功能,那么你可以利用它来操纵已映射的SQL语句。第三,不需要强制类型转换,同时BlogMapper接口可以保持简洁,返回值类型很安全

分享到:
评论

相关推荐

    mybatis获取SqlSession源代码流程

    mybatis获取SqlSession源代码流程

    SpringBoot+MyBatis+SqlSession

    MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。通过这种...

    Mybatis中执行String类型的自己拼写的sql,不执行配置文件中的sql

    例如,如果我们有一个`UserMapper`接口,我们可以在其中定义一个获取用户的方法: ```java public interface UserMapper { @Select("SELECT * FROM users WHERE id = #{id}") User getUserById(int id); } ``` ...

    Mybatis中SqlSession下的四大对象之执行器(executor)

    Mybatis中的SqlSession是与数据库交互的核心组件,它包含了四个重要的内部对象:Executor、StatementHandler、ParameterHandler和ResultHandler。这四个对象共同协作,实现了Mybatis的SQL执行、参数设置、结果处理等...

    mybatis中的sqlsession--executor实现.zip

    在MyBatis框架中,`SqlSession`是一个非常核心的组件,它负责与数据库进行交互,执行SQL语句并返回结果。而`Executor`则是`SqlSession`内部的一个执行器接口,是MyBatis实现数据库操作的核心部分。本文将深入探讨`...

    SqlSession 创建过程.pdf

    在深入了解MyBatis框架中SqlSession对象的创建过程之前,首先要明确SqlSession在MyBatis中的作用。SqlSession是MyBatis中的核心接口之一,它代表与数据库交互的一次会话,用于执行已经映射的SQL语句。创建SqlSession...

    原样输出mybatis的sql执行语句(mysql和oracle都可用).zip

    // 执行方法前,获取SqlSession SqlSession sqlSession = (SqlSession) args[0]; SqlSessionManager sqlSessionManager = sqlSession.getConfiguration().getSqlSessionManager(); Transaction tx = ...

    spring+mybatis链接包

    3. **SqlSessionFactory**:它是MyBatis的核心,用于创建SqlSession对象,SqlSession是执行SQL和获取结果的入口。 4. **Mapper接口和XML映射文件**:MyBatis允许定义Mapper接口,每个方法对应一个SQL查询,XML映射...

    mybatis入门级资源

    在MyBatis中,SqlSession是与数据库交互的核心对象,用于执行SQL语句。而Mapper接口和Mapper XML文件则是定义SQL语句的地方,它们通过注解或XML配置来绑定SQL与Java方法。SqlSessionFactoryBuilder用于构建...

    mybatis和Spring结合例子

    MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。 2. **...

    SqlSession:获取SqlSession并运行mysql

    要获取SqlSession,首先需要创建一个SqlSessionFactory对象。SqlSessionFactory是创建SqlSession的工厂,它可以根据配置文件或DataSource来初始化。通常,我们会使用SqlSessionFactoryBuilder来构建...

    struts+mybatis+spring+框架整合+数据库.zip

    Action在执行业务逻辑时,通过Spring的依赖注入获取到MyBatis的SqlSession,执行相应的SQL操作;最后,Struts根据Action的返回结果,渲染对应的视图页面。 压缩包中的文件列表“struts+ibatis+spring+框架整合+...

    mybatis入门之jdbc操作数据库

    SqlSessionFactory是MyBatis的核心对象,它可以创建SqlSession,进而执行SQL。我们通常通过SqlSessionFactoryBuilder来构建SqlSessionFactory。 ```java String resource = "mybatis-config.xml"; InputStream ...

    Mybatis的笔记pdf

    最后,编写对应的 Java 类(Mapper 接口和实体类),并通过 Mybatis 的 SqlSession 接口进行数据库操作。 在 Spring、SpringMVC 和 SpringBoot 等框架中,Mybatis 可以很好地集成,提供更高效的开发体验。例如,在 ...

    mybatis学习入门一、mybatis+servlet实现数据显示

    1. **SqlSessionFactory**: 这是MyBatis的启动点,用于创建SqlSession对象,它是操作数据库的接口。 2. **SqlSession**: 通过SqlSessionFactory获取,是与数据库交互的接口,用于执行SQL语句。 3. **Mapper**: 定义...

    mybatis入门实例(mysql数据库,带建表语句)

    MyBatis避免了几乎所有的JDBC代码和手动设置参数以及获取结果集。MyBatis可以使用简单的XML或注解进行配置和原始映射,将接口和Java的POJOs(Plain Old Java Objects,普通的Java对象)映射成数据库中的记录。 本入门...

    MyBatis常用项目范例

    同时,还会使用到MyBatis的SqlSession接口,它是执行SQL的主要入口点,提供了打开、提交和关闭事务,以及执行SQL方法等功能。Mapper接口和Mapper XML文件的配合使用也是MyBatis的一大特色,它们让SQL逻辑和Java代码...

    MyBatis3.2.1.jar+MyBatis-Spring1.1.1.jar

    通过MyBatis-Spring,你可以直接在Spring的环境中使用MyBatis的SqlSession和Mapper接口,而无需手动管理事务或者SqlSessionFactory。MyBatis-Spring1.1.1版本可能包含了对Spring框架的兼容性优化,以及对MyBatis...

    mybatissql_mybatis解决sql注入

    6. **使用MyBatis的SqlSession和SqlSessionFactory**:这两个组件负责管理数据库会话和配置,通过它们,开发者可以更好地控制SQL的执行,从而减少注入的风险。 描述中的“全新的sql框架”可能指的是MyBatis相对于...

    MyBatis执行SQL并将结果映射成Java对象.docx

    总的来说,MyBatis通过其配置文件、SqlSessionFactory、SqlSession、Executor和MappedStatement等核心组件,构建了一个强大的数据库操作框架,简化了Java应用程序与数据库的交互,使得开发者可以更加专注于业务逻辑...

Global site tag (gtag.js) - Google Analytics