JDBC自学笔记001_Real
一、基本概述
JDBC:Java Data Base Connection(Java语言连接数据库)
数据的持久化:
数据的持久化:把数据保存到可掉电式存储设备中心以供之后使用,大多数情况下,特别是企业级应用,数据持久化意味着将内存中的数据保存到硬盘上加以固化,而持久化的实现过程大多数通过各种关系数据库来完成。
持久化的主要应用是将内存中的数据存储到关系型数据库中,当然也可以存储到磁盘文件,XML数据文件中。
JDBC的本质是什么?
JDBC是SUN公司指定的一套接口(interface)
接口都有调用者和实现者。
接面向接口调用、面向接口写实现类,这都属于面向接口编程
为什么要面向接口编程?
解耦合:降低程序的讴歌都,提高程序的拓展能力 。
多态机制就是非常典型的:面向抽象编程
建议:
Animal a = new Cat();
Animal a = new Dog();
不建议:
Dog d = new Dog();
Cat c = new Cat();
二、JDBC之前的准备工作
先从官网上下载对应的驱动jar包,然后将其配置到环境变量classpath中去
用IDEA的图形化界面就比较简单
三、JDBC编程的步骤
1、注册驱动
告诉Java程序,即将要链接的是那个品牌的数据库
2、获取链接
表示JVM的进程和数据进程之间的通道打开了,这属于进程之间的通信,重量级别的,使用完之后一定要关闭
3、获取数据库操作对象
准们执行sql语句的对象
4、执行SQL语句
DQL DML
5、处理查询结果
只有当第四步执行的是Select语句的时候,才有第五步处理查询结果的步骤
6、释放资源
使用完资源中后一定要关闭资源,Java和数据库属于进程之间的通信,开启后一定需要关闭。
/*
JDBC编程的六个步骤
*/
import java.sql.Driver;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Connection;
import java.sql.Statement;
public class JDBCTest01{
public static void main(string[] args){
Statement stmt = null;
Connection conn = null;
//1、注册驱动
try{
Driver driver= new com.mnysql.jdbc.Driver();
DriverManager.registerDriver(driver); //多态,父类型引用指向子类对象
//2、获取链接
String url = "jdbc:mysql://127.0.0.1:3306/rapiddesignsystemdatabase";
/*
jdbc:mysql 协议
127.0.0.1 IP地址
3306 端口号
rapiddesignsystemdatabase 要链接的数据库名
*/
String uesr = "root";
String password = "123456";
conn = DriverManager.getConnection(url, user, password);
//3、获取数据库操作对象(Statement 专门执行SQL语句)
stmt = conn.createStatement();
//4、执行sql
String sql = "insert into t_admin(id, password) values (admin2, 135692)";
//准们,嗯执行DML语句的(insert delete update)
//返回值是“影响数据库中的记录条数”
int count = stmt.executeUpdate(sql);
System.out.ptintln(count == 1 ? "保存成功": "保存失败");
//5、处理查询结果
}catch(SQLException e){
e.printStackTrace();
}finally{
//6、释放资源
//为了保证资源的一定会释放,再finally语句中关闭资源
//并且要遵循从小到大一次关闭
//一定要分别对其进行try..catch
if(stml != null){
try{
stmt.close();
}catch(SQLException e){
e.printStackTrace();
}
}
if(conn != null){
try{
conn.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}
}
}
注册驱动的第二种方式,最常用的方式
/*
注册驱动的另一种方式(这种方式最常用,利用反射机制)
*/
import java.sql.*;
public class JDBCTest02{
public static void main(String[] args){
try{
//注册驱动
//这是注册驱动的第一种写法
//DriverManager.registerDriver(new com.mysql.cj.jdbc.Driver());
//注册驱动的第二种方式,最常用的,最重要的
//为社么那么腰用这种方式,是因为参数是一个字符串,,字符串可以写道xxx.properties文件中去
//以下方法不需要接收返回值,因为我们只想用它的类加载动作
Class.forName("com.mysql.cj.jdbc.Driver"); //利用反射
//2、获取链接
Connection conn = DriverManager.getConnection("jdbc:mysql://127.0.0.1:3306/rapiddesignsystemdatabase");
System.out.println(conn);
}catch(SQLException e){
e.printStackTrace();
}catch(ClassNotFoundException e){
e.printStackTrace();
}
}
}
从属性资源文件中读取连接数据库信息
首先主程序文件路径下新建jdbc.properties文件如图所示:
然后用文本文件的方式打开文件jdbc.propreties输入相应的信息
然后编写相应的程序代码
import java.*;
import java.until.*;
public class JDBCTest03{
public static void main(string[] args){
//使用资源帮顶起绑定属性配置文件
ResourceBundle bundle = ResourceBundle.getBundle("jdbc");
String driver = bundle.getString("driver");
String url = bundle.getString("url");
String user = bundle.getString("user");
String password = bundle.getString("password");
Statement stmt = null;
Connection conn = null;
try{
//1、注册驱动
Class.forName(driver);
//2、获取链接
conn = DriverManager.getConnection(url, user, password);
//3、获取数据库操作对象(Statement 专门执行SQL语句)
stmt = conn.createStatement();
//4、执行sql
String sql = "insert into t_admin(id, password) values ('admin2', '135692')";
//准们,嗯执行DML语句的(insert delete update)
//返回值是“影响数据库中的记录条数”
int count = stmt.executeUpdate(sql);
System.out.println(count == 1 ? "保存成功": "保存失败");
//5、处理查询结果
}catch(SQLException e){
e.printStackTrace();
}finally{
//6、释放资源
//为了保证资源的一定会释放,再finally语句中关闭资源
//并且要遵循从小到大一次关闭
//一定要分别对其进行try..catch
if(stml != null){
try{
stmt.close();
}catch(SQLException e){
e.printStackTrace();
}
}
if(conn != null){
try{
conn.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}
}
}
处理查询后的结果
package com.bjpowernode.jdbc;
import java.sql.*;
public class JDBCTest06 {
public static void main(String[] args) {
Connection conn = null;
Statement stmt = null;
ResultSet rs = null; //select语句得到的结果集
String url = "jdbc:mysql://127.0.0.1:3306/rapiddesignsystemdatabase";
String user = "root";
String password = "123456";
try {
Class.forName("com.mysql.cj.jdbc.Driver");
conn = DriverManager.getConnection(url, user, password);
stmt = conn.createStatement();
String sql = "select * from t_admin";
rs = stmt.executeQuery(sql); //专门执行DQL语句的方法
while(rs.next()){
String id = rs.getString(1); //JDBC所有的下表都从1开始
String name = rs.getString(2);
String psd = rs.getString(3);
System.out.println(id + ", " + name + ", " + psd);
}
} catch (Exception e) {
e.printStackTrace();
}finally {
if(stmt != null){
try{
stmt.close();
}catch(SQLException e){
e.printStackTrace();
}
}
if(conn != null){
try{
conn.close();
}catch(SQLException e){
e.printStackTrace();
}
}
}
}
}