一,基本理解
- JDBC是通过Java语言来操纵数据库的一套API
- 全称(Java DataBase Connectivity)java数据库连接
- JDBC就是一套标准接口
- 我们可以通过使用JDBC这套接口,真正执行的代码是数据库的 驱动
- 数据库的驱动就是实现类 用来实现JDBC接口, 实现了同一套Java代码,可以操作不同的数据库
- 真正执行代码的是驱动jar包中的实现类,不同的数据库都有自己的实现类 俗称驱动 。
二,实现步骤
首先创建项目,导入驱动jar包 *用什么数据库就导什么驱动 不同数据库驱动不一样
第一步:
main方法
第二步:注册驱动或叫加载数据库的驱动类
Class.formName("com.mysql.jdbc.Driver"); //遇到异常直接抛出即可
第三步:获取与数据库的连接 通过DriverManger类的静态方法 来实现,
实现后用对象接收例 conn
String url="jdbc:mysql://127.0.0.1:3306/写要连接的数据库名字";
//jdbc:mysql://127.0.0.1:3306/ 是固定格式
String username="写要连接的数据库用户名"
String password="写要连接的数据库的密码"
Connection conn =DriverManger.getConnection(url ,username,password);
第四步: 编写sql语句 并用变量接收
String sql = “sql语句”;
第五步: 获取执行sql的对象 statement 通过conn.createStatement()方法打 来获取对象
Statement stmt=conn.createStatement();
第六步:执行sql语句 通过stmt.excuteUpdate来执行
int count=stmt.executeUpdate(sql); //控制台会返回受影响的行数
第七步:处理结果 控制台输出一下
System.out.orintIn(count);
第八步:释放资源 因为先开的conn 后开的stmt
stmt.close();
conn.close();
三,代码实操
JDBC连接mysql数据库示例一:
需求说明:通过Java实现MySQL数据库的 表数据更新。 update
package com.java2.db;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class Test01 {
public static void main(String[] args) throws ClassNotFoundException, SQLException {
//注册驱动
Class.forName("com.mysql.jdbc.Driver");
//获取与数据库的连接
Connection conn= DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/epet","root","123456");
//编写sql
String sql="update pet set name='小花' where id=3";
//通过 conn.createStatement()方法 获取执行对象
Statement stmt=conn.createStatement();
//通过stmt.executeUpdate 来执行sql语句
int count=stmt.executeUpdate(sql);
//控制台输出 受影响的行数
System.out.println(count);
//关闭对象或叫释放资源
stmt.close();
conn.close();
}
}
JDBC连接mysql数据库示例二:
需求说明:通过Java实现MySQL数据库的 表数据查询。 select
package com.java2.db;
import java.sql.*;
import static java.lang.Class.forName;
/**
* jdbc连接mysql数据库示例
*/
public class DBConnertionDemo01 {
public static void main(String[]args) throws ClassNotFoundException, SQLException {
//加载数据库驱动类
Class.forName("com.mysql.jdbc.Driver");
//获取数据库连接
Connection con=DriverManager.getConnection("jdbc:mysql://localhost:3306/test",
"root","123456");
//通过连接对象con获取
Statement statement= con.createStatement();
//编写sql语句,sql的作用是查询student表的所有学生信息
String sql="select sid,sname,gender,class_id from student";
//执行sql语句,并且用ResultSet来接受查询后返回的数据
ResultSet sets=statement.executeQuery(sql);
while (sets.next()){
int sid=sets.getInt("sid");
String sname= sets.getString("sname");
String gender=sets.getString("gender");
int classid=sets.getInt("class_id");
System.out.println("学生id:"+sid+"学生姓名:"+sname
+"学生性别:"+gender+"所在班级id:"+classid);
}
con.close();
}
}
动态实现
需求说明:通过Java实现MySQL数据库的 表数据更新。 update
package com.java2.db;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class Test01 {
public static void main(String[] args) throws Exception {
updateTest2("旺财",2);
}
public static void updateTest2(String name,int id) throws Exception{
Class.forName("com.mysql.jdbc.Driver");
Connection connection=DriverManager.getConnection
("jdbc:mysql://localhost:3306/epet","root","123456");
Statement statement=connection.createStatement();
statement.execute("update pet set name='"+name+"' where id="+id+"");
connection.close();
}
}
JDBC连接mysql数据库示例三:
需求说明:通过Java实现MySQL数据库的 表数据查询。 select
public class DogDemo {
/**
* 查询每一个主人养的宠物的数量
*/
public static void main(String[] args) throws ClassNotFoundException, SQLException, IOException {
selectCount();
}
public static void selectCount() throws ClassNotFoundException, SQLException {
//连接数据库
Class.forName("com.mysql.jdbc.Driver");
Connection connection=DriverManager.getConnection
("jdbc:mysql://localhost:3306/epet","root","123456");
//编写sql
String sql="SELECT hoster.name,COUNT(pet.id) sum FROM hoster INNER JOIN pet ON
pet.hoster_id=hoster.id GROUP BY hoster.name;";
//执行sql语句
Statement statement=connection.createStatement();
ResultSet re=statement.executeQuery(sql);
System.out.println("每个主人养的宠物数量是:");
//循环 判断该表中的下一行有没有值 有就输出 没有就结束
while (re.next()){
String name= re.getString("name");
int sum=re.getInt("sum");
System.out.println(name+" "+sum);
}
}
}
JDBC连接mysql数据库示例三:
需求说明:通过Java实现MySQL数据库的 表数据新增。 insert
使用 PreparedStatement 完成
/**
* 插入宠物信息3
*/
public static void insertDog3() throws SQLException, IOException, ClassNotFoundException {
//连接数据库
Connection connection= DBUtil.getConnection();
String sql="insert into pet(name,strain)values(?,?)";
PreparedStatement preparedStatement=connection.prepareStatement(sql);
preparedStatement.setString(1,"白景瑞");
preparedStatement.setString(2,"拉布拉多");
preparedStatement.execute();
preparedStatement.close();
connection.close();
}
public class DogDemo {
public static void main(String[] args) throws ClassNotFoundException, SQLException, IOException {
insertDog3();
}
//方法
public static void insertDog3() throws SQLException, IOException, ClassNotFoundException {
//连接数据库
Connection connection= DBUtil.getConnection();
String sql="insert into pet(name,strain)values(?,?)";
PreparedStatement preparedStatement=connection.prepareStatement(sql);
preparedStatement.setString(1,"白景瑞");
preparedStatement.setString(2,"拉布拉多");
preparedStatement.execute();
preparedStatement.close();
connection.close();
}
}
四,常用方法
Statement常用方法
方法名
说 明 ResultSet executeQuery(String sql) 执行SQL查询并获取到ResultSet对象 int executeUpdate(String sql) 可以执行插入、删除、更新等操作,返回值是执行该操作所影响的行数 boolean execute(String sql) 可以执行任意SQL语句,然后获得一个布尔值,表示是否返回ResultSet
方法名 | 说 明 |
boolean next() | 将光标从当前位置向下移动一行 |
boolean previous() | 游标从当前位置向上移动一行 |
void close() | 关闭ResultSet 对象 |
int getInt(int colIndex) | 以int形式获取结果集当前行指定列号值 |
int getInt(String colLabel) | 以int形式获取结果集当前行指定列名值 |
float getFloat(int colIndex) | 以float形式获取结果集当前行指定列号值 |
float getFloat(String colLabel) | 以float形式获取结果集当前行指定列名值 |
String getString(int colIndex) | 以String 形式获取结果集当前行指定列号值 |
String getString(String colLabel) | 以String形式获取结果集当前行指定列名值 |
**小提示**
PreparedStatement 接口继承 Statement接口 PreparedStatement比普通的Statement对象使用起来更加灵活,更有效率 ,尽量使用PreparedStatement,尽量不使用Statement。