为什么不再使用原生JDBC,而选择MyBatis之类的框架?

JDBC 中三种执行SQL的API

  • Statement:用于通用查询
  • PreparedStatement:继承至Statement接口,用于执行参数化查询
  • CallableStatement:继承至PreparedStatement接口,用于存储过程

1、问题:Statement与PreparedStatement的区别以及如何避免SQL注入?

  • Statement属于语句硬编码的方式来执行SQL语句
String name = "1' or '1' = '1";
String age = "1' or '1' = '1";
String sql = "select * from user where name = '" + name +"' and age = '"+ age +"'";
最终结果:select * from user where name = '1' or '1' = '1' and age = '1' or '1' = '1'
  • PreparedStatement:占位符/动态参数化
String sql = "select * from user where name = ? and age = ?";
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只打杂的码农

你的鼓励是对我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值