通过JDBC进行简单的增删改查(以MySQL为例)

本文介绍如何使用JDBC对MySQL数据库进行增删改查操作,包括连接获取、SQL执行及结果处理等步骤,并提供示例代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

通过JDBC进行简单的增删改查(以MySQL为例)


前言:什么是JDBC

  维基百科的简介:

Java 数据库连接,(Java Database Connectivity,简称JDBC)是Java语言中用来规范客户端程序如何来访问数据库的应用程序接口,提供了诸如查询和更新数据库中数据的方法。JDBC也是Sun Microsystems的商标。它JDBC是面向关系型数据库的。

  简单地说,就是用于执行SQL语句的一类JavaAPI,通过JDBC使得我们可以直接使用Java编程来对关系数据库进行操作。通过封装,可以使开发人员使用纯Java API完成SQL的执行。

 

一、准备工作(一):MySQL安装配置和基础学习

  使用JDBC操作数据库之前,首先你需要有一个数据库。这里提供了3个链接供读者自学,如果曾有过SQL语言的使用经历(包括在学校中的课堂学习),前两个链接足以上手。

  1.安装和配置:mysql安装图解 mysql图文安装教程(详细说明)

  2.基本操作:21分钟 MySQL 入门教程

  3.简易命令查询 :一千行MySQL学习笔记

 

  建议边看入门教程,边练习,在练习insertupdateselectdelete等基本操作的同时,将后面要用的表建好。

  下图是我接下来用于演示的数据库的表。

    

 

二、准备工作(二):下载数据库对应的jar包并导入

  使用JDBC需要在工程中导入对应的jar包。数据库与JDBC包的对应关系可以参考各种数据库对应的jar包、驱动类名和URL格式。在Eclipse下的导入方法:

  在工程的图标上右击,选择”Properties”,在”Java Bulid Path”中选择”Add External JARs…”,选择下载并解压后获得的jar包。

       

  如果对MySQL进行操作,这时下面的import就不会报错了:

import com.mysql.jdbc.Connection;

import com.mysql.jdbc.PreparedStatement;

  除此以外,还需要JDBC的包,直接import即可。

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.SQLException;

 

三、JDBC基本操作

  为了简单起见,与数据库相关的操作、命令、参数都被硬编码了。有兴趣的读者可以对这些进行探索,降低数据与操作的耦合性。

  先看具体代码并实践,本文第五部分对用到的API稍作了研究。

  下面的所有方法和数据成员都在public class JDBCOperation内部。

(1)定义记录的类(可选)

  这样做主要是为了便于操作和接口定义,是非必须的。

static class Student {
        privateString Id;
        privateString Name;
        privateString Sex;
        privateString Age;
 
        Student(String Name, String Sex, StringAge) {
            this.Id = null; //default
            this.Name= Name;
            this.Sex =Sex;
            this.Age =Age;
        }
 
        publicString getId() {
            return Id;
        }
 
        public void setId(String Id) {
            this.Id =Id;
        }
 
        publicString getName() {
            return Name;
        }
 
        public void setName(String Name) {
            this.Name= Name;
        }
 
        publicString getSex() {
            return Sex;
        }
 
        public void setSex(String Sex) {
            this.Sex =Sex;
        }
 
        publicString getAge() {
            return Age;
        }
 
        public void setage(String Age) {
            this.Age =Age;
        }
}

 

(2)连接的获取

  在操作前必须先获取与数据库的连接。

  driver、url的格式同样可以参考各种数据库对应的jar包、驱动类名和URL格式

private static Connection getConn() {
    String driver ="com.mysql.jdbc.Driver";
    String url ="jdbc:mysql://localhost:3306/samp_db";
    String username = "root";
    String password = "";
    Connection conn = null;
    try {
        Class.forName(driver); //classLoader,加载对应驱动
        conn = (Connection)DriverManager.getConnection(url, username, password);
    } catch (ClassNotFoundException e) {
        e.printStackTrace();
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return conn;
}
 
(3)insert
private static int insert(Student student) {
    Connection conn = getConn();
    int i = 0;
    String sql = "insert into students(Name,Sex,Age) values(?,?,?)";
    PreparedStatement pstmt;
    try {
        pstmt = (PreparedStatement)conn.prepareStatement(sql);
        pstmt.setString(1, student.getName());
        pstmt.setString(2, student.getSex());
        pstmt.setString(3, student.getAge());
        i = pstmt.executeUpdate();
        pstmt.close();
        conn.close();
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return i;
}

 

(4)update

private static int update(Student student) {
    Connection conn = getConn();
    int i = 0;
    String sql = "update students setAge='" + student.getAge() + "' where Name='" + student.getName()+ "'";
    PreparedStatement pstmt;
    try {
        pstmt = (PreparedStatement)conn.prepareStatement(sql);
        i = pstmt.executeUpdate();
        System.out.println("resutl: " + i);
        pstmt.close();
        conn.close();
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return i;
}


(5)select

  以select* from XXX为例。

private static Integer getAll() {
    Connection conn = getConn();
    String sql = "select * fromstudents";
    PreparedStatement pstmt;
    try {
        pstmt =(PreparedStatement)conn.prepareStatement(sql);
        ResultSet rs = pstmt.executeQuery();
        int col =rs.getMetaData().getColumnCount();
       System.out.println("============================");
        while(rs.next()) {
            for (int i = 1; i <= col; i++) {
               System.out.print(rs.getString(i) + "\t");
                if ((i == 2) &&(rs.getString(i).length() < 8)) {
                   System.out.print("\t");
                }
             }
            System.out.println("");
        }
           System.out.println("============================");
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return null;
}


(6)delete

private static int delete(String name) {
    Connection conn = getConn();
    int i = 0;
    String sql = "delete from studentswhere Name='" + name + "'";
    PreparedStatement pstmt;
    try {
        pstmt = (PreparedStatement)conn.prepareStatement(sql);
        i = pstmt.executeUpdate();
        System.out.println("resutl: "+ i);
        pstmt.close();
        conn.close();
    } catch (SQLException e) {
        e.printStackTrace();
    }
    return i;
}


四、测试

  在测试前,需要在系统中打开对应数据库的服务。MySQL在Windows下的启动命令为

net start mysql

 

  测试代码

public static void main(String args[]) {
    JDBCOperation.getAll();
    JDBCOperation.insert(new Student("Achilles", "Male", "14"));
    JDBCOperation.getAll();
    JDBCOperation.update(new Student("Bean", "", "7"));
    JDBCOperation.delete("Achilles");
    JDBCOperation.getAll();
}


  Eclipse中的输出

============================

1    Ender       male    8   

2    Bean       male    6   

3    Petra        fema   9   

4    Peter       male    9   

5    _Graff        male   40   

6    GOD       fema    255   

============================

============================

1    Ender       male    8   

2    Bean       male    6   

3    Petra        fema   9   

4    Peter       male    9   

5    _Graff        male   40   

6    GOD       fema    255   

7    Achilles   Male    14   

============================

resutl: 1

resutl: 1

============================

1    Ender       male    8   

2    Bean       male    7   

3    Petra        fema   9   

4    Peter       male    9   

5    _Graff        male   40   

6    GOD       fema    255   

============================

 

五、代码分析

  在上述对数据库进行增删改查的过程中,可以发现其共性部分,即通用的流程:

  (1)创建Connection对象、SQL查询命令字符串;

  (2)对Connection对象传入SQL查询命令,获得PreparedStatement对象;

  (3)对PreparedStatement对象执行executeUpdate()或executeQurey()获得结果;

  (4)先后关闭PreparedStatement对象和Connection对象。

  可见,使用JDBC时,最常打交道的是Connection、PreparedStatement这两个类,以及select中的ResultSet类。查阅Java API手册可以了解其具体的意义和方法。


  

六、思考问题

1.每次SQL操作都需要建立和关闭连接,这势必会消耗大量的资源开销,如何避免?

分析:可以采用连接池,对连接进行统一维护,不必每次都建立和关闭。事实上这是很多对JDBC进行封装的工具所采用的。

 

2.Java代码中,传入的数据格式与数据库定义不同怎么办?如把Java的String对象赋值给数据库的tinyint属性。

分析:在执行SQL语句时,数据库会尝试进行转换。根据我的实验,如果用内容为纯字母的String对象传入tinyint的age属性时,会被转化成0。具体转化规则应该和数据库有关。





作者:五岳 
出处:http://www.cnblogs.com/wuyuegb2312
对于标题未标注为“转载”的文章均为原创,其版权归作者所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值