JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】

  • 黑马程序员-JDBC文档(腾讯微云)JDBC笔记.pdf:https://share.weiyun.com/Kxy7LmRm
  1. JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】
  2. JDBC学习笔记02【ResultSet类详解、JDBC登录案例练习、PreparedStatement类详解】
  3. JDBC学习笔记03【JDBC事务管理、数据库连接池、JDBCTemplate】

目录

01 JDBC快速入门

今日内容

JDBC_概念

JDBC_快速入门

驱动jar包解析

IntelliJ IDEA 2017.3.4 x64 新建项目、新建模块

Idea 新建包 不分级 解决方法

将 MySQL驱动jar包 添加到 Idea项目 中

Idea 连接 MySQL数据库 代码

02 JDBC各个类详解

Idea 导入 项目

JDBC各个类详解_DriverManager

JDBC各个类详解_DriverManager

DriverManager 获取数据库连接

JDBC各个类详解_Connection

获取执行sql的对象

管理事务

JDBC各个类详解_Statement

03 JDBC之CRUD练习

JDBC练习_insert语句

account表 添加一条记录

JDBC练习_update语句

account表 修改记录

JDBC练习_update、DDL语句

account表 删除一条记录

执行DDL语句


 

01 JDBC快速入门

今日内容

  1. JDBC基本概念
  2. 快速入门
  3. 对JDBC中各个接口和类详解

JDBC_概念

1. 概念:Java DataBase Connectivity  Java 数据库连接, Java语言操作数据库
    * JDBC本质:其实是官方(sun公司)定义的一套操作所有关系型数据库的规则,即接口。各个数据库厂商去实现这套接口,提供数据库驱动jar包。我们可以使用这套接口(JDBC)编程,真正执行的代码是驱动jar包中的实现类。

  • Person 接口:eat()方法   Worker实现类      Person p = new Worker(); // 父类引用指向子类对象
  • p.eat(); // 会调用Worker()实现类的eat方法,产生多态调用
  • JDBC编程,以接口类型调用方法。导入驱动jar包后,真正执行的是驱动jar包实现类对应的实现方法

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第1张图片

JDBC_快速入门

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();

驱动jar包解析

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第2张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第3张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第4张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第5张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第6张图片

IntelliJ IDEA 2017.3.4 x64 新建项目、新建模块

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第7张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第8张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第9张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第10张图片

新建模块

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第11张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第12张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第13张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第14张图片

Idea 新建包 不分级 解决方法

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第15张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第16张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第17张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第18张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第19张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第20张图片

将 MySQL驱动jar包 添加到 Idea项目 中

导入驱动jar包 mysql-connector-java-5.1.37-bin.jar
            1.复制mysql-connector-java-5.1.37-bin.jar到项目的libs目录下
            2.右键-->Add As Library

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第21张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第22张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第23张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第24张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第25张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第26张图片

Idea 连接 MySQL数据库 代码

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第27张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第28张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第29张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第30张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第31张图片

运行文件JdbcDemo1.java文件,出现如下信息(百度查了一下,可能电脑内存不够...),重新点击运行按钮,又好了。

# There is insufficient memory for the Java Runtime Environment to continue.
# Native memory allocation (malloc) failed to allocate 1048576 bytes for AllocateHeap
# An error report file with more information is saved as:
# F:\JetBrains\1ideaSpace\itcast\hs_err_pid2904.log

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第32张图片

package cn.itcast.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.Statement;

/**
 * JDBC快速入门
 */
public class JdbcDemo1 {
    public static void main(String[] args) throws Exception {
        //1.导入驱动jar包
        //2.注册驱动
        Class.forName("com.mysql.jdbc.Driver"); // 把类通过Class.forName()加载进内存
        //3.获取数据库连接对象
        Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/db3", "root", "root");
        //4.定义sql语句
        String sql = "update account set balance = 2000 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();
    }
}

02 JDBC各个类详解

Idea 导入 项目

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第33张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第34张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第35张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第36张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第37张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第38张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第39张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第40张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第41张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第42张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第43张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第44张图片

JDBC各个类详解_DriverManager

3. 详解各个对象:
    1. DriverManager:驱动管理对象
        * 功能:
            1. 注册驱动:告诉程序该使用哪一个数据库驱动jar包
                static void registerDriver(Driver driver) :注册与给定的驱动程序 DriverManager 。 
                写代码使用:  Class.forName("com.mysql.jdbc.Driver");
                通过查看源码发现:在com.mysql.jdbc.Driver类中存在静态代码块
                 static {
                        try {
                            java.sql.DriverManager.registerDriver(new Driver());
                        } catch (SQLException E) {
                            throw new RuntimeException("Can't register driver!");
                        }
                    }

                注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。
            2. 获取数据库连接

    2. Connection:数据库连接对象

    3. Statement:执行sql的对象

    4. ResultSet:结果集对象,封装查询结果

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第45张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第46张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第47张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第48张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第49张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第50张图片

JDBC各个类详解_DriverManager

3. 详解各个对象:
    1. DriverManager:驱动管理对象
        * 功能:
            1. 注册驱动:告诉程序该使用哪一个数据库驱动jar包
                static void registerDriver(Driver driver) :注册与给定的驱动程序 DriverManager 。 
                写代码使用:  Class.forName("com.mysql.jdbc.Driver");
                通过查看源码发现:在com.mysql.jdbc.Driver类中存在静态代码块
                 static {
                        try {
                            java.sql.DriverManager.registerDriver(new Driver());
                        } catch (SQLException E) {
                            throw new RuntimeException("Can't register driver!");
                        }
                    }

                注意:mysql5之后的驱动jar包可以省略注册驱动的步骤。
            2. 获取数据库连接:
                * 方法:static Connection getConnection(String url, String user, String password) 
                * 参数:
                    * url:指定连接的路径
                        * 语法:jdbc:mysql://ip地址(域名):端口号/数据库名称
                        * 例子:jdbc:mysql://localhost:3306/db3
                        * 细节:如果连接的是本机mysql服务器,并且mysql服务默认端口是3306,则url可以简写为:jdbc:mysql:///数据库名称
                    * user:用户名
                    * password:密码

DriverManager 获取数据库连接

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第51张图片

jdbc:mysql://ip地址(域名):端口号/数据库名称,端口号:找到计算机上安装的MySQL服务器。

JDBC各个类详解_Connection

    2. Connection:数据库连接对象(代表了当前代码和数据库之间的桥梁)。
        1. 功能:
            1. 获取执行sql 的对象
                * Statement createStatement()
                * PreparedStatement prepareStatement(String sql)  
            2. 管理事务:
                * 开启事务:setAutoCommit(boolean autoCommit) :调用该方法设置参数为false,即开启事务
                * 提交事务:commit() 
                * 回滚事务:rollback() 

获取执行sql的对象

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第52张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第53张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第54张图片

管理事务

事务:

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第55张图片

JDBC各个类详解_Statement

    3. Statement:执行sql的对象
        1. 执行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)语句

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第56张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第57张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第58张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第59张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第60张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第61张图片

03 JDBC之CRUD练习

JDBC练习_insert语句

    3. Statement:执行sql的对象
        1. 执行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)语句
        2. 练习:
            1. account表 添加一条记录
            2. account表 修改记录
            3. account表 删除一条记录

            代码:...

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第62张图片

account表 添加一条记录

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第63张图片  JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第64张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第65张图片

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第66张图片

package cn.itcast.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

/**
 * account表 添加一条记录 insert 语句
 */
public class JDBCDemo2 {
    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 account values(null,'王五',3000)";
            //3.获取Connection对象
            conn = DriverManager.getConnection("jdbc:mysql:///db3", "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练习_update语句

account表 修改记录

package cn.itcast.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

/**
 * account表 修改记录
 */
public class JDBCDemo3 {
    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        try {
            //1.注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            //2.获取连接对象
            conn = DriverManager.getConnection("jdbc:mysql:///db3", "root", "root");
            //3.定义sql
            String sql = "update account set balance = 1500 where id = 3";
            //4.获取执行sql对象
            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 {
            //7.释放资源
            if (stmt != null) {
                try {
                    stmt.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            if (conn != null) {
                try {
                    conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

JDBC练习_update、DDL语句

account表 删除一条记录

package cn.itcast.jdbc;

import cn.itcast.util.JDBCUtils;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

/**
 * account表 删除一条记录
 */
public class JDBCDemo4 {
    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        try {
            //1. 注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            //2.获取连接对象
            conn = DriverManager.getConnection("jdbc:mysql:///db3", "root", "root");
            //conn = JDBCUtils.getConnection("jdbc:mysql:///db3", "root", "root");
            //3.定义sql
            String sql = "delete from account where id = 3";
            //4.获取执行sql对象
            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 {
            //7.释放资源
            if (stmt != null) {
                try {
                    stmt.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            if (conn != null) {
                try {
                    conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

执行DDL语句

JDBC学习笔记01【JDBC快速入门、JDBC各个类详解、JDBC之CRUD练习】_第67张图片

package cn.itcast.jdbc;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.SQLException;
import java.sql.Statement;

/**
 * 执行DDL语句
 */
public class JDBCDemo5 {
    public static void main(String[] args) {
        Connection conn = null;
        Statement stmt = null;
        try {
            //1. 注册驱动
            Class.forName("com.mysql.jdbc.Driver");
            //2.获取连接对象
            conn = DriverManager.getConnection("jdbc:mysql:///db3", "root", "root");
            //3.定义sql
            String sql = "create table student (id int, name varchar(20))";
            //4.获取执行sql对象
            stmt = conn.createStatement();
            //5.执行sql
            int count = stmt.executeUpdate(sql);
            //6.处理结果
            System.out.println(count);
        } catch (ClassNotFoundException e) {
            e.printStackTrace();
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
            //7.释放资源
            if (stmt != null) {
                try {
                    stmt.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
            if (conn != null) {
                try {
                    conn.close();
                } catch (SQLException e) {
                    e.printStackTrace();
                }
            }
        }
    }
}

加油,赶紧学,宁死不玩~

你可能感兴趣的:(JDBC,数据库,java,jdbc,mysql,intellij,idea)