(1)Statement用于执行静态sql语句,在执行时,必须指定一个事先准备好的sql语句。
PrepareStatement是预编译的sql语句对象,sql语句被预编译并保存在对象中。被封装的sql语句代表某一类操作,语句中可以包含动态参数“?”,在执行时可以为“?”动态设置参数值。
使用PrepareStatement对象执行sql时,sql被数据库进行解析和编译,然后被放到命令缓冲区,每当执行同一个PrepareStatement对象时,它就会被解析一次,但不会被再次编译。在缓冲区可以发现预编译的命令,并且可以重用。
PrepareStatement可以减少编译次数提高数据库性能。
(2)PrepareStatement可以防止sql注入
(3)还有callablestatement,用来处理存储过程
相关文章
- localhost和127.0.0.1有什么区别?
- 牛客网Java刷题知识点之什么是cookie、什么是session、cookie和session有什么区别
- “/“和 “\“以及“//“和“\\“有什么区别?
- 80端口与8080端口是两种不同的端口吗?他们到底有什么区别和联系?
- wap页面和html5,WAP网站、3G网站、html5触屏版有什么区别?
- Application.CreateForm()和TForm.Create()创建的窗体有什么区别么?二者在使用上各有什么技巧?(50分)
- java 栈的isEmpty和empty有什么区别
- Transformer模型和RNN模型有什么区别
- linux 775和777权限有什么区别
- ${}和#{}有什么区别?