A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 王贺 中级黑马   /  2013-11-26 16:53  /  1202 人查看  /  4 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

在连接数据库进行执行语句的时候,存在Stataement 和PrepardStatement两种方式,问一下,他们之间的区别是什么,以及效率哪个更高。

评分

参与人数 1黑马币 +3 收起 理由
FFF + 3 今日加分已达到上限!请明天再努力哦!.

查看全部评分

4 个回复

正序浏览
PrepardStatement是Stataement的子接口,是Stataement功能的完善和扩充。
1、PrepardStatement更加安全,可以防止sql注入这类的问题的发生,
2、PrepardStatement的使用时我们写sql语句更加方便,sql语句中字段可以用?占位来表示。
例如下面这行代码:
  1. perstmt = con.prepareStatement("insert into tb_name (col1,col2,col2,col4) values (?,?,?,?)");
复制代码
回复 使用道具 举报
Stataement 速度比PrepardStatement慢PreparedStatement 是预编译,对SQL进行优化以后操作,而且批量的插入速度原高于Statement.Statement 的创建的速度很慢,要对SQL语句优化,因此效率低。常用选择PreparedStatement.
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马