JDBC:
JDBC概念
1. 概念:Java DataBase Connectivity Java 数据库连接, Java语言操作数据库
* JDBC本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。
2. 快速入门:
* 步骤:
1. 导入驱动jar包 mysql-connector-java-5.1.37-bin.jar
1.复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下
2.右键-->Add As Library
2. 注册驱动
3. 获取数据库连接对象 Connection
4. 定义sql
5. 获取执行sql语句的对象 Statement
6. 执行sql,接受返回结果
7. 处理结果
8. 释放资源
* 代码实现: //1. 导入驱动jar包 //2.注册驱动 Class.forName("com.mysql.jdbc.Driver"); //3.获取数据库连接对象 Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db3", "root", "root"); //4.定义sql语句 String sql = "update account set balance = 500 where id = 1"; //5.获取执行sql的对象 Statement Statement stmt = conn.createStatement(); //6.执行sql int count = stmt.executeUpdate(sql); //7.处理结果 System.out.println(count); //8.释放资源 stmt.close(); conn.close();
3. 详解各个对象:
1. DriverManager:驱动管理对象
功能:
注册驱动:告诉程序该使用哪一个数据库驱动jar
获取数据库连接:
2. Connection:数据库连接对象
功能:
获取执行sql 的对象
Statement createStatement()
PreparedStatement prepareStatement(String sql)
管理事务:
* 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务
* 提交事务:commit()
* 回滚事务:rollback()
3. Statement:执行sql的对象
1. boolean execute(String sql) :可以执行任意的sql
2. int executeUpdate(String sql) :执行DML(insert、update、delete)语句、DDL(create,alter、drop)语句
返回值:影响的行数,可以通过这个影响的行数判断DML语句是否执行成功 返回值>0的则执行成功,反之,则失败。
3. ResultSet executeQuery(String sql) :执行DQL(select)语句
4. JDBC的Statement和PreparedStatement的区别
1. 最明显的区别,就是执行的sql语句格式不同。
2. ParperStatement提高了代码的灵活性和执行效率。
3. 最后但也是最重要的一个大大的比Statement好的优点,那就是安全,可以防止SQL注入!
- ResultSet:结果集对象,封装查询结果
* boolean next(): 游标向下移动一行,判断当前行是否是最后一行末尾(是否有数据),如果是,则返回false,如果不是则返回true
* getXxx(参数):获取数据
* Xxx:代表数据类型 如: int getInt() , String getString()
* 参数:
1. int:代表列的编号,从1开始 如: getString(1)
2. String:代表列名称。 如: getDouble("balance")* 注意: * 使用步骤: 1. 游标向下移动一行 2. 判断是否有数据 3. 获取数据 //循环判断游标是否是最后一行末尾。 while(rs.next()){ //获取数据 //6.2 获取数据 int id = rs.getInt(1); String name = rs.getString("name"); double balance = rs.getDouble(3); System.out.println(id + "---" + name + "---" + balance); }
原生使用JDBC
package jdbc;/* *Created by tao on 2020-03-16. */ import java.sql.Connection; import java.sql.DriverManager; import java.sql.SQLException; import java.sql.Statement; //原生使用JDBC public class test1 { private Connection conn; public static void main(String[] args) { Statement stmt = null; Connection conn = null; try { //1. 注册驱动 Class.forName("com.mysql.jdbc.Driver"); //2. 定义sql(增删改查) String sql = "insert into admin values('王五','6666')"; //3.获取Connection对象 conn = DriverManager.getConnection("jdbc:mysql:///user", "root", "root"); //4.获取执行sql的对象 Statement stmt = conn.createStatement(); //5.执行sql int count = stmt.executeUpdate(sql);//影响的行数 //6.处理结果 System.out.println(count); if (count > 0) { System.out.println("添加成功!"); } else { System.out.println("添加失败!"); } } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } finally { //stmt.close(); //7. 释放资源 //避免空指针异常 if (stmt != null) { try { stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } } }
原生使用JDBC查询操作
1. 封装admin
package domain;/* *Created by tao on 2020-03-16. */ public class Admin { private String username; private String password; public String getUsername() { return username; } public void setUsername(String username) { this.username = username; } public String getPassword() { return password; } public void setPassword(String password) { this.password = password; } }
2. 查询数据,将数据封装为admin
package jdbc;/* *Created by tao on 2020-03-16. */ import domain.Admin; import java.sql.Connection; import java.util.ArrayList; import java.util.List; import java.sql.*; //原生使用JDBC查询操作 public class select { public static void main(String[] args) { List<Admin> list = new select().findAll(); // System.out.println(list); for (Admin li : list) { System.out.println("username:" + li.getUsername() + "------ password:" + li.getPassword()); } System.out.println(list.size()); } /** * 查询所有Admin对象 * * @return */ private List<Admin> findAll() { Connection conn = null; Statement stmt = null; ResultSet rs = null; List<Admin> list = null; try { //1.注册驱动 Class.forName("com.mysql.jdbc.Driver"); //2.获取连接 conn = DriverManager.getConnection("jdbc:mysql:///user", "root", "root"); //3.定义sql String sql = "select * from Admin"; //4.获取执行sql的对象 stmt = conn.createStatement(); //5.执行sql rs = stmt.executeQuery(sql); //6.遍历结果集,封装对象,装载集合 Admin emp = null; list = new ArrayList<Admin>(); while (rs.next()) { //获取数据 String username = rs.getString("username"); String password = rs.getString("password"); // 创建emp对象,并赋值 emp = new Admin(); emp.setUsername(username); emp.setPassword(password); //装载集合 list.add(emp); } } catch (ClassNotFoundException e) { e.printStackTrace(); } catch (SQLException e) { e.printStackTrace(); } finally { if (rs != null) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } if (stmt != null) { try { stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } return list; } }
JDBC事务回滚
JDBC控制事务:
1. 事务:一个包含多个步骤的业务操作。如果这个业务操作被事务管理,则这多个步骤要么同时成功,要么同时失败。 2. 操作: 1. 开启事务 2. 提交事务 3. 回滚事务 3. 使用Connection对象来管理事务 * 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务 * 在执行sql之前开启事务 * 提交事务:commit() * 当所有sql都执行完提交事务 * 回滚事务:rollback() * 在catch中回滚事务
事务回滚小案例
package jdbc;/* *Created by tao on 2020-03-16. */ import utils.JDBCUtils; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.SQLException; /* 执行过程中报异常后,当前所有sql操作全部回滚,不执行 */ public class 事务回滚 { public static void main(String[] args) { Connection conn = null; PreparedStatement pstmt1 = null; PreparedStatement pstmt2 = null; try { //1.获取连接 conn = JDBCUtils.getConnection(); //开启事务 conn.setAutoCommit(false); //2.定义sql String sql1 = "update admin set password = ? where username = ?"; String sql2 = "update admin set password = ? where username = ?"; //3.获取执行sql对象 pstmt1 = conn.prepareStatement(sql1); pstmt2 = conn.prepareStatement(sql2); //4. 设置参数 pstmt1.setString(2, "路飞"); pstmt1.setString(1, "666"); pstmt2.setString(2, "路飞"); pstmt2.setString(1, "888"); //5.执行sql pstmt1.executeUpdate(); // 手动制造异常 int i = 3 / 0; pstmt2.executeUpdate(); //提交事务 conn.commit(); } catch (Exception e) { //事务回滚 try { if (conn != null) { conn.rollback(); } } catch (SQLException e1) { e1.printStackTrace(); } e.printStackTrace(); } finally { JDBCUtils.close(pstmt1, conn); JDBCUtils.close(pstmt2, null); } } }
结果如下
登录小案例
package jdbc;/* *Created by tao on 2020-03-16. */ import java.sql.*; import java.util.Scanner; /** * 登录练习: * * 需求: * 1. 通过键盘录入用户名和密码 * 2. 判断用户是否登录成功 * * JDBC的Statement和PreparedStatement的区别 * 1. 最明显的区别,就是执行的sql语句格式不同。 * 2. ParperStatement提高了代码的灵活性和执行效率。 * 3. 最后但也是最重要的一个大大的比Statement好的优点,那就是安全,可以防止SQL注入! */ public class login { public static void main(String[] args) { //1.键盘录入,接受用户名和密码 Scanner sc = new Scanner(System.in); System.out.println("请输入用户名:"); String username = sc.nextLine(); System.out.println("请输入密码:"); String password = sc.nextLine(); //2.调用方法 boolean flag = new login().loginFlag1(username, password); //3.判断结果,输出不同语句 if (flag) { //登录成功 System.out.println("登录成功!"); } else { System.out.println("用户名或密码错误!"); } } /** * 登录方法,使用PreparedStatement实现 */ public boolean loginFlag1(String username, String password) { if (username == null || password == null) { return false; } //连接数据库判断是否登录成功 Connection conn = null; PreparedStatement pstmt = null; ResultSet rs = null; //1.获取连接 try { conn = DriverManager.getConnection("jdbc:mysql:///user", "root", "root"); //2.定义sql String sql = "select * from admin where username = ? and password = ?"; //3.获取执行sql的对象 pstmt = conn.prepareStatement(sql); //给每一个?赋值 pstmt.setString(1, username); pstmt.setString(2, password); //4.执行查询,不需要传递sql System.out.println(sql); rs = pstmt.executeQuery(); return rs.next();//如果有下一行,则返回true } catch (SQLException e) { e.printStackTrace(); } finally { if (rs != null) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } if (pstmt != null) { try { pstmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } return false; } /** * 登录方法,使用Statement实现 */ public boolean loginFlag2(String username ,String password){ if(username == null || password == null){ return false; } //连接数据库判断是否登录成功 Connection conn = null; Statement stmt = null; ResultSet rs = null; //1.获取连接 try { conn = DriverManager.getConnection("jdbc:mysql:///user", "root", "root"); //2.定义sql String sql = "select * from admin where username = '"+username+"' and password = '"+password+"' "; System.out.println(sql); //3.获取执行sql的对象 stmt = conn.createStatement(); //4.执行查询 rs = stmt.executeQuery(sql); //5.判断 return rs.next();//如果有下一行,则返回true } catch (SQLException e) { e.printStackTrace(); }finally { if (rs != null) { try { rs.close(); } catch (SQLException e) { e.printStackTrace(); } } if (stmt != null) { try { stmt.close(); } catch (SQLException e) { e.printStackTrace(); } } if (conn != null) { try { conn.close(); } catch (SQLException e) { e.printStackTrace(); } } } return false; } }
需要导入的系列jar包
点击下载
链接:https://pan.baidu.com/s/1xxcnFezaL7rVYf7KQyMahQ
提取码:x9lc