PreparedStatement接口

 功能:

  1. 预编译Statement,也是用于执行sql语句的工具接口

 

说明:

  1. 本文为了代码结构清晰 采用的是try-with-resource结构,请在java7下使用(或者自己改成传统模式)
  2. 具体使用请看例子,更多内容请看例子后的扩展阅读
  3. 阅读本文前建议先阅读Statement接口相关文章

 

程序演示: 放大

  1. package com.cxy.jdbc;  
  2.   
  3. import java.sql.Connection;  
  4. import java.sql.DriverManager;  
  5. import java.sql.PreparedStatement;  
  6. import java.sql.ResultSet;  
  7. import java.sql.ResultSetMetaData;  
  8. import java.sql.SQLException;  
  9.   
  10. /** 
  11.  * @author cxy @ www.cxyapi.com 
  12.  */  
  13. public class PreparedStatementTest  
  14. {  
  15.     public static void main(String[] args)  
  16.     {  
  17.         try(  
  18.                 Connection con=DriverManager.getConnection("jdbc:mysql://localhost/dbtest""root""root");  
  19.                 PreparedStatement pstmt=con.prepareStatement("insert into t_student values (?,?,?)");  
  20.            )  
  21.            {  
  22.                 //executeUpdate 执行插入语句  
  23.                 pstmt.setString(1"123");  
  24.                 pstmt.setString(2"小红");  
  25.                 pstmt.setObject(3"女"); //如果不知道占位符是什么类型的数据就用setObject,jdbc会自动为您转成合适的类型  
  26.                 pstmt.executeUpdate();  
  27.                 System.out.println("=======================");  
  28.                   
  29.                 //clearParameters:清理当前的参数,如果直接执行会带来异常:No value specified for parameter 1  
  30.                 //pstmt.clearParameters();  
  31.                 //pstmt.executeUpdate();   
  32.                   
  33.                 //executeQuery执行查询语句,返回结果集  
  34.                 PreparedStatement pstmt1=con.prepareStatement("select * from t_student");  
  35.                 printResultSet(pstmt1.executeQuery());  
  36.                 System.out.println("=======================");  
  37.                   
  38.                 //ResultSetMetaData:ResultSet对象的相关信息  
  39.                 ResultSetMetaData rsmd = pstmt1.getMetaData();  
  40.                 System.out.println("结果集字段的个数:"+rsmd.getColumnCount());  
  41.                 System.out.println("表名:"+rsmd.getTableName(1)); //获得指定参数所在表的表名  
  42.                 //更多的方法请看ResultSetMetaData相关文章  
  43.            }catch(Exception e)  
  44.            {e.printStackTrace();  
  45.                System.out.println("数据库操作出现异常");  
  46.            }  
  47.     }  
  48.       
  49.     public  static void printResultSet(ResultSet rs2)  
  50.     {  
  51.         try  
  52.         {  
  53.             while(rs2.next())  
  54.             {  
  55.                 System.out.println(rs2.getString(1)+"\t"+rs2.getString(2)+"\t"+rs2.getString(3));  
  56.             }  
  57.         } catch (SQLException e)  
  58.         {  
  59.             e.printStackTrace();  
  60.         }  
  61.     }  
  62.   
  63. }  

你可能感兴趣的:(PreparedStatement接口)