• Mybatis解决字段与属性不匹配的问题、链表查询、嵌套查询、#{}和${}的区别


    1.使用接口结合xml映射文件

    1. 创建一个接口,该接口要和映射文件匹配(接口中方法名要和映射文件中的id相同)
    2. 映射文件中命名空间要和接口全类名相同
    3. 测试:
    4. 创建一个与src同级的源文件夹resources,将配置文件、映射文件、日志属性文件放进去

    2.解决字段与属性不匹配

      1. 映射文件中的namespace与接口不对照
      2. 你的映射文件没有加入到配置文件中
    1. 解决字段与属性不匹配:
      1. 在sql语句中为表中的字段取别名,取名为bean中的属性名
      2. resultMap:引用resultMap标签,resultMap标签中写属性与字段的对应关系,id标签表示表中的主键与实体类中的属性的对应关系,result标签表示表中不是主键的字段与实体类中的属性的对应关系,type表示哪个实体类与表的对应关系

    3.联表查询

    1. 比如根据班级id查询班级信息(关联老师的信息)
      1. 联表查询
        1. teacher bean 类
        2. classbean类
        3. 映射文件
        4. no suchmethodexception :没有加无参构造函数
      2. 嵌套查询
        1.

        2.

        3.
    2. 根据班级id查询班级的学生以及老师(一对多)
      1. 联表查询
        1. 创建Students的bean类,如果bean类中重写了构造函数那么需要添加无参的构造函数
        2. 在class的bean类中添加private List<Students> students;属性并且添加get、set方法
        3. class的映射文件

    4. mybatis中$和#的区别(https://www.cnblogs.com/teach/p/5685545.html)

    1. #{}
      • 使用#{}意味着使用的预编译的语句,即在使用jdbc时的preparedStatement,sql语句中如果存在参数则会使用?作占位符,我们知道这种方式可以防止sql注入,并且在使用#{}时形成的sql语句,已经带有引号,例,select  * from table1 where id=#{id}  在调用这个语句时我们可以通过后台看到打印出的sql为:select * from table1 where id='2' 加入传的值为2.也就是说在组成sql语句的时候把参数默认为字符串。
    2. ${}
      • 使用${}时的sql不会当做字符串处理,是什么就是什么,如上边的语句:select * from table1 where id=${id} 在调用这个语句时控制台打印的为:select * from table1 where id=2 ,假设传的参数值为2从上边的介绍可以看出这两种方式的区别,我们最好是能用#{}则用它,因为它可以防止sql注入,且是预编译的,在需要原样输出时才使用${},如,select * from ${tableName} order by ${id} 这里需要传入表名和按照哪个列进行排序 ,加入传入table1、id 则语句为:select * from table1 order by id如果是使用#{} 则变成了select * from 'table1' order by 'id' 我们知道这样就不对了。
  • 相关阅读:
    c++中单引号和双引号的区别
    C++ 数组
    C++ 输出到文本文件
    C++中文本的读入
    C++ 输入和输出
    C++构造函数和文件组织
    Linux中使用gcc编译文件
    linux下修改gcc编译器版本
    Git--创建与合并分支
    'webpack' 不是内部或外部命令,也不是可运行的程序 或批处理文件。
  • 原文地址:https://www.cnblogs.com/wuliqqq/p/11431815.html
Copyright © 2020-2023  润新知