A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

mybatis的概述
        mybatis是一个持久层框架,用java编写的。
        它封装了jdbc操作的很多细节,使开发者只需要关注sql语句本身,而无需关注注册驱动,创建连接等繁杂过程
        它使用了ORM思想实现了结果集的封装。

        ORM:
                Object Relational Mappging 对象关系映射
                简单的说:
                        就是把数据库表和实体类及实体类的属性对应起来
                        让我们可以操作实体类就实现操作数据库表。

                        user                        User
                        id                        userId
                        user_name                userName
        今天我们需要做到
                实体类中的属性和数据库表的字段名称保持一致。
                        user                        User
                        id                        id
                        user_name                user_name
5、mybatis的入门
        mybatis的环境搭建
                第一步:创建maven工程并导入坐标
                第二步:创建实体类和dao的接口
                第三步:创建Mybatis的主配置文件
                                SqlMapConifg.xml
                第四步:创建映射配置文件
                                IUserDao.xml
        环境搭建的注意事项:
                第一个:创建IUserDao.xml 和 IUserDao.java时名称是为了和我们之前的知识保持一致。
                        在Mybatis中它把持久层的操作接口名称和映射文件也叫做:Mapper
                        所以:IUserDao 和 IUserMapper是一样的
                第二个:在idea中创建目录的时候,它和包是不一样的
                        包在创建时:com.itheima.dao它是三级结构
                        目录在创建时:com.itheima.dao是一级目录
                第三个:mybatis的映射配置文件位置必须和dao接口的包结构相同
                第四个:映射配置文件的mapper标签namespace属性的取值必须是dao接口的全限定类名
                第五个:映射配置文件的操作配置(select),id属性的取值必须是dao接口的方法名

                当我们遵从了第三,四,五点之后,我们在开发中就无须再写dao的实现类。
        mybatis的入门案例
                第一步:读取配置文件
                第二步:创建SqlSessionFactory工厂
                第三步:创建SqlSession
                第四步:创建Dao接口的代理对象
                第五步:执行dao中的方法
                第六步:释放资源

                注意事项:
                        不要忘记在映射配置中告知mybatis要封装到哪个实体类中
                        配置的方式:指定实体类的全限定类名
               
                mybatis基于注解的入门案例:
                        把IUserDao.xml移除,在dao接口的方法上使用@Select注解,并且指定SQL语句
                        同时需要在SqlMapConfig.xml中的mapper配置时,使用class属性指定dao接口的全限定类名。
        明确:
                我们在实际开发中,都是越简便越好,所以都是采用不写dao实现类的方式。
                不管使用XML还是注解配置。
                但是Mybatis它是支持写dao实现类的。

6、自定义Mybatis的分析:
        mybatis在使用代理dao的方式实现增删改查时做什么事呢?
                只有两件事:
                        第一:创建代理对象
                        第二:在代理对象中调用selectList
               
        自定义mybatis能通过入门案例看到类
                class Resources
                class SqlSessionFactoryBuilder
                interface SqlSessionFactory
                interface SqlSession

0 个回复

您需要登录后才可以回帖 登录 | 加入黑马