年轻人的第一个MyBatis项目就要这样来学习,不走弯路

之前的时候写过一篇关于mybatis插件--mybatis plus的文章:

我自己的博客平台发布之后,有小粉丝跟我说,现在刚开始学习Java,是不是可以不用学mybatis了直接学这个啊,听得我心里一阵后怕,总感觉自己带偏了他们的想法

其实我个人觉得,这不仅仅是他这种初学者,也是很多人的错误想法,就是觉得新的技术就是好的,不信?看这个,这也是一个初学者,在写代码的过程中遇到这样一个问题

原因,我直接上聊天记录吧

怎么样,这个问题简单吗?但是也凸显了一个问题,学习,尤其是开发这一行,真的不能激进,所以我借着今天的这个引子,整理今天的这份文章--mybatis,从最一开始的mybatis入门直到整合spring,并且附代码实现,刚开始学习的朋友可以实际操作一下,老牌程序员可以回顾一下当年的青葱岁月,哈哈哈哈哈

我们来看今天的正题吧

MyBatis前世

原生JDBC操作数据库的流程

加载驱动

获取链接 connection

获取statement

设置sql

给占位符 set值

执行sql,获取结果集

对结果集进行解析、封装

释放资源

原生的jdbc操作数据库的缺点:

频繁地进行获取链接、关闭链接,资源浪费。 数据库连接池

sql语句属于硬编码,维护不方便。并且需求变得可能性大,要经常地修改sql

占位符设置参数也属于硬编码,维护不方便

结果集解析过程也是硬编码,希望是能够自动地封装成我们自己开发的pojo对象中去

mybatis入门

mybatis 是一个持久层框架 ORM,他可以对jdbc的操作过程进行封装,使开发者只需关注sql本身,而无需去处理 注册驱动、获取链接、获取statement、结果集解析、资源释放等工作。

ORM :Object Ralational Mapping 对象关系映射

简单地说,是通过描述

对象和关系数据库之间的元数据的映射关系,将java中的对象持久化到关系数据库中。

mybatis配置

1、全局配置文件mybatis.xml(名字任意)

配置mybatis的运行环境,包括连接池、事务等。

2、配置映射文件(配置sql)mapper.xml

3、SqlSessionFactory(会话工厂,通过配置文件获取的)

创建SqlSession。

4、SqlSession(会话)

操作数据库。

5、Executor(执行器)

sqlSession是通过执行器来操作数据库的。

6、mapped Statement(底层封装对象)

对数据库的操作进行封装,包括sql、输入参数、输出结果。

支持的输入输出参数类型

java基本类型

hashmap

自定义pojo对象

简单的Mybatis入门程序

项目架构

jar包

log4j.properties

# Global logging configurationlog4j.rootLogger=DEBUG, stdout# Console output...log4j.appender.stdout=org.apache.log4j.ConsoleAppenderlog4j.appender.stdout.layout=org.apache.log4j.PatternLayoutlog4j.appender.stdout.layout.ConversionPattern=%5p [%t] - %m%n

mybatis.xml

<?xml version="1.0" encoding="UTF-8" ?><!--mybatis的运行环境

        mybatis与Spring整合后就不需要了

    --><!-- 事务--><!--数据库连接池-->

Users.java

publicclassUsers {privateStringusername;privateDatebirthday;privateStringsex;privateStringaddress;publicStringgetUsername() {returnusername;    }publicvoidsetUsername(Stringusername) {this.username = username;    }publicStringgetSex() {returnsex;    }publicvoidsetSex(Stringsex) {this.sex = sex;    }publicDategetBirthday() {returnbirthday;    }publicvoidsetBirthday(Datebirthday) {this.birthday = birthday;    }publicStringgetAddress() {returnaddress;    }publicvoidsetAddress(Stringaddress) {this.address = address;    }}

Users.mapper

<?xml version="1.0" encoding="UTF-8" ?><!--

    namespace;命名空间

    作用:分割sql

    --><!--根据姓名查询用户信息--><!--

        id用于标识映射文件中的sql,其实是statement的id

        parameterType:参数类型

        resultType:输出结果类型,单条结果的类型

        #{}:占位符。如果为简单类型,则可以通过#{value}来取值,也可以通过#{任意名字}来取值

    -->select * from users where id=#{id}<!--${}字符串拼接,不能防止sql注入-->/*传参为‘李%’*/        select * from users where username like #{value}        /*传参为‘李’*/        /*select * from users where username like '${value}%'*/

UsersTest.java

package com.me.test;importcom.me.pojo.Users;importorg.apache.ibatis.io.Resources;importorg.apache.ibatis.session.SqlSession;importorg.apache.ibatis.session.SqlSessionFactory;importorg.apache.ibatis.session.SqlSessionFactoryBuilder;importorg.junit.Before;importorg.junit.Test;importjava.io.IOException;importjava.io.InputStream;importjava.util.List;publicclassUsersTest{privateSqlSessionFactorysqlSessionFactory;    @Beforepublicvoidinit()throwsIOException{//获取全局配置文件InputStreamin=Resources.getResourceAsStream("mybatis.xml");//获取SqlSessionFactorysqlSessionFactory=newSqlSessionFactoryBuilder().build(in);    }    @Testpublicvoid test()throwsIOException{//获取sqlSessionSqlSessionsqlSession=sqlSessionFactory.openSession();//执行sqlUsersuser=sqlSession.selectOne("UsersMapper.selectById",1);System.err.println(user.getUsername());        sqlSession.close();    }    @Testpublicvoid test2(){SqlSessionsqlSession=sqlSessionFactory.openSession();List usersList=sqlSession.selectList("UsersMapper.selectByUserName","李%");/*List<Users> usersList=sqlSession.selectList("UsersMapper.selectByUserName","李");*/System.err.println(usersList);/*System.out.println(usersList.get(0).getUsername());

        System.out.println(usersList.get(1).getUsername());*/}}

mybatis对数据库的常用操作

一、查询

select*fromuserswhereid=#{id}        /*传参为‘李%’*/select*fromuserswhereusername like#{value}/*传参为‘李’*//*select * from users where username like '${value}%'*/

测试方法

@TestpublicvoidselectByUserName(){        SqlSession sqlSession=sqlSessionFactory.openSession();        List usersList=sqlSession.selectList("UsersMapper.selectByUserName","李%");/*List<Users> usersList=sqlSession.selectList("UsersMapper.selectByUserName","李");*/System.err.println(usersList);/*System.out.println(usersList.get(0).getUsername());

        System.out.println(usersList.get(1).getUsername());*/}

二、新增

<!--添加用户信息-->insert into users(id,username,password,address,birthday,sex) values(#{id},#{username},        # {password},#{address},#{birthday},#{sex})insert into users(id,username,password,address,birthday,sex) values(#{id},#{username},#        {password},#{address},#{birthday},#{sex})

测试方法

@TestpublicvoidaddUser(){        SqlSession sqlSession=sqlSessionFactory.openSession();        Users users=newUsers(4,"王五","123",newDate(),"男","北京");intres=sqlSession.insert("UsersMapper.addUser",users);        sqlSession.commit();        sqlSession.close();    }@TestpublicvoidaddUser2(){        SqlSession sqlSession=sqlSessionFactory.openSession();        Users user=newUsers(5,"王五","123",newDate(),"男","北京");intres=sqlSession.insert("UsersMapper.addUser",user);        System.err.println("res:"+res);        System.err.println("users.getId:"+user.getId());        sqlSession.commit();        sqlSession.close();    }

三、修改

        update userssetpassword=#{password},address=#{address} where id=#{id}

测试方法

@TestpublicvoidupdateUser(){        SqlSession sqlSession=sqlSessionFactory.openSession();        Users user=newUsers();        user.setPassword("newPass123456");        user.setAddress("济南");        user.setId(4);intres=sqlSession.update("UsersMapper.updateUser",user);        sqlSession.commit();        sqlSession.close();    }

四、删除

/*这里是简单类型,# { value } 中的value可以任意写*/deletefrom users where id=#{id}   

测试方法

@TestpublicvoiddeleteUser(){        SqlSession sqlSession=sqlSessionFactory.openSession();intres=sqlSession.delete("UsersMapper.deleteUser",5);        System.err.println("res:"+res);        sqlSession.commit();        sqlSession.close();    }

mybatis.xml的一些配置项

1、加载外部资源文件

2、起别名

<!--

            起别名第一种方式

            type:给哪个类起别名 alias:别名

        --><!--<typeAlias type="com.me.pojo.Users" alias="user"></typeAlias>--><!--

            起别名第二种方式:批量起别名

            name:包,起的别名就是类名的全名,首字母大写、小写皆可

        -->

3、SqlSessionFactory和SqlSession

//获取全局配置文件InputStream in= Resources.getResourceAsStream("mybatis.xml");//获取SqlSessionFactorysqlSessionFactory=newSqlSessionFactoryBuilder().build(in);//获取sqlSessionqlSession sqlSession=sqlSessionFactory.openSession();//执行sql

SqlSessionFactory:它是通过全局配置文件获取的,SqlSessionFactoryBuilder创建的。一旦它被创建,就会在程序的执行期一直存在,因此只需要一个实例。也就是说希望它是单例的。

SqlSession:作用是操作数据库,是线程不安全的。因而希望每个线程都有自己的sqlSession的实例。

4、工具类

package com.me.utils;importorg.apache.ibatis.io.Resources;importorg.apache.ibatis.session.SqlSessionFactory;importorg.apache.ibatis.session.SqlSessionFactoryBuilder;importjava.io.IOException;importjava.io.InputStream;publicclassMybatisUtils{privatestaticSqlSessionFactorysqlSessionFactory;static{try{//获取全局配置文件InputStreamin=Resources.getResourceAsStream("mybatis.xml");//获取SqlSessionFactorysqlSessionFactory=newSqlSessionFactoryBuilder().build(in);        }catch(IOExceptione) {            e.printStackTrace();        }    }publicstaticSqlSessionFactorygetSqlSessionFactory(){returnsqlSessionFactory;    }}

5、测试类

@TestpublicvoidselectById()throwsIOException{//获取sqlSessionSqlSession sqlSession= MybatisUtils.getSqlSessionFactory().openSession();//执行sqlUsers user=sqlSession.selectOne("UsersMapper.selectById",1);        System.err.println(user.getUsername());        sqlSession.close();    }

Spring与Mybatis整合

mybatis:dao层,操作数据库,需要单例的SqlSessionFactory工厂。

spring:容器,管理对象。

可以将SqlSessionFactory、事务、连接池以及mapper的动态代理交给spring来做。

applicationContext.xml

<?xml version="1.0" encoding="UTF-8"?>

        http://www.springframework.org/schema/beans/spring-beans.xsd

        http://www.springframework.org/schema/context

        http://www.springframework.org/schema/context/spring-context.xsd

        http://www.springframework.org/schema/aop

        http://www.springframework.org/schema/spring-aop.xsd"><!--加载外部资源文件--><!--数据库连接池--><!--配置SqlSessionFactory,通过Spring来管理会话工厂--><!--配置数据源:因为要使用SqlSession操作数据库--><!--加载mybatis的全局配置文件--><!--<property name="configLocation" value="classpath:mybatis.xml"></property>--><!--Spring起别名--><!--mapper动态代理 通过扫描批量加载mapper接口来创建代理bean,这些bean的名字是接口名字(首字母小写)--><!--指定mapper接口的包路径--><!--注解扫描-->

UsersService.java

publicinterfaceUsersService{publicUsersselectById(intid);}

UsersServiceImpl

@Service("userService")publicclassUsersServiceImplimplementsUsersService{@AutowiredprivateUsersMapper usersMapper;@OverridepublicUsersselectById(intid){returnusersMapper.selectById(id);    }}

测试类

publicclassAppTest{@TestpublicvoidselectById(){        ApplicationContext applicationContext=newClassPathXmlApplicationContext("applicationContext.xml");        UsersService usersService= (UsersService) applicationContext.getBean("userService");        Users user=usersService.selectById(1);        System.err.println(user.getUsername());    }}

总结

好了,不知道看完今天的内容大家感觉怎么样,有没有收获,我基本是按照从入门开始,逐步的往里面填充一些知识的顺序将mybatis进行了整理,那这个时候,我想,在实际的学习过程中你肯定还会遇到一些这样那样的问题,但是千万不要突进,脚踏实地,就从一些基础的,无聊的东西开始一点点的学习,网络上那些说这个牛,哪个好的,他肯定有一门傍身的技术作为基础,所以才能打到他说的那个层次

最后,所有程序员都能当架构师,哈哈哈哈哈

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

推荐阅读更多精彩内容