使用JDBC操作MySQL数据库
一、JDBC简介
JDBC(Java DataBase Connectivity)是一种用于执行SQL语句的Java API,可以为多种关系数据库提供统一的访问,它由一组用Java语言编写的类和接口组成。使用JDBC访问数据库的基本步骤如下:
1、加载JDBC驱动程序
2、建立数据库连接
3、创建操作数据库SQL的对象
4、执行语句并分析执行结果
5、关闭连接
在使用JDBC操作数据库之前,我们需要先向项目中加入JDBC驱动文件,将其放到项目中的lib文件夹下即可。

放入JDBC驱动文件(下)后,eclipse会自动将其加载到项目中(上)。
二、使用JDBC访问MySQL数据库
我们在MySQL数据库中建立了test库,test库中含有test表,表中的数据如下:

1、通过Statement对象执行静态SQL语句
package test;
import java.sql.*; //导入Java提供的数据库操作包
public class MySql {
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3306/test?serverTimezone=Asia/Shanghai"; //数据库连接地址,此处表示连接本机3306端口的MySQL数据库里的test库,使用上海时区
Connection con;
Statement statement;
ResultSet rs;
int i;
String string;
try {
Class.forName("com.mysql.cj.jdbc.Driver"); //加载JDBC驱动程序
con = DriverManager.getConnection(url, "root", "root"); //建立与数据库的连接,后两个参数分别为账号和密码
statement = con.createStatement(); //创建Statement对象
rs = statement.executeQuery("select * from test"); //执行sql查询语句,返回结果集
System.out.println("查询结果为:");
while(rs.next()) { //循环操作结果集
string = rs.getString("id") + "——" + rs.getString("name");
System.out.println(string);
}
i = statement.executeUpdate("insert into test value(4,'wxc')"); //执行sql更新语句,返回影响行数
System.out.println("影响行数为:" + i);
rs.close(); //关闭结果集
statement.close(); //关闭Statement对象
con.close(); //关闭与数据库的连接
} catch (Exception e) {
e.printStackTrace();
}
}
}
执行结果如下:

2、通过PreparedStatement对象执行预编译SQL语句
public class MySql { //大部分操作与执行静态SQL语句类似,相同部分此处不再赘述
public static void main(String[] args) {
String url = "jdbc:mysql://localhost:3306/test?serverTimezone=Asia/Shanghai";
Connection con;
String sql;
PreparedStatement preparedStatement;
ResultSet rs;
int i;
String string;
try {
Class.forName("com.mysql.cj.jdbc.Driver");
con = DriverManager.getConnection(url, "root", "root");
sql = "select * from test where id = ?"; //编写sql查询语句,问号为占位符,之后会被参数取代
preparedStatement = con.prepareStatement(sql); //创建PreparedStatement对象
preparedStatement.setString(1, "3"); //设置参数,第一个参数表示选择第几个占位符,第二个参数表示要输入的值
rs = preparedStatement.executeQuery();
System.out.println("查询结果为:");
if(rs.next()) {
string = rs.getString("id") + "——" + rs.getString("name");
System.out.println(string);
}
sql = "delete from test where id = ?";
preparedStatement = con.prepareStatement(sql);
preparedStatement.setString(1, "3");
i = preparedStatement.executeUpdate();
System.out.println("影响行数为:" + i);
rs.close();
preparedStatement.close();
con.close();
} catch (Exception e) {
e.printStackTrace();
}
}
}
执行结果如下:

使用JDBC操作MySQL数据库的更多相关文章
- JDBC操作MySQL数据库案例
JDBC操作MySQL数据库案例 import java.sql.Connection; import java.sql.DriverManager; import java.sql.Prepared ...
- Java使用Jdbc操作MySql数据库(一)
这个示例是Java操作MySql的基本方法. 在这个示例之前,要安装好MySql,并且配置好账户密码,创建一个logininfo数据库,在数据库中创建userinfo数据表.并且在表中添加示例数据. ...
- 原生Jdbc操作Mysql数据库开发步骤
原生Jdbc操作Mysql数据库开发步骤 原生的Jdbc就是指,不使用任何框架,仅用java.sql包下的方法实现数据库查询等的操作. 下面是开发步骤: 1.导入数据库驱动包 ...
- java数据库 JDBC操作MySQL数据库常用API 部门表和员工表 创建表 添加数据 查询数据
package com.swift.department; import java.sql.Connection; import java.sql.PreparedStatement; import ...
- JavaWeb用Jdbc操作MySql数据库(一)
一.添加开发包.在JavaWeb中用jdbc操作数据库,使用方法与java一样,但是在处理开发包的问题上有点差别.JavaWeb不能将mysql-connector-java-5.1.7-bin.ja ...
- 原生jdbc操作mysql数据库详解
首先给大家说一下使用JDBC链接数据库的步骤 1.加载链接数据库驱动 2.建立数据库链接 3.创建数据库操作对象 4.编写sql语句,执行sql语句 5.获取结果集 6.释放资源 我这边采用的是mav ...
- Java学习笔记(十一)——通过JDBC操作mysql数据库
[前面的话] 时间总是好快,每次都感觉还没有怎么好好去过,对于好多事情,希望自己可以做的更多一点.心情能够好一点,平淡一点就行了. 学习过程中的知识点总结,基础知识,选择阅读. [JDBC定义] 定义 ...
- Java第三十五天,用JDBC操作MySQL数据库(一),基础入门
一.JDBC的概念 Java DataBase Connectivity 从字面意思我们也不难理解,就是用Java语言连接数据库的意思 JDBC定义了Java语言操作所有关系型数据库的规则(接口).即 ...
- JavaEE系列之(三)JDBC操作MySQL数据库
一.JDBC简介 JDBC(Java Data Base Connectivity)java数据库连接 SUN公司为了简化.统一对数据库的操作,定义了一套Java操作数据库 ...
随机推荐
- 原生 JavaScript 实现扫雷
学习了这么长时间的 JS,不能光看不练,于是就写了个小游戏练习一下.因为自己还是个菜鸟,所以有错误的话还请各位大佬多多指点,谢谢啦~ 如果感兴趣的话可以试试:Demo 项目地址:game-mineSw ...
- VMware Workstation 的安装和使用
https://blog.csdn.net/lamp_yang_3533/article/details/53136474 VMware Workstation 是一个虚拟PC的软件,利用VMwa ...
- Java操作Memcached
本文复制其他播客,有好的技术文章希望各位大神能告知... 谢谢. 如何使用Java操作Memcached实例: 代码一: package com.ghj.packageoftool; import j ...
- SSM-SpringMVC-31:SpringMVC中利用hibernate-validator做后台校验
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 校验有三种:前台页面校验(例如js和h5),后台校验,数据库校验 但是一般能不用数据库校验就不用数据库校验,因 ...
- 如何在js或者jquery中操作EL表达式的一个List集合
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 先说明此篇博客看明白了可以干嘛: 就是在js或者jquery中操作一个EL表达式的一个list集合或者复杂类型 ...
- C#中DataGridView 对XML文档的使用
窗体就只用添加一个DataGridView控件就可以了.详细解释请参照上一篇中的借鉴曲终人散博客园的文档. XML文档代码如下:test.xml <?xml version="1.0& ...
- 解决openfire中发送某些特殊字符会断开xmpp连接的问题
在openfire中,如果发送某些特殊的字符(例如一些表情符合),会断开xmpp的连接,经查,是由以下的代码问题引起的: src\java\org\jivesoftware\openfire\net\ ...
- 理解Python中的yield
1.通常的for...in...循环中,in后面是一个数组,这个数组就是一个可迭代对象,类似的还有链表,字符串,文件.它可以是mylist = [1, 2, 3],也可以是mylist = [x*x ...
- [Python]range与xrange用法对比
[整理内容]具体如下: 先来看如下示例:>>>x=xrange(0,8)>>> print xxrange(8)>>>print x[0]0> ...
- python之@property
在绑定属性时,如果我们直接把属性暴露出去,虽然写起来很简单,但是,没办法检查参数,导致可以把成绩随便改: s = Student() s.score = 9999 这显然不合逻辑.为了限制score的 ...