目录
1.数据库驱动
驱动:声卡、显卡、数据库
我们的程序会通过 数据库 驱动 和数据库打交道
2.JDBC
SUN公司为了简化开发人员的(对数据库的统一)操作,提供了一个(java操作数据库的)规范,俗称JDBC,这些规范的实现由具体的厂商去做,如MySQL的规范MySQL的厂商指定等
3.编列第一个JDBC程序
1.创建一个普通java项目
太过于简单,这里就不演示了
2.创建数据库
新建一个数据库
CREATE DATABASE jdbcStudy CHARACTER SET utf8 COLLATE utf8_general_ci;
新建表插入数据
CREATE TABLE users(
id INT PRIMARY KEY,
`name` VARCHAR(40),
`password` VARCHAR(40),
email VARCHAR(60),
birthday DATE
);
INSERT INTO users(id,`name`,`password`,email,birthday)
VALUES(1,'张三','123456','zs@qq.com','2000-01-01');
INSERT INTO users(id,`name`,`password`,email,birthday)
VALUES(2,'李四','123456','ls@qq.com','2000-01-01');
INSERT INTO users(id,`name`,`password`,email,birthday)
VALUES(3,'王五','123456','ww@qq.com','2000-01-01');
SELECT * FROM users;
导入jar包
3.编写测试代码
步骤总结:
- 加载驱动
- 连接数据库,代表数据库
- 向数据库发送SQL的对象Statement : CRUD
- 编写SQL (根据业务,不同的SQL)
- 执行SQL
- 关闭连接(先开的后关)
package JDBC;
import java.sql.*;
//我的第一个JDBC程序
public class JdbcFirstDemo1 {
public static void main(String[] args) throws Exception {
//1.用户信息和url characterEncoding=utf-8:utf8字符集编码 useUnicode=true:支持中文 useSSL=false:是否使用安全链接
//mysql8.0需要加时区
String url = "jdbc:mysql://localhost:3306/jdbcstudy?characterEncoding=utf-8&useSSL=false&useUnicode=true";
String username="root";
String password="******";//这里使用自己密码
//2.加载驱动 mysql 8.0需要加cj com.mysql.cj.jdbc.Driver
Class.forName("com.mysql.jdbc.Driver");//固定写法 加载驱动
//3.连接数据库对象 Connection代表数据库
Connection connection = DriverManager.getConnection(url, username, password);
//4.执行sql的对象 Statement 执行SQL的对象
Statement statement = connection.createStatement();
//5.执行sql的对象 执行sql 可能存在结果,查看返回结果
String sql="SELECT * FROM users";
ResultSet resultSet = statement.executeQuery(sql);//返回的结果集,结果接种封装了我们全部查询出来的结果
while (resultSet.next()){
System.out.println("id=" + resultSet.getObject("id"));
System.out.println("name=" + resultSet.getObject("NAME"));
System.out.println("pwd=" + resultSet.getObject("PASSWORD"));
System.out.println("email=" + resultSet.getObject("email"));
System.out.println("birth=" + resultSet.getObject("birthday"));
}
//6.释放链接
resultSet.close();
statement.close();
connection.close();
}
}
1.DriverManager
//DriverManager.registerDriver(new com.mysql.jdbc.Driver());//源码
Class.forName("com.mysql.jdbc.Driver");//固定写法 加载驱动
Connection connection = DriverManager.getConnection(url, username, password);
//connection 代表数据库 可以有以下操作
//数据库设置自动提交
//事务提交
//事务回滚
connection.rollback();//回滚
connection.commit();//提交
connection.setAutoCommit(boolean b);//自动提交 ture/false
2.URL
String url = "jdbc:mysql://localhost:3306/jdbcstudy?characterEncoding=utf-8&useSSL=false&useUnicode=true";
//jdbc:mysql://主机地址:端口号/数据库名?参数1&参数2&参数3;
//mysql默认端口号3306 oralce默认端口号1521
//jdbc:mysql://localhost:3306/数据库名?参数1&参数2&参数3;
//如果在本机上可以直接jdbc:mysql:///数据库名?参数1&参数2&参数3; linux不可以这样操作
3.Statement
Statement 执行SQL的对象 PrepareStatement 执行SQL的对象
statement.executeQuery();//执行查询语句 返回resultSet:结果集
statement.execute();//执行任何SQL语句
statement.executeUpdate();//更新、插入、删除都使用这个,返回匹配到的行数
4.ResultSet
查询的结果集:封装了所有的查询结果
获得指定数据类型
resultSet.getObject();//在不知道列类型的情况下使用Object
//如果知道列类型就使用指定的类型
resultSet.getString();
resultSet.getInt();
resultSet.getFloat();
resultSet.getDate();
...
遍历
resultSet.beforeFirst();//移动到最前面
resultSet.afterLast();//移动到最后面
resultSet.next();//移动到下一个数据
resultSet.previous();//移动到前一行
resultSet.absolute(row);//移动到指定行
5.释放资源
resultSet.close();
statement.close();
connection.close();
4.Statement对象
Jdbc中的statement对象用于向数据库发送SQL语句,想完成对数据库的增删改查,只需要通过这个对象向数据库发送增删改查语句即可。
Statement对象的executeUpdate方法,用于向