I have a question related to this method: st.execute(sql);
where st obviously is a Statement object.
Directly from this oracle java tutorial:
execute: Returns true if the first object that the query returns is a ResultSet object. Use this method if the query could return one or more ResultSet objects. Retrieve the ResultSet objects returned from the query by repeatedly calling Statement.getResutSet.
What is meant by "one or more ResultSet objects"? How is it possible to manage them once got an array of ResultSet
?
Whereas st.executeQuery(sql)
and st.executeUpdate(sql)
are very clear. It's not (at least to me) the aim of st.execute(sql)
which can also return an int as if it was updated a table.
Thanks in advance
boolean execute(): Executes the SQL statement in this Prepared Statement object, which may be any kind of SQL statement.
ResultSet executeQuery(): Executes the SQL query in this Prepared Statement object and returns the ResultSet object generated by the query.
int executeUpdate(): Executes the SQL statement in this Prepared Statement object, which must be an SQL INSERT, UPDATE or DELETE statement; or an SQL statement that returns nothing, such as a DDL statement.
The best place to find answers to questions like this is the Javadocs: Here
The javadoc for the
execute
method says this:That pretty much explains it. Sometimes a query can deliver more than one
ResultSet
.I'm not sure what you mean but:
One use of
execute
is to execute an SQL statement if you don't know if it is a query, an update (of some kind) ... or something else that potentially delivers multiple result sets. It is a generalization ofexecuteQuery()
andexecuteUpdate()
...