<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="ru">
		<id>http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_by_API%2Fjava.sql%2FParameterMetaData</id>
		<title>Java by API/java.sql/ParameterMetaData - История изменений</title>
		<link rel="self" type="application/atom+xml" href="http://www.jexp.ru/index.php?action=history&amp;feed=atom&amp;title=Java_by_API%2Fjava.sql%2FParameterMetaData"/>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_by_API/java.sql/ParameterMetaData&amp;action=history"/>
		<updated>2026-04-22T09:50:35Z</updated>
		<subtitle>История изменений этой страницы в вики</subtitle>
		<generator>MediaWiki 1.30.0</generator>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java_by_API/java.sql/ParameterMetaData&amp;diff=2458&amp;oldid=prev</id>
		<title> в 17:43, 31 мая 2010</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_by_API/java.sql/ParameterMetaData&amp;diff=2458&amp;oldid=prev"/>
				<updated>2010-05-31T17:43:48Z</updated>
		
		<summary type="html">&lt;p&gt;&lt;/p&gt;
&lt;table class=&quot;diff diff-contentalign-left&quot; data-mw=&quot;interface&quot;&gt;
				&lt;tr style=&quot;vertical-align: top;&quot; lang=&quot;ru&quot;&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;← Предыдущая&lt;/td&gt;
				&lt;td colspan=&quot;1&quot; style=&quot;background-color: white; color:black; text-align: center;&quot;&gt;Версия 17:43, 31 мая 2010&lt;/td&gt;
				&lt;/tr&gt;&lt;tr&gt;&lt;td colspan=&quot;2&quot; style=&quot;text-align: center;&quot; lang=&quot;ru&quot;&gt;&lt;div class=&quot;mw-diff-empty&quot;&gt;(нет различий)&lt;/div&gt;
&lt;/td&gt;&lt;/tr&gt;&lt;/table&gt;</summary>
			</entry>

	<entry>
		<id>http://www.jexp.ru/index.php?title=Java_by_API/java.sql/ParameterMetaData&amp;diff=2459&amp;oldid=prev</id>
		<title>Admin: 1 версия</title>
		<link rel="alternate" type="text/html" href="http://www.jexp.ru/index.php?title=Java_by_API/java.sql/ParameterMetaData&amp;diff=2459&amp;oldid=prev"/>
				<updated>2010-05-31T14:46:45Z</updated>
		
		<summary type="html">&lt;p&gt;1 версия&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Новая страница&lt;/b&gt;&lt;/p&gt;&lt;div&gt;== ParameterMetaData: getParameterClassName(int param) ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = null;&lt;br /&gt;
    ParameterMetaData paramMetaData = null;&lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    pstmt = conn.prepareStatement(query);&lt;br /&gt;
    paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        String paramClassName = paramMetaData.getParameterClassName(param);&lt;br /&gt;
        System.out.println(&amp;quot;param class name=&amp;quot; + paramClassName);&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData: getParameterCount() ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    PreparedStatement pstmt = conn.prepareStatement(query);&lt;br /&gt;
    ParameterMetaData paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        String paramTypeName = paramMetaData.getParameterTypeName(param);&lt;br /&gt;
        System.out.println(&amp;quot;param SQL type name=&amp;quot; + paramTypeName);&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData: getParameterMode(int param) ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = null;&lt;br /&gt;
    ParameterMetaData paramMetaData = null;&lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    pstmt = conn.prepareStatement(query);&lt;br /&gt;
    paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        int paramMode = paramMetaData.getParameterMode(param);&lt;br /&gt;
        System.out.println(&amp;quot;param mode=&amp;quot; + paramMode);&lt;br /&gt;
        if (paramMode == ParameterMetaData.parameterModeOut) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is OUT.&amp;quot;);&lt;br /&gt;
        } else if (paramMode == ParameterMetaData.parameterModeIn) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is IN.&amp;quot;);&lt;br /&gt;
        } else if (paramMode == ParameterMetaData.parameterModeInOut) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is INOUT.&amp;quot;);&lt;br /&gt;
        } else {&lt;br /&gt;
          System.out.println(&amp;quot;the mode of a parameter is unknown.&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData: getParameterType(int param) ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
import java.sql.CallableStatement;&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getMySqlConnection();&lt;br /&gt;
    String simpleProc = &amp;quot;{ call simpleproc(?) }&amp;quot;;&lt;br /&gt;
    CallableStatement cs = conn.prepareCall(simpleProc);&lt;br /&gt;
    cs.registerOutParameter(1, java.sql.Types.INTEGER);&lt;br /&gt;
    cs.execute();&lt;br /&gt;
    int param1 = cs.getInt(1);&lt;br /&gt;
    System.out.println(&amp;quot;param1=&amp;quot; + param1);&lt;br /&gt;
    ParameterMetaData pmeta = cs.getParameterMetaData();&lt;br /&gt;
    if (pmeta == null) {&lt;br /&gt;
      System.out.println(&amp;quot;Vendor does not support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(pmeta.getParameterType(1));&lt;br /&gt;
    }&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
     &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData: getParameterTypeName(int param) ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
&lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    PreparedStatement pstmt = conn.prepareStatement(query);&lt;br /&gt;
    ParameterMetaData paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        String paramTypeName = paramMetaData.getParameterTypeName(param);&lt;br /&gt;
        System.out.println(&amp;quot;param SQL type name=&amp;quot; + paramTypeName);&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData: isNullable(int param) ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = null;&lt;br /&gt;
    ParameterMetaData paramMetaData = null;&lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    pstmt = conn.prepareStatement(query);&lt;br /&gt;
    paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        int nullable = paramMetaData.isNullable(param);&lt;br /&gt;
        if (nullable == ParameterMetaData.parameterNoNulls) {&lt;br /&gt;
          System.out.println(&amp;quot;parameter will not allow NULL values.&amp;quot;);&lt;br /&gt;
        } else if (nullable == ParameterMetaData.parameterNullable) {&lt;br /&gt;
          System.out.println(&amp;quot;parameter will allow NULL values.&amp;quot;);&lt;br /&gt;
        } else {&lt;br /&gt;
          System.out.println(&amp;quot;nullability of a parameter is unknown.&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData.parameterModeIn ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = null;&lt;br /&gt;
    ParameterMetaData paramMetaData = null;&lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    pstmt = conn.prepareStatement(query);&lt;br /&gt;
    paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        int paramMode = paramMetaData.getParameterMode(param);&lt;br /&gt;
        System.out.println(&amp;quot;param mode=&amp;quot; + paramMode);&lt;br /&gt;
        if (paramMode == ParameterMetaData.parameterModeOut) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is OUT.&amp;quot;);&lt;br /&gt;
        } else if (paramMode == ParameterMetaData.parameterModeIn) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is IN.&amp;quot;);&lt;br /&gt;
        } else if (paramMode == ParameterMetaData.parameterModeInOut) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is INOUT.&amp;quot;);&lt;br /&gt;
        } else {&lt;br /&gt;
          System.out.println(&amp;quot;the mode of a parameter is unknown.&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData.parameterModeInOut ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = null;&lt;br /&gt;
    ParameterMetaData paramMetaData = null;&lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    pstmt = conn.prepareStatement(query);&lt;br /&gt;
    paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        int paramMode = paramMetaData.getParameterMode(param);&lt;br /&gt;
        System.out.println(&amp;quot;param mode=&amp;quot; + paramMode);&lt;br /&gt;
        if (paramMode == ParameterMetaData.parameterModeOut) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is OUT.&amp;quot;);&lt;br /&gt;
        } else if (paramMode == ParameterMetaData.parameterModeIn) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is IN.&amp;quot;);&lt;br /&gt;
        } else if (paramMode == ParameterMetaData.parameterModeInOut) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is INOUT.&amp;quot;);&lt;br /&gt;
        } else {&lt;br /&gt;
          System.out.println(&amp;quot;the mode of a parameter is unknown.&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData.parameterModeOut ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = null;&lt;br /&gt;
    ParameterMetaData paramMetaData = null;&lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    pstmt = conn.prepareStatement(query);&lt;br /&gt;
    paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        int paramMode = paramMetaData.getParameterMode(param);&lt;br /&gt;
        System.out.println(&amp;quot;param mode=&amp;quot; + paramMode);&lt;br /&gt;
        if (paramMode == ParameterMetaData.parameterModeOut) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is OUT.&amp;quot;);&lt;br /&gt;
        } else if (paramMode == ParameterMetaData.parameterModeIn) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is IN.&amp;quot;);&lt;br /&gt;
        } else if (paramMode == ParameterMetaData.parameterModeInOut) {&lt;br /&gt;
          System.out.println(&amp;quot;the parameter&amp;quot;s mode is INOUT.&amp;quot;);&lt;br /&gt;
        } else {&lt;br /&gt;
          System.out.println(&amp;quot;the mode of a parameter is unknown.&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
== ParameterMetaData.parameterNoNulls ==&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- start source code --&amp;gt;&lt;br /&gt;
   &lt;br /&gt;
    &amp;lt;source lang=&amp;quot;java&amp;quot;&amp;gt;&lt;br /&gt;
 &lt;br /&gt;
import java.sql.Connection;&lt;br /&gt;
import java.sql.DriverManager;&lt;br /&gt;
import java.sql.ParameterMetaData;&lt;br /&gt;
import java.sql.PreparedStatement;&lt;br /&gt;
import java.sql.Statement;&lt;br /&gt;
public class Main {&lt;br /&gt;
  public static void main(String[] args) throws Exception {&lt;br /&gt;
    Connection conn = getHSQLConnection();&lt;br /&gt;
    System.out.println(&amp;quot;Got Connection.&amp;quot;);&lt;br /&gt;
    Statement st = conn.createStatement();&lt;br /&gt;
    st.executeUpdate(&amp;quot;create table survey (id int,name varchar);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;create view surveyView as (select * from survey);&amp;quot;);&lt;br /&gt;
    st.executeUpdate(&amp;quot;insert into survey (id,name ) values (1,&amp;quot;nameValue&amp;quot;)&amp;quot;);&lt;br /&gt;
    &lt;br /&gt;
    PreparedStatement pstmt = null;&lt;br /&gt;
    ParameterMetaData paramMetaData = null;&lt;br /&gt;
    String query = &amp;quot;select * from survey where id &amp;gt; ? and name = ?&amp;quot;;&lt;br /&gt;
    pstmt = conn.prepareStatement(query);&lt;br /&gt;
    paramMetaData = pstmt.getParameterMetaData();&lt;br /&gt;
    if (paramMetaData == null) {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor does NOT support ParameterMetaData&amp;quot;);&lt;br /&gt;
    } else {&lt;br /&gt;
      System.out.println(&amp;quot;db vendor supports ParameterMetaData&amp;quot;);&lt;br /&gt;
      // find out the number of dynamic parameters&lt;br /&gt;
      int paramCount = paramMetaData.getParameterCount();&lt;br /&gt;
      System.out.println(&amp;quot;paramCount=&amp;quot; + paramCount);&lt;br /&gt;
      System.out.println(&amp;quot;-------------------&amp;quot;);&lt;br /&gt;
      for (int param = 1; param &amp;lt;= paramCount; param++) {&lt;br /&gt;
        System.out.println(&amp;quot;param number=&amp;quot; + param);&lt;br /&gt;
        int nullable = paramMetaData.isNullable(param);&lt;br /&gt;
        if (nullable == ParameterMetaData.parameterNoNulls) {&lt;br /&gt;
          System.out.println(&amp;quot;parameter will not allow NULL values.&amp;quot;);&lt;br /&gt;
        } else if (nullable == ParameterMetaData.parameterNullable) {&lt;br /&gt;
          System.out.println(&amp;quot;parameter will allow NULL values.&amp;quot;);&lt;br /&gt;
        } else {&lt;br /&gt;
          System.out.println(&amp;quot;nullability of a parameter is unknown.&amp;quot;);&lt;br /&gt;
        }&lt;br /&gt;
      }&lt;br /&gt;
    }&lt;br /&gt;
    pstmt.close();&lt;br /&gt;
    conn.close();&lt;br /&gt;
  }&lt;br /&gt;
  private static Connection getHSQLConnection() throws Exception {&lt;br /&gt;
    Class.forName(&amp;quot;org.hsqldb.jdbcDriver&amp;quot;);&lt;br /&gt;
    System.out.println(&amp;quot;Driver Loaded.&amp;quot;);&lt;br /&gt;
    String url = &amp;quot;jdbc:hsqldb:data/tutorial&amp;quot;;&lt;br /&gt;
    return DriverManager.getConnection(url, &amp;quot;sa&amp;quot;, &amp;quot;&amp;quot;);&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getMySqlConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;org.gjt.mm.mysql.Driver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:mysql://localhost/demo2s&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;oost&amp;quot;;&lt;br /&gt;
    Class.forName(driver);&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
  public static Connection getOracleConnection() throws Exception {&lt;br /&gt;
    String driver = &amp;quot;oracle.jdbc.driver.OracleDriver&amp;quot;;&lt;br /&gt;
    String url = &amp;quot;jdbc:oracle:thin:@localhost:1521:caspian&amp;quot;;&lt;br /&gt;
    String username = &amp;quot;mp&amp;quot;;&lt;br /&gt;
    String password = &amp;quot;mp2&amp;quot;;&lt;br /&gt;
    Class.forName(driver); // load Oracle driver&lt;br /&gt;
    Connection conn = DriverManager.getConnection(url, username, password);&lt;br /&gt;
    return conn;&lt;br /&gt;
  }&lt;br /&gt;
}&lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;/source&amp;gt;&lt;br /&gt;
    &lt;br /&gt;
   &lt;br /&gt;
  &amp;lt;!-- end source code --&amp;gt;&lt;/div&gt;</summary>
		<author><name>Admin</name></author>	</entry>

	</feed>