氟塑料离心泵www.buybeng.com

jquery教程http://www.software8.co/wzjs/jquery/

JAVA基础 之 PreparedStatement

概述:

    1.本文为了代码结构清晰 采用的是try-with-resource结构,请在java7下使用(或者自己改成普通模式)

    2.预编译的sql语句存储在PreparedStatement对象中,所以PreparedStatement的执行效率要高于Statement

    3.使用占位符(?)的方式,使得重复的结构重复的语句不用重复的编写

       例如:Statement下如果我想插入两条记录

           stmt.addBatch("insert into t_student values ('11','小明','男')");

           stmt.addBatch("insert into t_student values ('22','小明2','男')");

           PreparedStatement下 使用占位符,只需要录入占位符的数据即可

           con.prepareStatement("insert into t_student values (?,?,?)"); 具体见例子

    4.这样的好处:

       1.防止重复编写多个结构类似的sql语句

       2.没有拼接字符串的烦恼

       3.防止sql注入(拼接字符串 会带来sql注入问题)

       4.sql语句预编译在PreparedStatement对象中,性能好

    5.使用前建议先看看Statement相关文章,很多方法类似
原文参考自站长网:http://www.software8.co/wzjs/java/3167.html

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

posted on 2013-03-04 08:34 你爸是李刚 阅读(1788) 评论(0)  编辑  收藏


只有注册用户登录后才能发表评论。


网站导航:
 
<2013年3月>
242526272812
3456789
10111213141516
17181920212223
24252627282930
31123456

导航

统计

常用链接

留言簿

随笔档案

文章档案

技术网站

行业网站

搜索

最新评论

阅读排行榜

评论排行榜

站长网 氟塑料离心泵 注塑机 液晶广告机