转自: http://blog.csdn.net/tobetheender/article/details/52772157

Java通过JDBC 进行MySQL数据库操作

原创 2016年10月10日 16:46:41
  • 4407

一:前言

在测试工作中难免会和数据库打交道,可能大家对数据库语句都比较熟,比如常见的增删改查等,但是当我们在做自动化测试时,比如接口测试,大部分请求参数,可能都是从数据库中取值,并且接口返回值最后都会记录在数据库中,这样前提就需要和数据库建立连接,才能进行读写操作。


二:JDBC是什么

java提供了一个API也就是JDBC(Java Data Base Connectivity),可以为多种关系数据库提供统一访问和操作,它由一组用Java语言编写的类和接口组成。

  • 没有jdbc之前 
    java开发人员需要维护不同的数据库的驱动程序,如果数据库的底层实现改变,驱动程序可能会随之改变!!

  • 有了jdbc之后: 
    java开发人员只需维护java应用和一套规范,也就是jdbc接口。数据库厂商提供具体的java驱动程序,数据库厂商的底层实现改变,厂商随之更新驱动程序,而不影响java应用程序!!


三:实现步骤

  1. 导入数据包 
    需要包括含有需要进行数据库编程的JDBC类的包。大多数情况下,使用 import java.sql.* 就可以了.

  2. 添加JDBC驱动程序包 
    添加jar程序驱动包http://www.mysql.com/downloads/connector/j,初始化驱动程序,可以与数据库打开一个通信通道。

  3. 打开数据库连接 
    需要使用DriverManager.getConnection() 方法创建一个Connection对象,它代表与数据库的物理连接。

  4. 执行数据库操作 
    需要使用类型声明的对象建立并提交一个SQL语句到数据库。

  5. 从结果集中提取数据 
    要求使用适当的关于ResultSet.getXXX()方法来检索结果集的数据。

  6. 清理环境 
    需要明确地关闭所有的数据库资源相对依靠JVM的垃圾收集。

JDBCUtil类

  • 主程序
  

 package com.jdbc;

 //导入数据包
import java.io.InputStream;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;
import java.util.Properties; /**
* @author Charlie.chen
*
*/ public class JDBCUtil{ // 驱动包名和数据库url
private static String url = null;
private static String driverClass = null;
// 数据库用户名和密码
private static String userName = null;
private static String password = null; /**
* 初始化驱动程序
* 静态代码块中(只加载一次)
*/
static{
try {
//读取db.properties文件
Properties prop = new Properties(); /**
* 使用类路径的读取方式
* / : 斜杠表示classpath的根目录
* 在java项目下,classpath的根目录从bin目录开始
* 在web项目下,classpath的根目录从WEB-INF/classes目录开始
*/
InputStream in = JDBCUtil.class.getResourceAsStream("/db.properties"); //加载文件
prop.load(in);
//读取信息
url = prop.getProperty("url");
driverClass = prop.getProperty("driverClass");
userName = prop.getProperty("user");
password = prop.getProperty("password"); //注册驱动程序
Class.forName(driverClass);
} catch (Exception e) {
e.printStackTrace();
System.out.println("驱程程序注册出错");
}
} /**
* 打开数据库驱动连接
*/
public static Connection getConnection(){
try {
Connection conn = DriverManager.getConnection(url, userName, password);
return conn;
} catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException(e);
}
} /**
* 清理环境,关闭连接(顺序:后打开的先关闭)
*/
public static void close(Connection conn,Statement stmt,ResultSet rs){
if(rs!=null)
try {
rs.close();
} catch (SQLException e1) {
e1.printStackTrace();
throw new RuntimeException(e1);
}
if(stmt!=null){
try {
stmt.close();
} catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException(e);
}
}
if(conn!=null){
try {
conn.close();
} catch (SQLException e) {
e.printStackTrace();
throw new RuntimeException(e);
}
}
} public static void main(String[] args) { Connection conn = null;
Statement stmt = null;
ResultSet rs = null; conn=JDBCUtil.getConnection();
try {
stmt=conn.createStatement();
//准备sql操作语句
String sql= "SELECT id, first, last, age FROM YourDBName";
rs = stmt.executeQuery(sql); //从结果集中提取数据
while(rs.next()){
int id = rs.getInt("id");
int age = rs.getInt("age");
String first = rs.getString("first");
String last = rs.getString("last"); System.out.print("ID: " + id);
System.out.print(", Age: " + age);
System.out.print(", First: " + first);
System.out.println(", Last: " + last);
}
} catch (SQLException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}finally{
JDBCUtil.close(conn, stmt, rs);
}
}
}
  • JDBC配置文件db.properties
  •  url=jdbc:mysql://localhost/yourDBName
    user=root
    password=root
    driverClass=com.mysql.jdbc.Driver

    四:JDBC核心API

    JDBC接口核心的API

    • java.sql.*
    • javax.sql.*

    •  |- Driver接口: 表示java驱动程序接口。所有的具体的数据库厂商要来实现此接口。
      |- connect(url, properties): 连接数据库的方法。
      url: 连接数据库的URL
      URL语法: jdbc协议:数据库子协议://主机:端口/数据库
      user: 数据库的用户名
      password: 数据库用户密码
      |- DriverManager类: 驱动管理器类,用于管理所有注册的驱动程序
      |-registerDriver(driver) : 注册驱动类对象
      |-Connection getConnection(url,user,password); 获取连接对象 |- Connection接口: 表示java程序和数据库的连接对象。
      |- Statement createStatement() : 创建Statement对象
      |- PreparedStatement prepareStatement(String sql) 创建PreparedStatement对象
      |- CallableStatement prepareCall(String sql) 创建CallableStatement对象 |- Statement接口: 用于执行静态的sql语句
      |- int executeUpdate(String sql) : 执行静态的更新sql语句(DDL,DML)
      |- ResultSet executeQuery(String sql) :执行的静态的查询sql语句(DQL) |-PreparedStatement接口:用于执行预编译sql语句
      |- int executeUpdate() : 执行预编译的更新sql语句(DDL,DML)
      |-ResultSet executeQuery() : 执行预编译的查询sql语句(DQL) |-CallableStatement接口:用于执行存储过程的sql语句(call xxx)
      |-ResultSet executeQuery() : 调用存储过程的方法 |- ResultSet接口:用于封装查询出来的数据
      |- boolean next() : 将光标移动到下一行
      |-getXX() : 获取列的值

      五:常见的SQL执行语句

    •  String sql = "CREATE TABLE student(id INT PRIMARY KEY AUTO_INCREMENT,NAME VARCHAR(20),gender VARCHAR(2))";
      //发送sql语句,执行sql语句,得到返回结果
      int count = stmt.executeUpdate(sql); String sql = "SELECT * FROM student";
      //执行sql
      ResultSet rs = stmt.executeQuery(sql); String sql = "INSERT INTO student(NAME,gender) VALUES('李四','女')";
      int count = stmt.executeUpdate(sql); String sql = "UPDATE student SET NAME='"+name+"' WHERE id="+id+""; String sql = "DELETE FROM student WHERE id="+id+"";

      六:补充

      数据库url制定

      当加载的驱动程序,可以建立程序中使用DriverManager.getConnection()方法的连接。为方便参考,让列出了三个重载DriverManager.getConnection()方法:

      getConnection(String url)

      getConnection(String url, Properties prop)

      getConnection(String url, String user, String password)

      在这里,每个表单需要一个数据库URL。数据库的URL是指向数据库地址。

      制定一个数据库URL是大多数用在建立连接相关。 
      如图列出了下来流行的JDBC驱动程序名和数据库的URL。 

      参考资料

      http://www.yiibai.com/jdbc/jdbc-sample-code.html#

Java通过JDBC 进行MySQL数据库操作的更多相关文章

  1. ava基础MySQL存储过程 Java基础 JDBC连接MySQL数据库

    1.MySQL存储过程   1.1.什么是存储过程 带有逻辑的sql语句:带有流程控制语句(if  while)等等 的sql语句   1.2.存储过程的特点 1)执行效率非常快,存储过程是数据库的服 ...

  2. java用JDBC连接MySQL数据库的详细知识点

    想实现java用JDBC连接MySQL数据库.需要有几个准备工作: 1.下载Connector/J的库文件,下载Connector/J的官网地址:http://www.mysql.com/downlo ...

  3. Java使用JDBC连接MySQL数据库

    1.引用 JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写 ...

  4. [原创]java使用JDBC向MySQL数据库批次插入10W条数据测试效率

    使用JDBC连接MySQL数据库进行数据插入的时候,特别是大批量数据连续插入(100000),如何提高效率呢?在JDBC编程接口中Statement 有两个方法特别值得注意:通过使用addBatch( ...

  5. 【转】Java 通过JDBC连接Mysql数据库的方法和实例【图文说明】

    JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口 ...

  6. Java 通过JDBC连接Mysql数据库的方法和实例

    JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口 ...

  7. Java 通过JDBC连接Mysql数据库的方法和实例【图文说明】

    JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Java语言编写的类和接口 ...

  8. Java:jdbc连接mysql数据库

    安装eclipse和mysql的步骤这里不赘述了. 1.一定要下jar包 要想实现连接数据库,要先下载mysql-connector-java-5.1.47(或者其他版本)的jar包.低版本的jar包 ...

  9. JDBC连接mysql数据库操作详解

    1.什么是JDBC JDBC(Java Data Base Connectivity,java数据库连接)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一访问,它由一组用Jav ...

随机推荐

  1. ibm云时代的转型

    好几个月了,有两个说法很流行. 第一个说法,是老有人嚷嚷思科快被SDN整趴下了:第二个说法,是老有人嚷嚷IBM在云计算时代完全落后了,要倒下了. 刚开始我还跟有些人辩论: 1.裁员是西方企业常用的战略 ...

  2. obj-c编程03:多个参数方法的定义

    好吧,虽说本猫不能自吹精通十几种语言,但是也见过十几种语言的语法啊.像obj-c这样奇葩,或者说另类的写法还是头一次见到,完整写法我都不知道怎么起方法名了.虽说有简短写法,可和C比起来那个" ...

  3. 恶补web之八:jQuery(3)

    jquery和其他js框架.jQuery使用$作为jQuery的简写,但是还有很多js框架,比如: MooTools,Backbone,Sammy,Cappuccino,Knockout,JavaSc ...

  4. JAVA设计模式--学习总结(序)

    设计模式(Design pattern)是一套被反复使用的.代码设计经验的总结.使用设计模式是为了可重用代码.让代码更容易被他人理解.保证代码可靠性. 常见的设计模式有23种.分为三大类:创建型模式, ...

  5. LindDotNetCore~框架介绍及特色功能(有点springboot的意思)

    LindDotNetCore模块介绍 大叔博客 LindDotNetCore相关模块介绍 [x] 全局都是依赖DI [x] 消息队列 [x] NoSql [x] Caching [x] 仓储 [x] ...

  6. Pyharm中关于“warning: Debugger speedups using cython not found”问题的解决

    在终端中输入 Python "/Applications/PyCharm CE.app/Contents/helpers/pydev/setup_cython.py" build_ ...

  7. MongoDB使用过程中的一些问题

    1.MongoDB配置修改不生效的问题:今天因为某个原因,需要修改mongodb的配置文件. 改完以后,在init.d里面restart命令重启server,后来stop又start重启server. ...

  8. Triangle (第8届山东省赛的某题)

    triangle(第8届山东省赛的某题) 传送门 题意:喵了个呜,这题意真是峰回路转啊.懒死了,不想描述. 做法:我们拿set或线段树维护exp的最小值,每次取出exp值最小的边,删除之.并更新这条边 ...

  9. c#语言中的Process进程类型的使用示例

    下面我们用一个简单的例子来说明如何使用 我们用vs2015新建一个解决方案,这个解决方案包含两个WINFORM窗体项目,一个是SoftWare.Test,一个是SoftWare.Update,如下图所 ...

  10. uedit,检测粘贴事件,替换粘贴内容

    vue.editor.addListener("beforepaste",function(type, arg1, arg2){arg1.html="ddddddd&qu ...