欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2018年07月07日 11:28:07   作者:Young-xy  
這篇文章主要介紹了Java使用PreparedStatement接口及ResultSet結(jié)果集的方法,結(jié)合實(shí)例形式分析了PreparedStatement接口及ResultSet結(jié)果集的相關(guān)使用方法與操作注意事項(xiàng),需要的朋友可以參考下

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

說明:

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

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

3.在JDBC應(yīng)用中,一般都用PreparedStatement,而不是Statement。

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

對(duì)連接數(shù)據(jù)庫(kù),關(guān)閉連接封裝,在之前博客中已經(jīng)提到DbUtil.java;

對(duì)數(shù)據(jù)庫(kù)表進(jìn)行封裝,這里是對(duì)我的數(shù)據(jù)庫(kù)中comp表進(jìn)行操作,因此封裝如下:

package com.mysqltest.jdbc.modelComp;
public class CompMember {
  private int id;
  private String name;
  private int age;
  private double salary;
  /**
   * 構(gòu)造函數(shù)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;
  }
  /**
   * 重載構(gòu)造函數(shù)
   * @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接口實(shí)現(xiàn)增的操作:

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是子類,用父類關(guān)閉也行
    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接口實(shí)現(xiàn)查詢,并運(yùn)用ResultSet結(jié)果集:

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();
  /**
   * 遍歷查詢結(jié)果
   * @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();// 返回結(jié)果集
    // next()將光標(biāo)向后一行
    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("編號(hào):" + id + "姓名:" + name + "年齡:" + age + "工資:" + salary);
      System.out.println("+====================================+");
    }
  }
  /**
   * 遍歷查詢結(jié)果方法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();// 返回結(jié)果集
    // next()將光標(biāo)向后一行
    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("編號(hào):" + 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();// 返回結(jié)果集
    // next()將光標(biāo)向后一行
    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) { //遍歷集合的每個(gè)元素
      System.out.println(mem);
    }
  }
}

更多關(guān)于java相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java+MySQL數(shù)據(jù)庫(kù)程序設(shè)計(jì)總結(jié)》、《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java文件與目錄操作技巧匯總》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》和《Java緩存操作技巧匯總

希望本文所述對(duì)大家java程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Spring Boot 員工管理系統(tǒng)超詳細(xì)教程(源碼分享)

    Spring Boot 員工管理系統(tǒng)超詳細(xì)教程(源碼分享)

    這篇文章主要介紹了Spring Boot 員工管理系統(tǒng)超詳細(xì)教程(源碼分享),本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-05-05
  • Spring AOP注解案例及基本原理詳解

    Spring AOP注解案例及基本原理詳解

    這篇文章主要介紹了Spring AOP注解案例及基本原理詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • java對(duì)象的序列化和反序列化

    java對(duì)象的序列化和反序列化

    這篇文章主要為大家詳細(xì)介紹了java對(duì)象的序列化和反序列化,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Java FileWriter輸出換行操作

    Java FileWriter輸出換行操作

    這篇文章主要介紹了Java FileWriter輸出換行操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • java jdk動(dòng)態(tài)代理詳解

    java jdk動(dòng)態(tài)代理詳解

    動(dòng)態(tài)代理類的Class實(shí)例是怎么生成的呢,是通過ProxyGenerator類來生成動(dòng)態(tài)代理類的class字節(jié)流,把它載入方法區(qū)
    2013-09-09
  • 詳解SpringBoot中5種類型參數(shù)傳遞和json數(shù)據(jù)傳參的操作

    詳解SpringBoot中5種類型參數(shù)傳遞和json數(shù)據(jù)傳參的操作

    當(dāng)涉及到參數(shù)傳遞時(shí),Spring?Boot遵循HTTP協(xié)議,并支持多種參數(shù)傳遞方式,這些參數(shù)傳遞方式可以根據(jù)請(qǐng)求的不同部分進(jìn)行分類,
    2023-12-12
  • RabbitMQ消息隊(duì)列的目錄結(jié)構(gòu)

    RabbitMQ消息隊(duì)列的目錄結(jié)構(gòu)

    這篇文章主要介紹了RabbitMQ消息隊(duì)列的目錄結(jié)構(gòu),RabbitMQ?屬于消息中間件,主要用于組件之間的解耦,消息的發(fā)送者無需知道消息使用者的存在,反之亦然,那么用了那么久RabbitMQ,其目錄結(jié)構(gòu)是怎樣的呢,讓我們一起來看一下吧
    2023-08-08
  • Java中clone方法使用筆記

    Java中clone方法使用筆記

    clone顧名思義是復(fù)制,在Java語言中,clone方法被對(duì)象調(diào)用,所以會(huì)復(fù)制對(duì)象,下面這篇文章主要給大家介紹了關(guān)于Java中clone方法使用的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • Java攔截器Interceptor實(shí)現(xiàn)原理及代碼示例

    Java攔截器Interceptor實(shí)現(xiàn)原理及代碼示例

    本文詳細(xì)講解了Java攔截器Interceptor實(shí)現(xiàn)原理及代碼示例,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-12-12
  • Mybatis-plus apply函數(shù)使用場(chǎng)景分析

    Mybatis-plus apply函數(shù)使用場(chǎng)景分析

    Mybatis-plus 里面的 apply方法 是用于拼接自定義的條件判斷,自定義時(shí)間查詢,根據(jù)傳進(jìn)來的開始日期,查詢所有該日期是數(shù)據(jù),但是數(shù)據(jù)庫(kù)中保存是時(shí)間,所以需要使用apply查詢方式并格式化,這篇文章給大家介紹Mybatis-plus apply函數(shù)使用,感興趣的朋友一起看看吧
    2024-02-02

最新評(píng)論