亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > Java > 正文

Java使用PreparedStatement接口及ResultSet結果集的方法示例

2024-07-14 08:41:28
字體:
來源:轉載
供稿:網友

本文實例講述了Java使用PreparedStatement接口及ResultSet結果集的方法。分享給大家供大家參考,具體如下:

說明:

1.PreparedStatement接口繼承Statement,它的實例包含已編譯的SQL語句,執行速度要快于Statement。

2.PreparedStatement繼承了Statement的所有功能,三種方法executeUpdate、executeQueryexecute不再需要參數。

3.在JDBC應用中,一般都用PreparedStatement,而不是Statement。

便于操作,先做一些封裝:

對連接數據庫,關閉連接封裝,在之前博客中已經提到DbUtil.java;

對數據庫表進行封裝,這里是對我的數據庫中comp表進行操作,因此封裝如下:

package com.mysqltest.jdbc.modelComp;public class CompMember {  private int id;  private String name;  private int age;  private double salary;  /**   * 構造函數1   * @param name   * @param age   * @param salary   */  public CompMember(String name, int age, double salary) {    super();    this.name = name;    this.age = age;    this.salary = salary;  }  /**   * 重載構造函數   * @param id   * @param name   * @param age   * @param salary   */  public CompMember(int id, String name, int age, double salary) {    super();    this.id = id;    this.name = name;    this.age = age;    this.salary = salary;  }  /**   * get,set方法   */  public int getId() {    return id;  }  public void setId(int id) {    this.id = id;  }  public String getName() {    return name;  }  public void setName(String name) {    this.name = name;  }  public int getAge() {    return age;  }  public void setAge(int age) {    this.age = age;  }  public double getSalary() {    return salary;  }  public void setSalary(double salary) {    this.salary = salary;  }  @Override  /**   * 改寫toString,使得顯示更好   */  public String toString() {    return "["+this.id+"]"+this.name+","+this.age+","+this.salary;  }}

然后利用PreparedStatement接口實現增的操作:

package com.mysqltest.jdbc.xiao1;import java.sql.Connection;import java.sql.PreparedStatement;import com.mysqltest.jdbc.modelComp.CompMember;import com.mysqltest.jdbc.util.DbUtil;public class PstatementTest {  private static DbUtil dbUtil = new DbUtil();  /**   * 用PreparedStatement添加成員   * @param mem   * @return   * @throws Exception   */  private static int addMember(CompMember mem) throws Exception{    Connection con = dbUtil.getCon();    String sql = "insert into comp values(null,?,?,?)";    PreparedStatement pstmt = con.prepareStatement(sql);    pstmt.setString(1, mem.getName());    pstmt.setInt(2, mem.getAge());    pstmt.setDouble(3, mem.getSalary());    int result = pstmt.executeUpdate();//中間不用傳入sql    dbUtil.close(pstmt, con); //preparedStatement是子類,用父類關閉也行    return result;  }  public static void main(String[] args) throws Exception {    CompMember mem = new CompMember("劉翔", 24, 8000.00);    int result = addMember(mem);    if (result==1) {      System.out.println("添加成功");    } else {      System.out.println("添加失敗");    }  }}

再利用PreparedStatement接口實現查詢,并運用ResultSet結果集:

package com.mysqltest.jdbc.xiao2;import java.sql.Connection;import java.sql.PreparedStatement;import java.sql.ResultSet;import java.util.ArrayList;import java.util.List;import com.mysqltest.jdbc.modelComp.CompMember;import com.mysqltest.jdbc.util.DbUtil;public class ResultsetTest {  private static DbUtil dbUtil = new DbUtil();  /**   * 遍歷查詢結果   * @throws Exception   */  @SuppressWarnings("unused")  private static void listMem1() throws Exception {    Connection con = dbUtil.getCon();// 獲取連接    String sql = "select * from comp";    PreparedStatement pstmt = con.prepareStatement(sql);    ResultSet rs = pstmt.executeQuery();// 返回結果集    // next()將光標向后一行    while (rs.next()) {      int id = rs.getInt(1);// 獲取第一列的值id      String name = rs.getString(2);//      int age = rs.getInt(3);      double salary = rs.getDouble(4);      System.out.println("編號:" + id + "姓名:" + name + "年齡:" + age + "工資:" + salary);      System.out.println("+====================================+");    }  }  /**   * 遍歷查詢結果方法2   * @throws Exception   */  @SuppressWarnings("unused")  private static void listMem2() throws Exception {    Connection con = dbUtil.getCon();// 獲取連接    String sql = "select * from comp";    PreparedStatement pstmt = con.prepareStatement(sql);    ResultSet rs = pstmt.executeQuery();// 返回結果集    // next()將光標向后一行    while (rs.next()) {      int id = rs.getInt("id");// 獲取第一列的值id      String name = rs.getString("name");//      int age = rs.getInt("age");      double salary = rs.getDouble("salary");      System.out.println("編號:" + id + "姓名:" + name + "年齡:" + age + "工資:" + salary);      System.out.println("+====================================+");    }  }  private static List<CompMember> listMem3() throws Exception{    List<CompMember> memList = new ArrayList<CompMember>();    Connection con = dbUtil.getCon();// 獲取連接    String sql = "select * from comp";    PreparedStatement pstmt = con.prepareStatement(sql);    ResultSet rs = pstmt.executeQuery();// 返回結果集    // next()將光標向后一行    while (rs.next()) {      int id = rs.getInt("id");// 獲取第一列的值id      String name = rs.getString("name");//      int age = rs.getInt("age");      double salary = rs.getDouble("salary");      CompMember mem = new CompMember(id, name, age, salary);      memList.add(mem);//添加到List中    }    return memList;  }  public static void main(String[] args) throws Exception {//    listMem1();//    listMem2();    List<CompMember> memList = listMem3();    for (CompMember mem : memList) { //遍歷集合的每個元素      System.out.println(mem);    }  }}

希望本文所述對大家java程序設計有所幫助。


注:相關教程知識閱讀請移步到JAVA教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲国产精品专区久久| 久久亚洲精品一区| 国产视频丨精品|在线观看| 欧美精品videosex性欧美| 国产伦精品一区二区三区精品视频| 91在线观看免费网站| 日韩电影免费在线观看中文字幕| 国产91久久婷婷一区二区| 国产精品嫩草影院久久久| 日韩毛片中文字幕| 国产视频欧美视频| 亚洲午夜未满十八勿入免费观看全集| 欧美精品激情blacked18| 久久精品国产欧美亚洲人人爽| 久久精品一偷一偷国产| 国产精品福利在线| 欧美激情精品久久久久久蜜臀| 成人黄色片在线| 亚洲第一区第二区| 成人乱人伦精品视频在线观看| 久久精品国产2020观看福利| 欧美激情国内偷拍| 亚洲精品视频播放| 日韩美女免费线视频| 欧美激情aaaa| 久久久综合av| 国产欧美 在线欧美| 久久久久久尹人网香蕉| 一本色道久久综合狠狠躁篇的优点| 日韩在线高清视频| 日韩高清av在线| 国内精品久久久久久影视8| 亚洲国产精品va在线看黑人动漫| 国外成人性视频| 国产精品专区第二| 欧美色视频日本高清在线观看| 久久亚洲国产成人| 欧美性生交大片免网| 日韩精品福利网站| 91亚洲精品久久久久久久久久久久| 亚洲午夜久久久久久久| 超碰97人人做人人爱少妇| 成人动漫网站在线观看| 国产精品美女免费视频| 亚洲免费人成在线视频观看| 亚洲欧美制服综合另类| 国产盗摄xxxx视频xxx69| 亚洲女人天堂视频| 久久在线免费观看视频| 欧美黄色小视频| 91在线高清视频| 国产精品美女主播在线观看纯欲| 亚洲精品日韩久久久| 91系列在线观看| 国产美女久久精品香蕉69| 91成人天堂久久成人| 亚洲欧美日本另类| 日韩av在线高清| 日韩美女在线播放| 91av视频在线观看| 亚洲精品久久久久久久久久久| 国产精品手机播放| 日韩中文字幕网| www.久久久久久.com| 亚洲欧美国产va在线影院| 91精品91久久久久久| 亚洲女性裸体视频| 欧美激情国产日韩精品一区18| 亚洲国产成人爱av在线播放| 久久亚洲综合国产精品99麻豆精品福利| 亚洲精品国产综合久久| 91国语精品自产拍在线观看性色| 日韩欧美中文免费| 亚洲一区二区三区成人在线视频精品| 国产午夜精品一区理论片飘花| 日本伊人精品一区二区三区介绍| 在线视频一区二区| 中文字幕亚洲第一| 欧美激情视频在线免费观看 欧美视频免费一| 91视频88av| 国产福利视频一区二区| 亚洲人成网站免费播放| 精品一区二区三区四区在线| 中日韩美女免费视频网站在线观看| 亚洲男人天堂网| 在线性视频日韩欧美| 91免费看国产| 日韩电视剧免费观看网站| 成人免费观看a| 久久国产精品99国产精| 日韩a**站在线观看| 美女福利视频一区| 亚洲国产天堂久久国产91| 成人444kkkk在线观看| 国产一区二区三区视频在线观看| 国产精品pans私拍| 亚洲第一中文字幕在线观看| 国产精品美女www爽爽爽视频| 亚州国产精品久久久| 北条麻妃一区二区三区中文字幕| 久久久国产精彩视频美女艺术照福利| 亚洲乱码一区av黑人高潮| 91精品国产免费久久久久久| 久久精品最新地址| 国产精品久久久久久久久影视| 久久久亚洲成人| 一区二区三区天堂av| 国产精品6699| 亚洲色在线视频| 亚洲欧洲xxxx| 欧美精品电影免费在线观看| 欧美日韩在线视频一区| 91网站在线免费观看| 国产精品日韩欧美| 国产精品日韩电影| 青青草原成人在线视频| 欧美日韩国产综合视频在线观看中文| 8090成年在线看片午夜| 97视频在线观看免费高清完整版在线观看| 色综久久综合桃花网| 国产精自产拍久久久久久| 九九精品在线播放| 少妇av一区二区三区| 国产欧美日韩精品专区| 国产日韩亚洲欧美| 国产在线视频2019最新视频| 国产日韩欧美黄色| 欧美噜噜久久久xxx| 丝袜美腿精品国产二区| 欧美激情精品久久久久久变态| 91成品人片a无限观看| 日韩欧美aⅴ综合网站发布| 欧美精品九九久久| 精品一区二区三区四区在线| 国产偷亚洲偷欧美偷精品| 欧美日韩免费在线| 国产不卡av在线免费观看| 日韩精品中文字幕在线播放| 91成人精品网站| 国产精国产精品| 国产在线一区二区三区| 日本精品免费观看| 日韩在线观看免费高清完整版| 国产成人拍精品视频午夜网站| 亚洲国产欧美精品| 亚洲xxxx视频| 2019中文在线观看| 亚洲自拍偷拍网址| 亚洲一区二区三区成人在线视频精品| 91福利视频在线观看| 伊人久久免费视频| 欧美午夜久久久| 91在线直播亚洲| 国产z一区二区三区| 亚洲精品久久久久久久久久久久久| 色偷偷av一区二区三区| 亚洲精品女av网站| 国产亚洲视频在线观看| 欧美精品福利视频| 成人深夜直播免费观看| 97精品一区二区三区| 国产成人精品电影| 精品国产欧美成人夜夜嗨| 日韩欧美在线免费观看|