spring mvc、meven结合mybatis

mybatis可以说是一个很不错的数据库操作库,相比于hibernate来说,mybatis更加灵活,需要自己写sql语句来实现数据库的操作,但是可以把全部的数据库操作语句都放在一起管理,这样就避免了我们将要去代码里面找到sql语句,然后在执行相应的优化和修改的步骤,而且hibernate不能自己配置sql语句,对于小型项目来说,可能是很不错的选择,但是当我们需要自己优化项目的时候,就会出现捉襟见肘的局面,所以自学了一下mybatis框架的使用。

在集成了springmvc的meven项目框架中,想要加入mybatis还是很方便的,只需要在pom.xml里面加入mybatis的依赖,同时也要加入mysql-connector-java的依赖,因为我们使用的mysql数据库,所以需要这个数据库连接的管理,但是我在使用的时候,发现eclipse中的meven找不到mybatis的依赖,这个时候可以自己去mybatis的官网里面下载mybatis的jar包,在项目中引入依赖

http://blog.mybatis.org/里面下载依赖就好,这里下载的是3.4.4版本的jar包

在src/main/resources下面加入mybatis-config.xml的mybatis依赖配置,这里有一份简单的配置

<?xml version="1.0" encoding="UTF-8" ?>  
<!DOCTYPE configuration PUBLIC "-//ibatis.apache.org//DTD Config 3.0//EN" "http://ibatis.apache.org/dtd/ibatis-3-config.dtd">  
<configuration>  
    <!--配置日志,使用log4j日志-->
    <settings>
        <setting name="logImpl" value="log4j"></setting>
    </settings>
    <!--配置数据库连接环境,这里使用mysql数据库-->
    <environments default="environment">  
        <environment id="environment"> 
            <!--事务管理器,使用JDBC-->
            <transactionManager type="JDBC" />
            <!--数据库连接池的方式-->
            <dataSource type="POOLED">
                <!--数据库驱动-->
                <property name="driver" value="com.mysql.jdbc.Driver" />  
                <property name="url"  
                    value="jdbc:mysql://localhost:3306/spring?characterEncoding=UTF-8" />  
                <property name="username" value="root" />  
                <property name="password" value="vbklio" />  
            </dataSource>  
        </environment>  
    </environments>  
    <!--一些mapper文件,就是我们操作数据库的SQL语句,最好和我们的实体属性相对-->
    <mappers>
        <mapper resource="mybatis/UserMapper.xml"/>
        <mapper resource="mybatis/StudentMapper.xml"/>
    </mappers>
</configuration>

比如一个mapper文件,就是上面配置的对于User模型的mapper

mybatis/UserMapper.xml

<?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:com.model.professional -->
<mapper namespace="uc.meven.test2.UserMapper">
    <resultMap id="userResultMap" type="uc.meven.test2.modal.UserTest">
        <id property="id" column="id"/>
        <result property="name" column="name"/>
        <result property="sex" column="sex"/>
        <result property="age" column="age"/>
    </resultMap>
    <insert id="save" parameterType="uc.meven.test2.modal.UserTest" useGeneratedKeys="true">
        <!-- 底层的SQL语句 -->
        INSERT INTO tb_user(name,sex,age) VALUES(#{name},#{sex},#{age})
    </insert>
    <update id="update" parameterType="uc.meven.test2.modal.UserTest">
        UPDATE tb_user SET name=#{name},sex=#{sex},age=#{age} WHERE id=#{id}
    </update>
    <select id="select" parameterType="int" resultType="uc.meven.test2.modal.UserTest">
        SELECT * FROM tb_user WHERE id=#{id}
    </select>
    <select id="selectAll" resultMap="userResultMap">
        SELECT * FROM tb_user
    </select>
    <delete id="delete" parameterType="int">
        DELETE FROM tb_user WHERE id=#{id}
    </delete>
</mapper>

在我们的数据库操作中只需要简单的开启一个事务连接,调用相应的mapper方法,就可以对数据库进行操作了

//获取相应的mybatis配置
InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        
SqlSession session = sqlSessionFactory.openSession();

// 创建一个要操作的数据实例
UserTest user = new UserTest("小明2", "男", 28);
// 调用相应的mapper来进行相应的数据库操作
session.insert("uc.meven.test2.UserMapper.save", user);
// 提交事务
session.commit();
// 关闭连接
session.close();

这样我们就可以简单的实现我们的数据库操作了

一般我们都会将操作方式再封装一层,通过接口类的方式来实现对mapper的调用,如上面的对User的操作,实现一个UserMapper的接口类

package uc.meven.test2;

import uc.meven.test2.modal.UserTest;

public interface UserMapper {
    UserTest select(int id);
}

注意这里的接口包名和接口名要和我们在UserMapper.xml中声明的命名空间一样,不然会找不到相应的mapper对象

然后在进行数据库操作的时候,直接获取这个接口类就好

InputStream inputStream = Resources.getResourceAsStream("mybatis-config.xml");
SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);

SqlSession session = sqlSessionFactory.openSession();

// 获取相应的mapper接口类
UserMapper um = session.getMapper(UserMapper.class);
// 直接调用接口类里面声明的方法和我们在UserMapper.xml中的数据库操作对应
UserTest user = um.select(1);
// 提交事务
session.commit();
// 关闭连接
session.close();

这样也能实现我们想要的结果

或者我们也可以将sql语句以注解的方式写在相应的接口类方法上,如上面的

package uc.meven.test2.mapper;


import org.apache.ibatis.annotations.Select;

import uc.meven.test2.modal.UserTest;

public interface UserMapper {
    @Select("SELECT * FROM tb_user WHERE id=#{id}")
    UserTest select(int id);
}

这个时候,我们需要把我们的mapper.xml文件中相应的sql操作语句去掉,不然会出现重复定义的问题,但是那个maper.xml文件还是需要的,也就是说我们的sql语句可以写在注解或者是xml文件中,两者二选一就好

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,042评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,996评论 2 384
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,674评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,340评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,404评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,749评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,902评论 3 405
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,662评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,110评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,451评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,577评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,258评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,848评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,726评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,952评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,271评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,452评论 2 348

推荐阅读更多精彩内容