不多bb了直接上。

工具:myeclipse 2016,mysql 5.7

目的:java操作数据库增删改查商品信息

test数据库的goods表

gid主键,自增

1、实体类Goods:封装数据库数据(与数据库表中各字段相匹配的类)

// 实体类
public class Goods {
private int gid;
private String gname;
private double gprice;
private String gdate;
//生成get、set方法
public int getGid() {
return gid;
}
public void setGid(int gid) {
this.gid = gid;
}
public String getGname() {
return gname;
}
public void setGname(String gname) {
this.gname = gname;
}
public double getGprice() {
return gprice;
}
public void setGprice(double gprice) {
this.gprice = gprice;
}
public String getGdate() {
return gdate;
}
public void setGdate(String gdate) {
this.gdate = gdate;
}
//生成构造方法
public Goods(int gid, String gname, double gprice, String gdate) {
super();
this.gid = gid;
this.gname = gname;
this.gprice = gprice;
this.gdate = gdate;
}
//生成无参构造方法
public Goods() {
super();
} }

2、实现类GoodsDao(不带DBHelper):操作数据库实现增删改查

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement;
import java.util.Scanner; public class GoodsDao { public static void main(String[] args) {
GoodsDao dao = new GoodsDao();
// dao.add(); // dao.del(); // dao.upd();
Scanner input = new Scanner(System.in); System.out.println("请输入商品名称:"); String name = input.next(); System.out.println("请输入商品价格:"); double price = input.nextDouble(); dao.newAdd(name, price); // System.out.println("请输入最低价格:");
// double price = input.nextDouble();
//
// dao.search(price);
//
System.out.println("已经成功完成操作!");
} // 增数据
public void add(){
try{
// 1.通过反射,加载驱动类到jvm
Class.forName("com.mysql.jdbc.Driver");
// 2.获取数据库连接对象
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=true","root","");
// 3.创建数据库操作对象
Statement stmt = conn.createStatement();
// 4.操作数据库
stmt.execute("insert into goods(gname,gprice,gdate) values('ggg','2.33',now())"); //5.关闭各个资源
stmt.close();
conn.close(); } catch(Exception e){
e.printStackTrace();
}
}
//删数据
public void del(){
try{
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=true","root",""); Statement stmt = conn.createStatement(); stmt.execute("delete from goods where gid=1"); stmt.close();
conn.close(); } catch(Exception e){
e.printStackTrace();
}
}
//改数据
public void upd(){
try{
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=true","root",""); Statement stmt = conn.createStatement();
stmt.execute("update goods set gname='ggg' where gid=1 "); stmt.close();
conn.close(); } catch(Exception e){
e.printStackTrace();
}
}
//查数据
public void search(double price){
try{
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=true","root",""); Statement stmt = conn.createStatement();
// 结果集对象
ResultSet rs = stmt.executeQuery("select * from goods where gprice>"+price); while(rs.next()){
System.out.println(rs.getString(1)+"#"+rs.getString("gname")+"#"+rs.getDouble("gprice")+"#"+rs.getString("gdate"));
} rs.close();
stmt.close();
conn.close(); } catch(Exception e){
e.printStackTrace();
}
} //用拼字符串的方法增数据
public void newAdd(String gname, double gprice){
try{
Class.forName("com.mysql.jdbc.Driver");
Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=true","root",""); // Statement stmt = conn.createStatement();
//
// stmt.execute("insert into goods(gname, gprice,gdate) values('"+gname+"','"+gprice+"',now())");
//
// stmt.close();
//拼字符串更简单
String sql = "insert into goods(gname, gprice, gdate) values(?,?,now())"; PreparedStatement pstmt = conn.prepareStatement(sql); pstmt.setString(1, gname);
pstmt.setDouble(2, gprice); pstmt.execute(); conn.close();
} catch(Exception e){
e.printStackTrace();
}
} }

3、DBHelper类:解决上述代码操作数据库的重复工作

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.sql.Statement; /**
* 获取数据库操作的连接对象
* 关闭数据库操作的各种资源
* @author 晏先政
*
*/
public class DBHelper {
private static final String className = "com.mysql.jdbc.Driver";
private static final String url = "jdbc:mysql://localhost:3306/test?characterEncoding=utf8&useSSL=true";
private static final String uname = "root";
private static final String upass = ""; /**
* 获取数据库连接对象的方法
*/
public static Connection getConn(){
Connection conn = null;
try{
Class.forName(className);
conn = DriverManager.getConnection(url,uname, upass);
} catch(Exception e){
e.printStackTrace();
} return conn;
} /**
* 关闭数据库连接对象
*/
public static void closeConn(Connection conn){
try{
if(conn!=null){
conn.close();
}
} catch(Exception e){
e.printStackTrace();
}
} /**
* 关闭数据库操作对象
*/
public static void closeStmt(Statement stmt){
try{
if(stmt!=null){
stmt.close();
}
} catch(Exception e){
e.printStackTrace();
}
} /**
* 关闭数据库操作对象
*/
public static void closePstmt(PreparedStatement pstmt){
try{
if(pstmt!=null){
pstmt.close();
}
} catch(Exception e){
e.printStackTrace();
}
} /**
* 关闭数据库操作对象
*/
public static void closeRs(ResultSet rs){
try{
if(rs!=null){
rs.close();
}
} catch(Exception e){
e.printStackTrace();
}
}
}

4、实现类NewDao(带DBHelper):操作数据库实现增删改查

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.ArrayList;
import java.util.List;
import java.util.Scanner; public class NewDao { public static void main(String[] args) {
NewDao nd = new NewDao();
nd.show();
// Scanner input = new Scanner(System.in);
//改数据
// System.out.println("请输入要修改的商品编号:");
// int gid = input.nextInt();
// System.out.println("请输入要修改的商品名称:");
// String gname = input.next();
// System.out.println("请输入要修改的商品价格:");
// double gprice = input.nextDouble();
//
// nd.upd(gid, gname, gprice); //查数据
// System.out.println("请输入最低价格:");
// double mprice = input.nextDouble();
// System.out.println("请输入最高价格:");
// double xprice = input.nextDouble();
//
// nd.search(mprice, xprice); }
private Connection conn = null;
private PreparedStatement pstmt = null;
private ResultSet rs = null;
//查数据
public void search(double minprice, double maxprice){
try{
conn = DBHelper.getConn();
String sql = "select * from goods where gprice>=? and gprice<=?";
// 预编译的对象
pstmt = conn.prepareStatement(sql); pstmt.setDouble(1, minprice);
pstmt.setDouble(2, maxprice); rs = pstmt.executeQuery();
while(rs.next()){
System.out.println(rs.getString("gid")+"#"+rs.getString("gname")+"#"+rs.getString("gprice"));
} } catch(Exception e){
e.printStackTrace();
} finally{
DBHelper.closeRs(rs);
DBHelper.closePstmt(pstmt);
DBHelper.closeConn(conn);
}
} //改数据
public void upd(int gid , String gname, double gprice){
try{
conn = DBHelper.getConn();
String sql = "update goods set gname=?, gprice=? where gid=?"; pstmt = conn.prepareStatement(sql);
pstmt.setString(1, gname);
pstmt.setDouble(2, gprice);
pstmt.setInt(3, gid); pstmt.execute(); } catch(Exception e){
e.printStackTrace();
} finally{
DBHelper.closePstmt(pstmt);
DBHelper.closeConn(conn);
}
} //用集合展示数据
public List<Goods> getAllGoods(){
List<Goods> list = new ArrayList<Goods>();
try{
conn = DBHelper.getConn(); String sql = "select * from goods"; pstmt = conn.prepareStatement(sql); rs = pstmt.executeQuery(); while(rs.next()){
Goods goods = new Goods(rs.getInt("gid"),rs.getString("gname"),rs.getDouble("gprice"),rs.getString("gdate")); list.add(goods);
} } catch(Exception e){
e.printStackTrace();
} finally{
DBHelper.closeRs(rs);
DBHelper.closePstmt(pstmt);
DBHelper.closeConn(conn);
}
return list;
} public void show(){
List<Goods> list = getAllGoods(); for(int i=0;i<list.size();i++){
System.out.println(list.get(i).getGid()+"#"+list.get(i).getGname()+"#"+list.get(i).getGprice());
}
} }

java操作数据库:增删改查的更多相关文章

  1. java操作数据库增删改查的小工具1--TxQueryRunner

    在java程序中,一般使用jdbc连接数据库,比较麻烦,在看传智教程时学了一个工具类,用于简化与数据库之间的操作步骤,就是TxQueryRunner,他是QueryRunner的子类,用起来和他是一样 ...

  2. java操作数据库增删改查的小工具2--TxQueryRunner

    当涉及到多表查询时,如数据库中有两张表分别为t_person和t_address,表结构如下: 其中t_person的外键为t-address的主键aid, 新建两个javaBean类,Person ...

  3. 2. MongoDB基本操作 —— 用Mongo.exe操作数据库增删改查

    一.开篇 传统的关系数据库一般由数据库(database).表(table).记录(record)三个层次概念组成,MongoDB是由数据库(database).集合(collection).文档对象 ...

  4. MongoDB(六)java操作mongodb增删改查

    java操作mysql数据库的代码我们已经了如指掌了.增删改查,java对mongodb数据库也是类似的操作,先是数据库连接.再是进行操作. 首先我们进入进入admin数据库.然后建立自己的数据库te ...

  5. Django-Model操作数据库(增删改查、连表结构)

    一.数据库操作 1.创建model表         基本结构 1 2 3 4 5 6 from django.db import models     class userinfo(models.M ...

  6. phpcms 操作数据库 增删改查

    数据库的其他类继承的都是libs/class/model.class.php 这里面有写好的操作数据库的常用方法 1.增 insert($data, $return_insert_id = false ...

  7. MongoDB学习day04--NodeJs操作数据库增删改查

    一.在Nodejs中使用Mongodb Nodejs需要引入的包 npm install mongodb --save -dev 或者使用镜像 cnpm install mongodb --save ...

  8. Java针对数据库增删改查代码

    package com.bank.abc; import java.beans.PropertyVetoException; import java.sql.Connection; import ja ...

  9. JavaWeb学习记录(七)——MVC操作数据库增删改查与分页功能

    一.分页工具类 package blank.util;import java.util.List; import org.springframework.jdbc.core.JdbcTemplate; ...

  10. 6. MongoDB——Java操作(增删改查)

    转自:https://blog.csdn.net/kai402458953/article/details/79626148 import java.net.UnknownHostException; ...

随机推荐

  1. Python将是人工智能时代的最佳编程语言

    Python将是人工智能时代的最佳编程语言 移动互联网取代PC互联网领跑在互联网时代的最前沿,Android和iOS一度成为移动互联网应用平台的两大霸主,成为移动开发者首选的两门技术,HTML5以其跨 ...

  2. 15 Zabbix Item类型之Zabbix trapper类型

    点击返回:自学Zabbix之路 点击返回:自学Zabbix4.0之路 点击返回:自学zabbix集锦 15 Zabbix Item类型之Zabbix trapper类型 zabbix获取数据时有时会出 ...

  3. 【BZOJ2324】[ZJOI2011]营救皮卡丘(网络流,费用流)

    [BZOJ2324][ZJOI2011]营救皮卡丘(网络流,费用流) 题面 BZOJ 洛谷 题解 如果考虑每个人走的路径,就会很麻烦. 转过来考虑每个人破坏的点集,这样子每个人可以得到一个上升的序列. ...

  4. RHEL7下用本地光盘或镜像iso文件做yum源

    应用场境:Redhat 系统想要直接在线通过yum的条件时需要注册,一般用户都是非注册的,这个时候如果要想通过yum安装新软件,我们可以通过将安装盘或者镜像iso文件设置为yum源的方式来进行. 测试 ...

  5. 为什么分布式一定要有redis?

    为什么分布式一定要有redis? 孤独烟 架构师小秘圈 昨天 作者:孤独烟 来自:http://rjzheng.cnblogs.com/ 1.为什么使用redis   分析:博主觉得在项目中使用red ...

  6. 解题:CF622F The Sum of the k-th Powers

    题面 TJOI2018出CF原题弱化版是不是有点太过分了?对,就是 TJOI2018 教科书般的亵渎 然而我这个问题只会那个题的范围的m^3做法 回忆一下1到n求和是二次的,平方求和公式是三次的,立方 ...

  7. java锁——wait,notify,synchronized

    背景:这篇博客用来总结java锁相关的知识点,平时还是要自己多加练习 wait 和 notify以及notifyAll (1).方法介绍1.wait.notify以及notifyAll都是Object ...

  8. latex 双引号 “

    别在latex敲,在记事本上敲完后,拷贝到latex中.

  9. mfc01

    1.解决不能将参数1从“const char []”转换为“LPCTSTR” ,使用多字节字符集.

  10. codeforces 540E"Infinite Inversions"

    传送门 题意: 给你一个无限大的整数序列  p = {1, 2, 3, ...}: 有 n 次操作,每次操作交换第 ai 个数和第 aj 个数: 求序列中逆序对的个数: 题解: 考虑交换完后的序列,存 ...