我是靠谱客的博主 欢呼火车,最近开发中收集的这篇文章主要介绍JDBC中使用预编译Statement以及它的优点,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

JDBC中PreparedStatement与Statement一样是用于执行SQL语句的,比如增加,删除

1. 使用PreparedStatement

和 Statement一样,PreparedStatement也是用来执行sql语句的,与创建Statement不同的是,需要根据sql语句创建PreparedStatement。除此之外,还能够通过设置参数,指定相应的值,而不是Statement那样使用字符串拼接:

String sql = "insert into hero values(null,?,?,?)";
Connection c = DriverManager.getConnection(...);
// 根据sql语句创建PreparedStatement
PreparedStatement ps = c.prepareStatement(sql);
// 设置参数
ps.setString(1, "...");
ps.setFloat(2, 313.0f);
ps.setInt(3, 50);
// 执行
ps.execute();

2. PreparedStatement的优点1 - 参数设置

Statement 需要进行字符串拼接,可读性和维护性比较差

String sql = “insert into hero values(null,”+"‘提莫’"+","+313.0f+","+50+")";

PreparedStatement 使用参数设置,可读性好,不易犯错

String sql = “insert into hero values(null,?,?,?)”;

3. PreparedStatement的优点2 - 性能表现

PreparedStatement有预编译机制,性能比Statement更快

// Statement执行10次,需要10次把SQL语句传输到数据库端
// 数据库要对每一次来的SQL语句进行编译处理
Statement s = c.createStatement();
for (int i = 0; i < 10; i++) {
String sql = "insert into hero values(null," + "'...'" + ","
+ 313.0f + "," + 50 + ")";
s.execute(sql);
}
// PreparedStatement 执行10次,只需要1次把SQL语句传输到数据库端
// 数据库对带?的SQL进行预编译
// 每次执行,只需要传输参数到数据库端
// 1. 网络传输量比Statement更小
// 2. 数据库不需要再进行编译,响应更快
String sql = "insert into hero values(null,?,?,?)";
PreparedStatement ps = c.prepareStatement(sql);
for (int i = 0; i < 10; i++) {
ps.setString(1, "提莫");
ps.setFloat(2, 313.0f);
ps.setInt(3, 50);
ps.execute();
}

4. PreparedStatement的优点3 - 防止SQL注入式攻击

假设name是用户提交来的数据

String name = “‘IronMan’ OR 1=1”;

使用Statement就需要进行字符串拼接
拼接出来的语句是:

select * from hero where name = ‘IronMan’ OR 1=1

因为有OR 1=1,这是恒成立
那么就会把所有的人都查出来,而不只是IronMan
如果表里的数据是海量的,比如几百万条,把这个表里的数据全部查出来
会让数据库负载变高,CPU100%,内存消耗光,响应变得极其缓慢

而PreparedStatement使用的是参数设置,就不会有这个问题

最后

以上就是欢呼火车为你收集整理的JDBC中使用预编译Statement以及它的优点的全部内容,希望文章能够帮你解决JDBC中使用预编译Statement以及它的优点所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(37)

评论列表共有 0 条评论

立即
投稿
返回
顶部