Java使用Statement接口執(zhí)行SQL語(yǔ)句操作實(shí)例分析
本文實(shí)例講述了Java使用Statement接口執(zhí)行SQL語(yǔ)句操作的方法。分享給大家供大家參考,具體如下:
Statement執(zhí)行SQL語(yǔ)句:
1. 對(duì)數(shù)據(jù)庫(kù)的曾刪改操作時(shí),使用stmt.executeUpdate(sql) 執(zhí)行給定 SQL 語(yǔ)句,分別為 insert 、update、delete.
2. 對(duì)數(shù)據(jù)庫(kù)做查詢(xún)時(shí),直接使用 stmt.executeQuery(sql),返回結(jié)果可以為一個(gè)resultSet結(jié)果集。
首先做一些準(zhǔn)備工作:
①對(duì)要進(jìn)行操作的數(shù)據(jù)庫(kù)表進(jìn)行封裝,比如說(shuō)我的數(shù)據(jù)mydata中的aistu表,用AiMember.java進(jìn)行封裝,以便后面操作。具體如下:
package com.mysqltest.jdbc.model;
/**
* 定義一個(gè)model
* 成員模型
* @author AI_STU
*
*/
public class AiMember {
private String name;
private int id;
private int age;
private String email;
private String tel;
private double salary;
private String riqi;
/**
* alt+shift+s 添加構(gòu)造函數(shù)generating constructor using fields.
* @param name
* @param id
* @param age
* @param email
* @param tel
* @param salary
* @param riqi
*/
public AiMember(String name, int id, int age, String email, String tel, double salary, String riqi) {
super();
this.name = name;
this.id = id;
this.age = age;
this.email = email;
this.tel = tel;
this.salary = salary;
this.riqi = riqi;
}
//重構(gòu)
public AiMember(int id) {
super();
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getEmail() {
return email;
}
public void setEmail(String email) {
this.email = email;
}
public String getTel() {
return tel;
}
public void setTel(String tel) {
this.tel = tel;
}
public double getSalary() {
return salary;
}
public void setSalary(double salary) {
this.salary = salary;
}
public String getRiqi() {
return riqi;
}
public void setRiqi(String riqi) {
this.riqi = riqi;
}
}
②對(duì)連接MySQL數(shù)據(jù)庫(kù),和關(guān)閉連接方法進(jìn)行封裝,這里用DbUtil.java進(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
/**
* 改寫(xiě)toString,使得顯示更好
*/
public String toString() {
return "["+this.id+"]"+this.name+","+this.age+","+this.salary;
}
}
準(zhǔn)備工作做好了,下面開(kāi)始使用Statement接口執(zhí)行sql語(yǔ)句來(lái)實(shí)現(xiàn)增刪改:
①增:
package com.mysqltest.jdbc.two2;
import java.sql.Connection;
import java.sql.Statement;
import com.mysqltest.jdbc.model.AiMember;
import com.mysqltest.jdbc.util.DbUtil;
public class Demo3 {
/**
* 添加成員到表中1
* @param name
* @param id
* @param age
* @param email
* @param tel
* @param salary
* @param riqi
* @return
* @throws Exception
*/
@SuppressWarnings("unused")
private static int addMember(String name,int id,int age,String email,String tel,double salary,String riqi) throws Exception{
DbUtil dbUtil = new DbUtil();//之前封裝好的
Connection con = dbUtil.getCon(); //獲取數(shù)據(jù)庫(kù)連接
String sql = "insert into aistu values('"+name+"',"+id+",'"+age+"','"+email+"','"+tel+"','"+salary+"','"+riqi+"')";
Statement stmt = con.createStatement();//獲取statement
int result = stmt.executeUpdate(sql);
dbUtil.close(stmt, con);
return result;
}
/**
* 添加成員到表中2方法
* @param mem
* @return
* @throws Exception
*/
private static int addMember2(AiMember mem) throws Exception{ //AiMember也是之前封裝好的
// mem.getName();
DbUtil dbUtil = new DbUtil();//之前封裝好的
Connection con = dbUtil.getCon(); //獲取數(shù)據(jù)庫(kù)連接
String sql = "insert into aistu values('"+mem.getName()+"',"+mem.getId()+",'"+mem.getAge()+"','"+mem.getEmail()+"','"+mem.getTel()+"','"+mem.getSalary()+"','"+mem.getRiqi()+"')";
Statement stmt = con.createStatement();//獲取statement
int result = stmt.executeUpdate(sql);
dbUtil.close(stmt, con);
return result;
}
// private static int addMenber2()
public static void main(String[] args) throws Exception {
/*int result = addMember("劉翔", 4, 28, "15xliu@stu.edu.cn", "13411957776", 8000.00, "2015-09-10");
if(result==1){
System.out.println("添加成功");
}else{
System.out.println("添加失敗");
}*/ //多行注釋?zhuān)琧trl+shift+/
AiMember mem = new AiMember("李娜", 6, 25, "15nli@stu.edu.cn", "13411957775", 8000.00, "2015-09-03");
int result = addMember2(mem);
if(result==1){
System.out.println("添加成功");
}else{
System.out.println("添加失敗");
}
}
}
②改:
package com.mysqltest.jdbc.two3;
import java.sql.Connection;
import java.sql.Statement;
import com.mysqltest.jdbc.model.AiMember;
import com.mysqltest.jdbc.util.DbUtil;
public class Demo4 {
private static DbUtil dbUtil = new DbUtil();
// @SuppressWarnings("unused")
/**
* 修改成員
* @param mem
* @return
* @throws Exception
*/
private static int updateMember(AiMember mem) throws Exception {
Connection con = dbUtil.getCon(); // 獲取數(shù)據(jù)庫(kù)連接
String sql = "update aistu set name='" + mem.getName() + "',id=" + mem.getId() + ",age='" + mem.getAge()
+ "',email='" + mem.getEmail() + "',tel='" + mem.getTel() + "',salary='" + mem.getSalary() + "',riqi='"
+ mem.getRiqi() + "' where id=" + mem.getId();
//格式化,ctrl+a全選,然后ctrl+shift+f格式化
Statement stmt = con.createStatement();// 獲取statement
int result = stmt.executeUpdate(sql);
dbUtil.close(stmt, con);
return result;
// return 0;
}
public static void main(String[] args) throws Exception {
AiMember mem = new AiMember("勞爾", 6, 24, "14elao@stu.edu.cn", "13411957770", 18000.00, "2014-09-03");
int result = updateMember(mem);
if (result==1) {
System.out.println("更新成功");
} else {
System.out.println("更新失敗");
}
}
}
③刪:
package com.mysqltest.jdbc.two4;
import java.sql.Connection;
import java.sql.Statement;
import com.mysqltest.jdbc.model.AiMember;
import com.mysqltest.jdbc.util.DbUtil;
public class Demo5 {
private static DbUtil dbUtil = new DbUtil();
public static int deletMember(AiMember mem) throws Exception{
Connection con = dbUtil.getCon(); // 獲取數(shù)據(jù)庫(kù)連接
String sql = "delete from aistu where id="+mem.getId();
Statement stmt = con.createStatement();// 獲取statement
int result = stmt.executeUpdate(sql);
dbUtil.close(stmt, con);
return result;
}
public static void main(String[] args) throws Exception {
AiMember mem = new AiMember(5);
int result = deletMember(mem);
if (result==1) {
System.out.println("成功刪除成員");
} else {
System.out.println("刪除成員失敗");
}
}
}
更多關(guān)于java相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《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ì)有所幫助。
- Java使用PreparedStatement接口及ResultSet結(jié)果集的方法示例
- Java連接數(shù)據(jù)庫(kù)JDBC技術(shù)之prepareStatement的詳細(xì)介紹
- java中PreparedStatement和Statement詳細(xì)講解
- Java數(shù)據(jù)庫(kù)連接PreparedStatement的使用詳解
- java 中createStatement()方法的實(shí)例詳解
- Java的JDBC中Statement與CallableStatement對(duì)象實(shí)例
- 詳解Java的JDBC中Statement與PreparedStatement對(duì)象
- java中Statement 與 PreparedStatement接口之間的關(guān)系和區(qū)別
相關(guān)文章
Springboot+Jackson自定義注解數(shù)據(jù)脫敏的項(xiàng)目實(shí)踐
數(shù)據(jù)脫敏可以對(duì)敏感數(shù)據(jù)比如 手機(jī)號(hào)、銀行卡號(hào)等信息進(jìn)行轉(zhuǎn)換或者修改,本文主要介紹了Springboot+Jackson?自定義注解數(shù)據(jù)脫敏,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-08-08
Spring?Data?Jpa?復(fù)雜查詢(xún)方式總結(jié)(多表關(guān)聯(lián)及自定義分頁(yè))
這篇文章主要介紹了Spring?Data?Jpa?復(fù)雜查詢(xún)方式總結(jié)(多表關(guān)聯(lián)及自定義分頁(yè)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-02-02
java實(shí)現(xiàn)簡(jiǎn)易撲克牌游戲
這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)簡(jiǎn)易撲克牌游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04
MyBatis學(xué)習(xí)教程之開(kāi)發(fā)Dao的方法教程
這篇文章主要給大家介紹了關(guān)于MyBatis開(kāi)發(fā)Dao的相關(guān)資料,使用Mybatis開(kāi)發(fā)Dao,通常有兩個(gè)方法,即原始Dao開(kāi)發(fā)方法和Mapper接口開(kāi)發(fā)方法。文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友們下面來(lái)一起看看吧。2017-07-07
Java搭建一個(gè)springboot3.4.1項(xiàng)目?JDK21的詳細(xì)過(guò)程
這篇文章詳細(xì)介紹了如何使用IntelliJ IDEA搭建一個(gè)基于Spring Boot 3.4.1的項(xiàng)目,并使用JDK 21和Maven 3.6.3,涵蓋了環(huán)境準(zhǔn)備、項(xiàng)目創(chuàng)建、依賴(lài)管理、Maven配置、以及解決常見(jiàn)問(wèn)題的步驟,感興趣的朋友跟隨小編一起看看吧2025-01-01
springboot中shiro使用自定義注解屏蔽接口鑒權(quán)實(shí)現(xiàn)
本文主要介紹了springboot中shiro使用自定義注解屏蔽接口鑒權(quán)實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-07-07
Spring-Boot 訪(fǎng)問(wèn)外部接口的方案總結(jié)
在Spring-Boot項(xiàng)目開(kāi)發(fā)中,存在著本模塊的代碼需要訪(fǎng)問(wèn)外面模塊接口,或外部url鏈接的需求,針對(duì)這一需求目前存在著三種解決方案,下面將對(duì)這三種方案進(jìn)行整理和說(shuō)明,對(duì)Spring-Boot 訪(fǎng)問(wèn)外部接口方案感興趣的朋友跟隨小編一起看看吧2022-12-12

