Difference between Statement and PreparedStatement

前端 未结 15 1105
野的像风
野的像风 2020-11-22 02:49

The Prepared Statement is a slightly more powerful version of a Statement, and should always be at least as quick and easy to handle as a Statement.
The Prepared Stateme

相关标签:
15条回答
  • 2020-11-22 03:05
    • It's easier to read
    • You can easily make the query string a constant
    0 讨论(0)
  • 2020-11-22 03:06

    Another characteristic of Prepared or Parameterized Query: Reference taken from this article.

    This statement is one of features of the database system in which same SQL statement executes repeatedly with high efficiency. The prepared statements are one kind of the Template and used by application with different parameters.

    The statement template is prepared and sent to the database system and database system perform parsing, compiling and optimization on this template and store without executing it.

    Some of parameter like, where clause is not passed during template creation later application, send these parameters to the database system and database system use template of SQL Statement and executes as per request.

    Prepared statements are very useful against SQL Injection because the application can prepare parameter using different techniques and protocols.

    When the number of data is increasing and indexes are changing frequently at that time Prepared Statements might be fail because in this situation require a new query plan.

    0 讨论(0)
  • 2020-11-22 03:08
    1. They are pre-compiled (once), so faster for repeated execution of dynamic SQL (where parameters change)

    2. Database statement caching boosts DB execution performance

      Databases store caches of execution plans for previously executed statements. This allows the database engine to reuse the plans for statements that have been executed previously. Because PreparedStatement uses parameters, each time it is executed it appears as the same SQL, the database can reuse the previous access plan, reducing processing. Statements "inline" the parameters into the SQL string and so do not appear as the same SQL to the DB, preventing cache usage.

    3. Binary communications protocol means less bandwidth and faster comms calls to DB server

      Prepared statements are normally executed through a non-SQL binary protocol. This means that there is less data in the packets, so communications to the server is faster. As a rule of thumb network operations are an order of magnitude slower than disk operations which are an order of magnitude slower than in-memory CPU operations. Hence, any reduction in amount of data sent over the network will have a good effect on overall performance.

    4. They protect against SQL injection, by escaping text for all the parameter values provided.

    5. They provide stronger separation between the query code and the parameter values (compared to concatenated SQL strings), boosting readability and helping code maintainers quickly understand inputs and outputs of the query.

    6. In java, can call getMetadata() and getParameterMetadata() to reflect on the result set fields and the parameter fields, respectively

    7. In java, intelligently accepts java objects as parameter types via setObject, setBoolean, setByte, setDate, setDouble, setDouble, setFloat, setInt, setLong, setShort, setTime, setTimestamp - it converts into JDBC type format that is comprehendible to DB (not just toString() format).

    8. In java, accepts SQL ARRAYs, as parameter type via setArray method

    9. In java, accepts CLOBs, BLOBs, OutputStreams and Readers as parameter "feeds" via setClob/setNClob, setBlob, setBinaryStream, setCharacterStream/setAsciiStream/setNCharacterStream methods, respectively

    10. In java, allows DB-specific values to be set for SQL DATALINK, SQL ROWID, SQL XML, and NULL via setURL, setRowId, setSQLXML ans setNull methods

    11. In java, inherits all methods from Statement. It inherits the addBatch method, and additionally allows a set of parameter values to be added to match the set of batched SQL commands via addBatch method.

    12. In java, a special type of PreparedStatement (the subclass CallableStatement) allows stored procedures to be executed - supporting high performance, encapsulation, procedural programming and SQL, DB administration/maintenance/tweaking of logic, and use of proprietary DB logic & features

    0 讨论(0)
  • 2020-11-22 03:11

    Statement interface executes static SQL statements without parameters

    PreparedStatement interface (extending Statement) executes a precompiled SQL statement with/without parameters

    1. Efficient for repeated executions

    2. It is precompiled so it's faster

    0 讨论(0)
  • 2020-11-22 03:12

    Some of the benefits of PreparedStatement over Statement are:

    1. PreparedStatement helps us in preventing SQL injection attacks because it automatically escapes the special characters.
    2. PreparedStatement allows us to execute dynamic queries with parameter inputs.
    3. PreparedStatement provides different types of setter methods to set the input parameters for the query.
    4. PreparedStatement is faster than Statement. It becomes more visible when we reuse the PreparedStatement or use it’s batch processing methods for executing multiple queries.
    5. PreparedStatement helps us in writing object Oriented code with setter methods whereas with Statement we have to use String Concatenation to create the query. If there are multiple parameters to set, writing Query using String concatenation looks very ugly and error prone.

    Read more about SQL injection issue at http://www.journaldev.com/2489/jdbc-statement-vs-preparedstatement-sql-injection-example

    0 讨论(0)
  • 2020-11-22 03:14

    Dont get confusion : simply remember

    1. Statement is used for static queries like DDLs i.e. create,drop,alter and prepareStatement is used for dynamic queries i.e. DML query.
    2. In Statement, the query is not precompiled while in prepareStatement query is precompiled, because of this prepareStatement is time efficient.
    3. prepareStatement takes argument at the time of creation while Statement does not take arguments. For Example if you want to create table and insert element then :: Create table (static) by using Statement and Insert element (dynamic)by using prepareStatement.
    0 讨论(0)
提交回复
热议问题