本帖最后由 陈叶_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类型转换
|