JDBC自学笔记001_Real

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();
                }
            }
        }
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

仲子_real

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值