JDBC是java语言操作关系型数据的一套API.
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
/**
* JDBC 快速入门
*/
public class JDBCdemo {
public static void main(String[] args) throws SQLException {
//1. 注册驱动,MySQL 5之后的驱动包,可以省略注册驱动的步骤
//jar包中META-INF/services/java.sql.Driver文件中的驱动类
//Class.forName("com.mysql.jdbc.Driver");
//2. 获取连接
String url = "jdbc:mysql://127.0.0.1:3306/db1";
String username = "root";
String password = "1234";
Connection conn = DriverManager.getConnection(url, username, password);
//3. 定义sql
String sql = "update account set money = 2000 where id = 1";
//4. 获取执行sql的对象 Statement
Statement stmt = conn.createStatement();
//5. 执行sql
int count = stmt.executeUpdate(sql);//受影响的行数
//6. 处理结果
System.out.println(count);
//7. 释放资源
stmt.close();
conn.close();
}
}
DriverManager(驱动管理类)作用:注册驱动和获取数据库连接
Class.forName("com.mysql.jdbc.Driver");
//url : 连接路径 -> jdbc:mysql://ip地址(域名):端口号/数据库名称?参数键值对1&参数键值对2…
//user :用户名
//poassword :密码
DriverManager.getConnection(url, username, password);
Connection(数据库连接对象)作用:获取执行 SQL 的对象、管理事务
conn.createStatement()
//1.开启事务 : BEGIN; 或者 START TRANSACTION;
setAutoCommit(bool) //表示是否自动提交事务,true表示自动提交事务,false表示手动提交事务。
//2.提交事务 : COMMIT; //MySQL默认是自动提交事务
commit()//程序运行到此处,说明没有出现任何问题,则需求提交事务
//3.回滚事务 : ROLLBACK;
rollback()//程序在出现异常时会执行到这个地方,此时就需要回滚事务
示例代码,执行DML语句:
package com.itheima.jdbc;
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;
public class JDBCdemo {
public static void main(String[] args) throws SQLException {
//1. 注册驱动
//Class.forName("com.mysql.jdbc.Driver");
//2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
//useSSL=false 配置 useSSL=false 参数,禁用安全连接方式,解决警告提示
String url = "jdbc:mysql:///db1?useSSL=false";
String username = "root";
String password = "1234";
Connection conn = DriverManager.getConnection(url, username, password);
//3. 定义sql
String sql1 = "update account set money = 3000 where id = 1";
String sql2 = "update account set money = 3000 where id = 2";
//4. 获取执行sql的对象 Statement
Statement stmt = conn.createStatement();
try {
//开启事务
conn.setAutoCommit(false);
//5. 执行sql
int count1 = stmt.executeUpdate(sql1);//受影响的行数
//6. 处理结果
System.out.println(count1);
//int i = 3/0; //人为添加异常
//5. 执行sql
int count2 = stmt.executeUpdate(sql2);//受影响的行数
//6. 处理结果
System.out.println(count2);
// 提交事务
conn.commit();
} catch (Exception e) {
// 异常回滚事务
conn.rollback();
e.printStackTrace();
}
//7. 释放资源
stmt.close();
conn.close();
}
}
ResultSet(结果集对象)作用:封装了SQL查询语句的结果。
executeQuery(sql)//执行DQL 语句,返回 ResultSet 对象
//ResultSet 对象中获取我们想要的数据
getXxx(参数)//获取数据如: int getInt(参数) ;String getString(参数)
next()//判断当前行是否为有效行
代码实现:
package com.itheima.jdbc;
import pojo.Account;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
public class JDBCdemo {
public static void main(String[] args) throws SQLException {
//1. 注册驱动
//Class.forName("com.mysql.jdbc.Driver");
//2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
String url = "jdbc:mysql:///db1?useSSL=false";
String username = "root";
String password = "1234";
Connection conn = DriverManager.getConnection(url, username, password);
//3. 定义sql
String sql1 = "SELECT * FROM `account`";
String sql2 = "insert into account(name,money) values('XX',40000)";
//4. 获取statement对象
Statement stmt = conn.createStatement();
//5. 执行sql
int rs2 = stmt.executeUpdate(sql2);
ResultSet rs1 = stmt.executeQuery(sql1);
List<Account> accounts = new ArrayList<Account>();
//6. 处理结果, 遍历rs中的所有数据
// 6.1 光标向下移动一行,并且判断当前行是否有数据
//注:查询时先执行其它数据操作再进行查询,不然游标会停留在最后的的位置处导致循环终止
while (rs1.next()){
//6.2 获取数据 getXxx()
int id = rs1.getInt("id");
String name = rs1.getString("name");
double money = rs1.getDouble("money");
Account account1 = new Account();
account1.setId(id);
account1.setMoney(money);
account1.setName(name);
System.out.println(id);
System.out.println(name);
System.out.println(money);
System.out.println("--------------");
accounts.add(account1);
}
System.out.println(accounts);
//7. 释放资源
rs1.close();
stmt.close();
conn.close();
}
}
Account类:
package pojo;
public class Account {
private int id;
public void setId(int id) {
this.id = id;
}
public void setName(String name) {
this.name = name;
}
public void setMoney(double money) {
this.money = money;
}
private String name;
private double money;
public int getId() {
return id;
}
public String getName() {
return name;
}
public double getMoney() {
return money;
}
}
Statement对象的作用就是用来执行SQL语句。而针对不同类型的SQL语句使用的方法也不一样。
对于DDL和DML使用executeUpdate(),对于DQL使用executeQuery()。
代码实现:
public static void testDML1() throws SQLException {
String url = "jdbc:mysql:///db1?useSSL=false";
String username = "root";
String password = "1234";
Connection conn = DriverManager.getConnection(url,username,password);
String sql0 = "update account set money = 10000 where id = 1 ";
String sql1 = "SELECT * FROM `account`";
Statement stmt = conn.createStatement();
int count =stmt.executeUpdate(sql0);
ResultSet rs = stmt.executeQuery(sql1);
if (count>0){
System.out.println("修改成功!");
}else{
System.out.println("修改失败!");
}
if (rs.next()){
System.out.println("查询成功!");
}else{
System.out.println("查询失败!");
}
}
预编译SQL语句并执行:预防SQL注入问题
PreparedStatement对象:setXxx(问号位置,参数)
也可以使用敏感字符进行转义防止SQL注入问题。
代码示例:
public static void testlogin1() throws SQLException {
//2. 获取连接:如果连接的是本机mysql并且端口是默认的 3306 可以简化书写
String url = "jdbc:mysql:///db1?useSSL=false";
String username = "root";
String password = "1234";
Connection conn = DriverManager.getConnection(url, username, password);
// 接收用户输入 用户名和密码
//错误密码,预防SQL注入问题
//String name = "zhangsan";
//String pwd = "' or '1' = '1";
//正常登录
String name = "zhangsan";
String pwd = "123";
// 定义sql
String sql = "select * from tb_user where username = ? and password = ?";
// 获取pstmt对象,预防SQL注入问题
PreparedStatement pstmt = conn.prepareStatement(sql);
// 设置?的值
pstmt.setString(1,name);
pstmt.setString(2,pwd);
// 执行sql,不需要SQL语句
ResultSet rs = pstmt.executeQuery();
// 判断登录是否成功
if(rs.next()){
System.out.println("登录成功!");
}else{
System.out.println("登录失败!");
}
//7. 释放资源
rs.close();
pstmt.close();
conn.close();
}
自学javaweb中所记录的课程笔记,记录学习过程。
参考资料:https://www.bilibili.com/video/BV1Qf4y1T7Hx?p=8&vd_source=c17a6596481e29f0ffac1a21a026abff
欢迎关注公众号【智能建造小硕】(分享计算机编程、人工智能、智能建造、日常学习、科研和写作经验等,欢迎大家关注交流。)