转载----PreparedStatement和Statement的区别

1>PreparedStatement用于处理动态SQL语句,在执行前会有一个预编译过程,这个过程是有时间开销的,虽然相对数据库的操作,该时间开销可以忽略不计,但是PreparedStatement的预编译结果会被缓存,下次执行相同的预编译语句时,就不需要编译,只要将参数直接传入编译过的语句执行代码中就会得到执行,所以,对于批量处理可以大大提高效率。

2>Statement每次都会执行SQL语句,相关数据库都要执行SQL语句的编译。

3>作为开发者,应该尽可能以PreparedStatement代替Statement,其原因如下:

(1)代码的可读性和可维护性。从代码比较中就应该能看出来;

stmt.executeUpdate("insert into tb_name (col1,col2,col2,col4) values (‘"+var1+"‘,‘"+var2+"‘,"+var3+",‘"+var4+"‘)");//stmt是Statement对象实例

perstmt = con.prepareStatement("insert into tb_name (col1,col2,col2,col4) values (?,?,?,?)");
perstmt.setString(1,var1);
perstmt.setString(2,var2);
perstmt.setString(3,var3);
perstmt.setString(4,var4);
perstmt.executeUpdate(); //prestmt是 PreparedStatement 对象实例

(2)PreparedStatement尽最大可能提高性能。

(3)极大的提高了安全性。

恶意SQL语法

String sql = "select * from tb_name where name= ‘"+varname+"‘ and passwd=‘"+varpasswd+"‘"; 
如果我们把[‘ or ‘1‘ = ‘1]作为varpasswd传入进来.用户名随意,看看会成为什么? 
select * from tb_name = ‘随意‘ and passwd = ‘‘ or ‘1‘ = ‘1‘; 
因为‘1‘=‘1‘肯定成立,所以可以任何通过验证.更有甚者: 
把[‘;drop table tb_name;]作为varpasswd传入进来,则: 
select * from tb_name = ‘随意‘ and passwd = ‘‘;drop table tb_name;有些数据库是不会让你成功的,但也有很多数据库就可以使这些语句得到执行. 
而如果你使用预编译语句.你传入的任何内容就不会和原来的语句发生任何匹配的关系.只要全使用预编译语句,你就用不着对传入的数据做任何过虑.而如果使用普通的statement,有可能要对drop,;等做费尽心机的判断和过虑.

时间: 2024-10-22 20:14:44

转载----PreparedStatement和Statement的区别的相关文章

【Java】PreparedStatement和Statement的区别

1>PreparedStatement用于处理动态SQL语句,在执行前会有一个预编译过程,这个过程是有时间开销的,虽然相对数据库的操作,该时间开销可以忽略不计,但是PreparedStatement的预编译结果会被缓存,下次执行相同的预编译语句时,就不需要编译,只要将参数直接传入编译过的语句执行代码中就会得到执行,所以,对于批量处理可以大大提高效率. 2>Statement每次都会执行SQL语句,相关数据库都要执行SQL语句的编译. 3>作为开发者,应该尽可能以PreparedState

JDBC中PreparedStatement和Statement的区别

共同点: PreparedStatement和Statement都是用来执行SQL查询语句的API之一. 不同点: 在PreparedStatement中,当我们经常需要反复执行一条结构相似的sql语句,比如: insert into table values(0,'first',1); insert into table values(0,'second',2); 我们可以使用带占位符的sql来代替它: insert into table values(0,?,?); 然后每次传入参数即可,但

java PreparedStatement和statement的区别

1. PreparedStatement接口继承Statement, PreparedStatement 实例包含已编译的 SQL 语句,所以其执行速度要快于 Statement 对象.2.作为 Statement 的子类,PreparedStatement 继承了 Statement 的所有功能.三种方法execute. executeQuery 和 executeUpdate 已被更改以使之不再需要参数 3.在JDBC应用中,如果你已经是稍有水平开发者,你就应该始终以PreparedStat

PreparedStatement 与 Statement 的区别

1. PreparedStatement 接口继承 Statement, PreparedStatement 实例包含已编译的 SQL 语句,所以其执行速度要快于 Statement 对象. 2.作为 Statement 的子类,PreparedStatement 继承了 Statement 的所有功能.三种方法 execute. executeQuery 和 executeUpdate 已被更改以使之不再需要参数. 3.在JDBC应用中,大部分情况应该以PreparedStatement代替 

Java中PreparedStatement和Statement的用法区别

Java中PreparedStatement和Statement的用法区别 (2012-08-01 11:06:44) 转载▼ 标签: 杂谈   1. PreparedStatement接口继承Statement, PreparedStatement 实例包含已编译的 SQL 语句,所以其执行速度要快于 Statement 对象. 2.作为 Statement 的子类,PreparedStatement 继承了 Statement 的所有功能.三种方法 execute. executeQuery

java.sql.preparedstatement和java.sql.statement的区别

本文转自CSDN,然后整理了一遍.原文出处:CSDN JDBC(java database connectivity,java数据库连接)的api中的主要的四个类之一的java.sql.statement要求开发者付出大量的时间和精力.在使用statement获取JDBC访问时所具有的一个共通的问题是输入适当格式的日期和时间戳:2002-02-0520:56 或者 02/05/02 8:56 pm. 通过使用java.sql.preparedstatement,这个问题可以自动解决.一个prep

prepareStatement与Statement的区别

prepareStatement与Statement的区别 1.区别: 1 stmt=conn.CreateStatement(); 2 resultSet rs=stmt.executeQuery(sql); 3 上面是statement的用法 4 ============================ 5 下面是PrepareStatement的用法 6 ptmt=conn.PreparedStatement(sql); 7 resultSet rs=ptmt.executeQuery()

PreparedStatement 与 Statement

PreparedStatement是用来执行SQL查询语句的API之一,Java提供了 Statement.PreparedStatement 和 CallableStatement三种方式来执行查询语句,其中 Statement 用于通用查询, PreparedStatement 用于执行参数化查询,而 CallableStatement则是用于存储过程.同时PreparedStatement还经常会在Java面试被提及,譬如:Statement与PreparedStatement的区别以及如

PreparedStatement与Statement

PreparedStatement是用来执行SQL查询语句的API之一,Java提供了 Statement.PreparedStatement 和 CallableStatement三种方式来执行查询语句,其中 Statement 用于通用查询, PreparedStatement 用于执行参数化查询,而 CallableStatement则是用于存储过程.同时PreparedStatement还经常会在Java面试被提及,譬如:Statement与PreparedStatement的区别以及如