Day10.Mybatis 8.1

本文介绍了在Mybatis中如何创建起步依赖,包括mybatis、mysql驱动和lombok。重点讨论了预编译SQL的优势,如提高性能、防止SQL注入。讲解了SQL注入的概念,并展示了参数占位符的使用。接着,文章涵盖了新增、更新和查询操作,以及数据封装和条件查询。还提到了在XML映射文件中使用注解和If、ForEach等语句进行复杂操作。
摘要由CSDN通过智能技术生成

Day10.Mybatis  8.1

  1. 创建时起步依赖(mybatis、mysql驱动、lombok)

2.Application.properties文件中

spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver

spring.datasource.url=jdbc:mysql://localhost:3306/仓库名spring.datasource.username=root

spring.datasource.password=1234

#指定mybatis输出日志的位置, 输出控制台

mybatis.configuration.log-impl=org.apache.ibatis.logging.stdout.StdOutImpl

#开启驼峰命名(推荐):如果字段名与属性名符合驼峰命名规则,mybatis会自动通过驼峰命名规则映射。

mybatis.configuration.map-underscore-to-camel-case=true

#下面这些内容是为了让MyBatis映射
#指定Mybatis的Mapper文件     阿里网域创建的项目自带,可以注释
#mybatis.mapper-locations=classpath:mappers/*xml      //xml文件地址
#指定Mybatis的实体目录
#mybatis.type-aliases-package=com.itheima.pojo       //pojo文件地址

3.pojo实体类要和mybatis中的字段对应(有软件的书写不同)

4.准备Mapper接口 ...Mapper(接口文件)

5.MySQL数据库中设定下仓库的位置

6.测试文件中测试

改查

删除:(mapper文件内)

    @Delete("delete from 表名 where id = #{id}")

    public void delete(Integer id);}

测试文件中

@Autowired

  Private ...Mapper 对象

@Test

  Public 返回类型 方法名(){

对象.mapper文件中方法(实参)}

  1. 预编译SQL,优势1)性能更高: 预编译SQL,编译一次之后会将编译后的SQL语句缓存起来,再次执行相同SQL语句时,不会再次编译。 只是输入的参数不同。2)将敏感字进行转义,安全。
  2. SQL注入:通过操作输入来修改事先定义好的SQL语句,用以达到执行代码对服务器进行攻击的方法。 of ‘1=1’

9.参数占位符

#{...}

执行SQL时,会将#{…}替换为?,生成预编译SQL,会自动设置参数值。

使用时机:参数传递,都使用#{…}

${...}

拼接SQL。直接将参数拼接在SQL语句中,存在SQL注入问题。

使用时机:如果对表名、列表进行动态设置时使用。

新增

@Insert("insert into 表名( 字段1,字段2,....) " +

"values(#{pojo变量名1}, #{pojo变量名2}, ...")<

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值