JDBC之PreparedStatement

一、java.sql.PreparedStatement接口简介

  该接口表示预编译的 SQL 语句的对象。

  SQL 语句被预编译并存储在 PreparedStatement 对象中。然后可以使用此对象多次高效地执行该语句。

  

  可以通过调用 Connection 对象的 preparedStatement() 方法获取 PreparedStatement 对象

  PreparedStatement 接口是 Statement 的子接口,它表示一条预编译过的 SQL 语句

  PreparedStatement 对象所代表的 SQL 语句中的参数用问号(?)来表示,调用 PreparedStatement 对象的 setXXX() 方法来设置这些参数. setXXX() 方法有两个参数,第一个参数是要设置的 SQL 语句中的参数的索引(从 1 开始),第二个是设置的 SQL 语句中的参数的值

二、PreapredStatement接口方法介绍

 void addBatch()
          将一组参数添加到此 PreparedStatement 对象的批处理命令中。
 void clearParameters()

          立即清除当前参数值。
 boolean execute()

          在此 PreparedStatement 对象中执行 SQL 语句,该语句可以是任何种类的 SQL
语句。
 ResultSet executeQuery()

          在此 PreparedStatement 对象中执行 SQL 查询,并返回该查询生成的
ResultSet 对象。
 int executeUpdate()

          在此 PreparedStatement 对象中执行 SQL 语句,该语句必须是一个 SQL
数据操作语言(Data Manipulation Language,DML)语句,比如
INSERTUPDATEDELETE 语句;或者是无返回内容的 SQL
语句,比如 DDL 语句。
 ResultSetMetaData getMetaData()

          获取包含有关 ResultSet 对象列信息的
ResultSetMetaData 对象,ResultSet 对象将在执行此
PreparedStatement 对象时返回。
 ParameterMetaData getParameterMetaData()

          获取此 PreparedStatement 对象的参数的编号、类型和属性。
 void setArray(int parameterIndex,
Array x)


          将指定参数设置为给定 java.sql.Array 对象。
 void setAsciiStream(int parameterIndex,
InputStream x)


          将指定参数设置为给定输入流。
 void setAsciiStream(int parameterIndex,
InputStream x,
int length)

          将指定参数设置为给定输入流,该输入流将具有给定字节数。
 void setAsciiStream(int parameterIndex,
InputStream x,
long length)

          将指定参数设置为给定输入流,该输入流将具有指定字节数。
 void setBigDecimal(int parameterIndex,
BigDecimal x)


          将指定参数设置为给定 java.math.BigDecimal 值。
 void setBinaryStream(int parameterIndex,
InputStream x)


          将指定参数设置为给定输入流。
 void setBinaryStream(int parameterIndex,
InputStream x,
int length)

          将指定参数设置为给定输入流,该输入流将具有给定字节数。
 void setBinaryStream(int parameterIndex,
InputStream x,
long length)

          将指定参数设置为给定输入流,该输入流将具有指定字节数。
 void setBlob(int parameterIndex,
Blob x)


          将指定参数设置为给定 java.sql.Blob 对象。
 void setBlob(int parameterIndex,
InputStream inputStream)


          将指定参数设置为 InputStream 对象。
 void setBlob(int parameterIndex,
InputStream inputStream,
long length)

          将指定参数设置为 InputStream
对象。
 void setBoolean(int parameterIndex,
boolean x)

          将指定参数设置为给定 Java boolean
值。
 void setByte(int parameterIndex,
byte x)

          将指定参数设置为给定 Java byte 值。
 void setBytes(int parameterIndex,
byte[] x)

          将指定参数设置为给定 Java byte 数组。
 void setCharacterStream(int parameterIndex,
Reader reader)


          将指定参数设置为给定 Reader 对象。
 void setCharacterStream(int parameterIndex,
Reader reader,
int length)

          将给定参数设置为给定 Reader
对象,该对象具有给定字符数长度。
 void setCharacterStream(int parameterIndex,
Reader reader,
long length)

          将指定参数设置为给定 Reader
对象,该对象具有给定字符数长度。
 void setClob(int parameterIndex,
Clob x)


          将指定参数设置为给定 java.sql.Clob 对象。
 void setClob(int parameterIndex,
Reader reader)


          将指定参数设置为 Reader 对象。
 void setClob(int parameterIndex,
Reader reader,
long length)

          将指定参数设置为 Reader 对象。
 void setDate(int parameterIndex,
Date x)


          使用运行应用程序的虚拟机的默认时区将指定参数设置为给定 java.sql.Date
值。
 void setDate(int parameterIndex,
Date x, Calendar cal)


          使用给定的 Calendar 对象将指定参数设置为给定
java.sql.Date 值。
 void setDouble(int parameterIndex,
double x)

          将指定参数设置为给定 Java double 值。
 void setFloat(int parameterIndex,
float x)

          将指定参数设置为给定 Java REAL 值。
 void setInt(int parameterIndex,
int x)

          将指定参数设置为给定 Java int 值。
 void setLong(int parameterIndex,
long x)

          将指定参数设置为给定 Java long 值。
 void setNCharacterStream(int parameterIndex,
Reader value)


          将指定参数设置为 Reader 对象。
 void setNCharacterStream(int parameterIndex,
Reader value,
long length)

          将指定参数设置为 Reader 对象。
 void setNClob(int parameterIndex,
NClob value)

          将指定参数设置为
java.sql.NClob 对象。
 void setNClob(int parameterIndex,
Reader reader)


          将指定参数设置为 Reader 对象。
 void setNClob(int parameterIndex,
Reader reader,
long length)

          将指定参数设置为 Reader 对象。
 void setNString(int parameterIndex,
String value)


          将指定参数设置为给定 String 对象。
 void setNull(int parameterIndex,
int sqlType)

          将指定参数设置为 SQL NULL
 void setNull(int parameterIndex,
int sqlType, String typeName)


          将指定参数设置为 SQL NULL
 void setObject(int parameterIndex,
Object x)


          使用给定对象设置指定参数的值。
 void setObject(int parameterIndex,
Object x,
int targetSqlType)

          使用给定对象设置指定参数的值。
 void setObject(int parameterIndex,
Object x,
int targetSqlType, int scaleOrLength)


          使用给定对象设置指定参数的值。
 void setRef(int parameterIndex,
Ref x)


          将指定参数设置为给定 REF(<structured-type>) 值。
 void setRowId(int parameterIndex,
RowId x)


          将指定参数设置为给定 java.sql.RowId 对象。
 void setShort(int parameterIndex,
short x)

          将指定参数设置为给定 Java short 值。
 void setSQLXML(int parameterIndex,
SQLXML xmlObject)


          将指定参数设置为给定 java.sql.SQLXML 对象。
 void setString(int parameterIndex,
String x)


          将指定参数设置为给定 Java String 值。
 void setTime(int parameterIndex,
Time x)


          将指定参数设置为给定 java.sql.Time 值。
 void setTime(int parameterIndex,
Time x, Calendar cal)


          使用给定的 Calendar 对象将指定参数设置为给定
java.sql.Time 值。
 void setTimestamp(int parameterIndex,
Timestamp x)


          将指定参数设置为给定 java.sql.Timestamp 值。
 void setTimestamp(int parameterIndex,
Timestamp x, Calendar cal)


          使用给定的 Calendar 对象将指定参数设置为给定
java.sql.Timestamp 值。
 void setUnicodeStream(int parameterIndex,
InputStream x,
int length)

          已过时。  
 void setURL(int parameterIndex,
URL x)


          将指定参数设置为给定 java.net.URL 值。

三、PreparedStatement vs Statement

  相比于Statement,PreparedStatement的代码的可读性和可维护性较好.

  PreparedStatement 能最大可能提高性能:

  ①DBServer会对预编译语句提供性能优化。因为预编译语句有可能被重复调用,所以语句在被DBServer的编译器编译后的执行代码被缓存下来,那么下次调用时只要是相同的预编译语句就不需要编译,只要将参数直接传入编译过的语句执行代码中就会得到执行。
  ②在statement语句中,即使是相同操作但因为数据内容不一样,所以整个语句本身不能匹配,没有缓存语句的意义.事实是没有数据库会对
普通语句编译后的执行代码缓存.这样每执行一次都要对传入的语句编译一次.
  ③(语法检查,语义检查,翻译成二进制命令,缓存)

  PreparedStatement 可以防止 SQL 注入,SQL注入是利用某些系统没有对用户输入的数据进行充分的检查,而在用户输入数据中注入非法的 SQL 语句段或命令,从而利用系统的 SQL 引擎完成恶意行为的做法对于 Java 而言,要防范 SQL 注入,只要用PreparedStatement 取代 Statement 就可以了

如果,您对我的这篇博文有什么疑问,欢迎评论区留言,大家互相讨论学习。
如果,您认为阅读这篇博客让您有些收获,不妨点击一下右下角的【推荐】。
如果,您希望更容易地发现我的新博客,不妨点击一下左下角的【关注我】。
如果,您对我的博文感兴趣,可以关注我的后续博客,我是【AlbertRui】。

转载请注明出处和链接地址,欢迎转载,谢谢!

JDBC之PreparedStatement的更多相关文章

  1. java中使用JDBC的preparedStatement批处理数据的添加

    在项目中我们偶尔可能会遇到批量向数据库中导入数据,如果批处理的情况较多的情况下可以使用spring batch,如果只是一个导入功能的话可以考虑使用jdbc的preparedStatement处理. ...

  2. JDBC连接数据库(PreparedStatement)

    PreparedStatement是在数据库端防止SQL注入漏洞的SQL方法这里演示了一些基本使用方法同样使用Oracle数据库,之前已经手动建立了一张t_account表数据库代码参见上一篇< ...

  3. 转自“脚本之家”!!JDBC之PreparedStatement类中预编译的综合应用解析

    JDK 文档:SQL 语句被预编译并存储在 PreparedStatement 对象中(PreparedStatement是存储在JDBC里的,初始化后,缓存到了JDBC里),然后可以使用此对象多次高 ...

  4. JDBC - Oracle PreparedStatement (GeneratedKey kind) ArrayIndexOutOfBoundsException

    问题: Exception in thread "main" java.lang.ArrayIndexOutOfBoundsException: 12at oracle.jdbc. ...

  5. Java学习笔记——JDBC之PreparedStatement类中“预编译”的综合应用

    预编译 SQL 语句被预编译并存储在 PreparedStatement 对象中.然后可以使用此对象多次高效地执行该语句. 预编译的优点 1.PreparedStatement是预编译的,对于批量处理 ...

  6. JDBC 中preparedStatement和Statement区别

    一.概念 PreparedStatement是用来执行SQL查询语句的API之一,Java提供了 Statement.PreparedStatement 和 CallableStatement三种方式 ...

  7. [疯狂Java]JDBC:PreparedStatement预编译执行SQL语句

    1. SQL语句的执行过程——Statement直接执行的弊病: 1) SQL语句和编程语言一样,仅仅就会普通的文本字符串,首先数据库引擎无法识别这种文本字符串,而底层的CPU更不理解这些文本字符串( ...

  8. 回头探索JDBC及PreparedStatement防SQL注入原理

    概述 JDBC在我们学习J2EE的时候已经接触到了,但是仅是照搬步骤书写,其中的PreparedStatement防sql注入原理也是一知半解,然后就想回头查资料及敲测试代码探索一下.再有就是我们在项 ...

  9. JDBC Statements, PreparedStatement和CallableStatement语句

    当获得了与数据库的连接后,就可以与数据库进行交互了. JDBC Statement,CallableStatement和PreparedStatement接口定义了可用于发送SQL或PL/SQL命令, ...

随机推荐

  1. MyEclipse2014破解版

    百度云:链接:http://pan.baidu.com/s/1c3jKMa 密码:yss0 等版本)后,不要打开软件. 二.解压破解文件压缩包,得到一下文件列表: 三.双击run.bat,即可运行cr ...

  2. C++ 八数码问题宽搜

    C++ 八数码问题宽搜 题目描述 样例输入 (none) 样例输出 H--F--A AC代码 #include <iostream> #include <stdio.h> #i ...

  3. 【pip】brew install pip 问题

    Mac 下用 brew install pip 命令安装 pip 时报错: Error: No available formula with the name "pip" Home ...

  4. 关于python中的特殊方法

    研究了几个小时,大概对python中的特殊方法一知半解,现在写写自己的理解,以及记录一些找到的资源.待自己有比较深入理解的时候,再来更新 https://docs.python.org/3/refer ...

  5. java并发笔记之四synchronized 锁的膨胀过程(锁的升级过程)深入剖析

    警告⚠️:本文耗时很长,先做好心理准备,建议PC端浏览器浏览效果更佳. 本篇我们讲通过大量实例代码及hotspot源码分析偏向锁(批量重偏向.批量撤销).轻量级锁.重量级锁及锁的膨胀过程(也就是锁的升 ...

  6. 第十章 Centos7-系统进程管理 随堂笔记

    第十章 Centos7-系统进程管理 本节所讲内容: 10.1 进程概述和ps查看进程工具 10.2 uptime查看系统负载-top动态管理进程 10.3 前后台进程切换- nice进程优先级-实战 ...

  7. 内存泄漏排查之:Show me your Memory

    java 语言有个神奇的地方,那就是你时不时会去关注下内存.(当然了,任何牛逼的同学都应该关注内存) 今天我们就来这么场景吧:某应用运行了一段时间后,ecs监控报警了,内存比较高了,怎么办?随着时间的 ...

  8. 算法与数据结构基础 - 滑动窗口(Sliding Window)

    滑动窗口基础 滑动窗口常用来解决求字符串子串问题,借助map和计数器,其能在O(n)时间复杂度求子串问题.滑动窗口和双指针(Two pointers)有些类似,可以理解为往同一个方向走的双指针.常用滑 ...

  9. 【0812 | Day 13】闭包函数/装饰器/迭代器

    目录 闭包函数 无参装饰器 有参装饰器 迭代器 闭包函数 一.什么是闭包? 闭包指的是:函数内部函数对外部作用域而非全局作用域的引用. def outter(): x = 1 def inner(): ...

  10. Spring Boot 支持 Https 有那么难吗?

    https 现在已经越来越普及了,特别是做一些小程序或者公众号开发的时候,https 基本上都是刚需了. 不过一个 https 证书还是挺费钱的,个人开发者可以在各个云服务提供商那里申请一个免费的证书 ...