黑马程序员技术交流社区

标题: 【石家庄校区】mybatis笔记。Skr [打印本页]

作者: 陈叶_cy    时间: 2018-10-10 09:31
标题: 【石家庄校区】mybatis笔记。Skr
本帖最后由 陈叶_cy 于 2018-10-10 09:34 编辑

Mybatis
        Mybatis是一个持久层框架,用java编写的。它封装了jdbc操作的很多细节,使开发者只需关注sql语句本身,而无需关注注册驱动,创建连接等繁杂过程,它使用了ORM思想实现了结果集的封装(ORM就是把数据库表和实体类及实体类的属性对应起来,让我们可以操作实体类就实现操作数据库表)
       Mybatis的入门
              Mybatis的环境搭建
                     第一步:创建maven工程并导入坐标
                     第二步:创建实体类和dao的接口
                     第三步:创建Mybatis的主配置文件SqlMapConfig.xml
                     第四步:创建映射配置文件UserDao.xml
              环境搭建的注意事项:
                     第一个:创建USerDao.xml和UserDao.java时名称是为了和我们之前的知识保持一致。
                            在Mybatis中它把持久层的操作接口名称和映射文件也叫做:Mapper
                            所以:UserDao和UserMapper是一样的
                     第二个:在idea中创建目录的时候,它和包是不一样的
                            包在创建时:com.itheima.dao它是三级结构
                            目录在创建时:com.itheima.dao是一级目录
                     第三个:mybatis的映射配置文件位置必须和dao接口的包结构相同
                     第四个:映射配置文件的mapper标签namespace属性的取值必须是dao接口的全限定类名
                     第五个:映射配置文件的操作配置,id属性的取值必须是dao接口的方法名
              当我们遵从了第三四五点之后,我们在开发中就无须再写dao的实现类
       入门案例:
       第一步:读取配置文件
       第二步:创建sqlSessionFactory工厂
       第三步:创建SqlSession
       第四步:创建Dao接口的代理对象
       第五步:执行dao中的方法
       第六步:释放资源
       注意事项:不要忘记在影射配置中高职mybatis要封装到哪个实体类中,配置方式:指定实体类的全限定类名

Mybatis基于注解的入门案例:
       把UserDao.xml移除,在dao接口的方法上使用@Select注解,并且制定SQL语句
       同时需要在SqlMapConfig.xml中的mapper配置时,使用class属性指定dao接口的全限定类名。
       如果mapper类中的属性和数据库中的不一致,那么就封装不到实体类中,需要用别名或者使用接口的配置文件修改,后者使用居多。例如:
       其中result中的property的值为mapper的属性值,column是数据库对应的真实字段,resultMap与之相对应,把原来的 修改为resultMap。
       在插入记录的过程中,如果想返回插入数据的信息,并且返回插入数据的id属性值(id属性值是递增的)那么要在<insert>标签中写上:
       其中select last_inset_id()是固定的写法,keyProperty是mapper中的属性,keyColumn是数据库中的字段,order是在插入之前或者之后返回。
       在参数类型中,参数如果是mapper类型的,那么在接口对应的配置文件中,就必须是mapper的字段值。如果是查询单个的,参数是基本的数据类型的,那么在配置文件中的条件要与接口的形参变量名相同。
       Mapper类再封装mapper类,如下第一个,在QueryVo中封装了user实体类,在对应的配置文件中直接可以用user的对象,然后找所要找的值就即可。
       有时候在写sql语句中,也会出现多个条件然后查找值,可以用其别名的方式把在配置文件中填写对应的别名即可
       把数据结果封装到map集合中
       对应的配置文件
       关于#{}和${}:
              1、#{}表示一个占位符号,通过#{}可以实现preparedStatement向占位符中设置值,自动 进行java类型和jdbc类型转换
              2、#{}可以接受简单类型值或pojo属性值
              3、${}可以接受简单类型值或pojo属性值,如果paramenterType传输单个简单类型值,${}括号中中鞥是value
              4、${}表示拼接sql串,通过${}可以将parameterType传入的内容拼接在sql中且不进行jsbc类型转换






欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2