JDBC简介

Posted 我没得冰阔落.

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JDBC简介相关的知识,希望对你有一定的参考价值。

文章目录

一、JDBC简介

1.什么是jdbc
JDBC全称:java database connectivity,简称jdbc, 翻译就是 Java 数据库连接。

2.jdbc有什么作用:
是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库。可以通过jdbc代码实现对数据库的操作。包括DDL,DML,DQL等。

二、JDBC执行步骤

1.导入驱动jar包
链接:https://pan.baidu.com/s/1mP3Nb4wKd1VrBrGmbD3QDg
提取码:t0kh
导入jar包步骤

  • 1.在你的web-INF目录下创建一个lib包,专门放置jar包
  • 2.将jar包复制到lib路径下
  • 3.右键单击,选择add as library
  • 4.将level改成module library 点击OK

如果你的lib路径下的jar包有以下小箭头,就添加成功了

2.注册驱动

	Class.forName("com.mysql.jdbc.Driver");

3.获取连接

	Connection connection = DriverManager.getConnection(url, username, password);

4.定义SQL语句

	String sql = "sql语句";

5.获取执行SQl对象

Statement statement = connection.createStatement();

6.执行sql语句

statement.executeUpdate(sql);

7.处理结果

8.释放资源

statement.close();
connection.close();
package com.example.jdbc;

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

public class jdbcdemo 
    public static void main(String[] args) throws Exception 
//        1.注册驱动
        Class.forName("com.mysql.jdbc.Driver");

//        2.获取连接
        String url = "jdbc:mysql://127.0.0.1:3306/dbcsdn";
        String username = "root";
        String password = "1234";
        Connection connection = DriverManager.getConnection(url, username, password);
//        3.定义sql语句,这里以创建一个work_user表为例
        String sql1 = "use dbcsdn";
        String sql2 = "create table work_user(" +
                "id int(5) primary key auto_increment," +
                "username varchar(20) unique," +
                "password varchar(20))";
//        4.获取sql对象
        Statement statement = connection.createStatement();
//        5.执行sql
        int l1 = statement.executeUpdate(sql1);
        int l2 = statement.executeUpdate(sql2);

//        6.处理结果
        System.out.println("sql1受影响条数"+l1);
        System.out.println("sql2受影响条数"+l2);

//        7.释放资源
        statement.close();
        connection.close();
    

三、执行步骤中类的简介

1、DriverManager类

DriverManager类下面提供的全是静态方法,只需要用类名点方法就可以调用,不需要实例化。它的作用主要有两个:
1.注册驱动: registerDriver()

	Class.forName("com.mysql.jdbc.Driver");

其中的Driver类里面有一个静态代码块,有一句DriverManager. registerDriver()完成驱动的注册

2.获取连接:getConnection(url, username, password);
这个方法可以通过mysql的URL地址、数据库用户名、密码获取连接。传入的参数就是对应的URL地址:形如jdbc.mysql://ip地址:端口号/数据库名称。如果是本机连接,IP地址可以写成127.0.0.1或者localhost。如果端口号是默认的3306,可以写成缩写格式:jdbc.mysql:///数据库名

	Connection connection = DriverManager.getConnection(url, username, password);

2.Connection类

connection类主要有两个作用:一是可以获取执行sql的对象,二是管理事务的功能。我们都知道数据库里面的数据局一旦改变就是永久的,所以需要一个管理事务功能验证sql语句的正确性。在mysql中事务管理通过begin开启事务,rollback回滚事务,commit提交事务。在jdbc里面通过connection类的特定方法也可以实现这三个功能。

  1. 获取执行sql的对象用到的方法。
    第一个就是普通执行sql对象:connection.createStatement()方法,返回一个Statement对象。

    Statement statement = connection.createStatement();
    

statement类下面有两个对数据进行操作的方法,分别是excuteUpdate(),excuteQuery()。excuteUpdate()这个方法主要是实现DML(操作数据),DDL(操作数据库,操作表)的代码。执行成功之后会返回一个值,这个值就是受影响的行数。但是DDL中就算执行成功之后有可能是0,因为创建一个新的表这样的sql代码受影响行数是0。excuteQuery()主要是实现DQL(查询语句),这个方法会返回一个resultSet对象,这个对象主要用于接受查询到的内容。

演示excuteUpdate()方法。

package com.example.jdbc;

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

public class jdbcdemo 
    public static void main(String[] args) throws Exception 
        String url = "jdbc:mysql://127.0.0.1:3306/dbcsdn";
        String username = "root";
        String password = "1234";
        Connection connection = DriverManager.getConnection(url, username, password);

        String sql = "insert  into work_user values " +
                "(1,'name1','password1')," +
                "(2,'name2','password2');";

        Statement statement = connection.createStatement();

        int i = statement.executeUpdate(sql);

        System.out.println("受影响的行数是:"+i+"行");

        statement.close();
        connection.close();
    

第二个是防止sql注入的prepareStatement()方法,其中传入sql语句,可以防止sql注入,最终返回一个PrepareStatement对象。

2.jdbc事务管理用法举例

package com.example.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 Exception 
        String url = "jdbc:mysql://127.0.0.1:3306/dbcsdn";
        String username = "root";
        String password = "1234";
        Connection connection = DriverManager.getConnection(url, username, password);

        String sql1 = "insert  into work_user values " +
                "(5,'name5','password5')," +
                "(6,'name6','password6');";

        String sql2 = "update work_user set username = 'name002' where id = 2;";

        Statement statement = connection.createStatement();

        try 
            // 开启事务
            connection.setAutoCommit(false);

            int l1 = statement.executeUpdate(sql1);
            System.out.println("sql1受影响的行数是:"+l1+"行");
            int l2 = statement.executeUpdate(sql2);
            System.out.println("sql2受影响行数是:"+ l2+ "行");
            // 提交事务
            connection.commit();
         catch (Exception e) 
            //回滚事务
            connection.rollback();
            e.printStackTrace();
        
        statement.close();
        connection.close();
    


3、ResultSet类

作用:对DQL查询语句进行封装,返回一个resultset对象,并且可以通过特定方法获取查询结果。

  1. 对DQL查询语句封装

    ResultSet resultSet = statement.executeQuery(sql);
    
  2. 通过特定方法获取查询结果

next()方法。返回Boolean类型,主要用于判断当前行是否有有效数据,若有就返回true,否则返回false。

getXXX()方法。通过resultSet获取数据,对应数据类型定义对应方法。传参可以为字段名,也可以是列对应的编号。

package com.example.jdbc;

import java.sql.*;

public class jdbcdemo 
    public static void main(String[] args) throws Exception 
        String url = "jdbc:mysql://127.0.0.1:3306/dbcsdn";
        String username = "root";
        String password = "1234";
        Connection connection = DriverManager.getConnection(url, username, password);

        String sql = "select * from work_user";


        Statement statement = connection.createStatement();

        ResultSet resultSet = statement.executeQuery(sql);

        while (resultSet.next())
            int id = resultSet.getInt("id");
            String name = resultSet.getString("username");
            String psd = resultSet.getString("password");

            System.out.print("id:"+id+"\\t");
            System.out.print("username:"+name+"\\t");
            System.out.println("password:"+psd);
            System.out.println("---------------");
        
        resultSet.close();
        statement.close();
        connection.close();
    


JDBC—01—JDBC简介;JDBC常用接口与类;


 

 

一、 JDBC 简介

1 什么是 JDBC

  • JDBC(Java DataBase Connectivity)java 数据库连接
  • 是 JavaEE 平台下的技术规范
  • 定义了在 Java 语言中连接数据,执行 SQL 语句的标准(标准即是接口;)
  • 可以为多种关系数据库提供统一访问

2 什么是数据库驱动程序

  • 数据库厂商对 JDBC 规范的具体实现,是接口的实现类;
  • 不同数据产品的数据库驱动名字有差异
  • 在程序中需要依赖数据库驱动来完成对数据库的操作

3 程序操作数据库流程

定义了在 Java 语言中连接数据,执行 SQL 语句的标准———接口

数据库驱动程序——接口的实现类(不同的数据库有不同的数据库驱动程序)

通过Drive接口的实现类,获得数据库驱动对象,再把数据库驱动对象放到Drive Manager类中,通过Drive Manager类的getConnection()得到一个connection类型的数据库连接对象;

 

二、 JDBC3.0 标准中常用接口与类

1、Driver 接口

Driver 接口的作用是来定义数据库驱动对象应该具备的一些能力。

比如与数据库建立连接的方法的定义所有支持 java 语言连接的数据库都实现了该接口,实现该接口的类我们称之为数据库驱动类。

在程序中要连接数据库,必须先通过 JDK 的反射机制加载数据库驱动类,将其实例化。不同的数据库驱动类的类名有区别。

加载 MySql 驱动:Class.forName("com.mysql.jdbc.Driver");

加载 Oracle 驱动:Class.forName("oracle.jdbc.driver.OracleDriver");

2、DriverManager

DriverManager 通过实例化的数据库驱动对象,能够建立应用程序与数据库之间建立连接。并返回 Connection 接口类型的数据库连接对象。

2.1常用方法

getConnection(String jdbcUrl, String user, String password)

该方法通过访问数据库的 url、用户以及密码,返回对应的数据库的 Connection 对象。

2.2JDBC URL

与数据库连接时,用来连接到指定数据库标识符。在 URL 中包括了该数据库的类型、地址、端口、库名称等信息。不同品牌数据库的连接 URL 不同。

3、Connection 接口

Connection 与数据库的连接(会话)对象。我们可以通过该对象执行 sql 语句并返回结果。

连接 MySql 数据库:

Connection conn = DriverManager.getConnection("jdbc:mysql://host:port/database", "user",

"password");

连接 Oracle 数据库:

Connection conn = DriverManager.getConnection("jdbc:oracle:thin:@host:port:database",

"user", "password");

连接 SqlServer 数据库:

Connection conn = DriverManager.getConnection("jdbc:microsoft:sqlserver://host:port;

DatabaseName=database", "user", "password");

3.1常用方法

• createStatement():创建向数据库发送 sql 的 Statement 接口类型的对象。

• preparedStatement(sql) :创建向数据库发送预编译 sql 的 PrepareSatement 接口类型的对象。

• prepareCall(sql):创建执行存储过程的 CallableStatement 接口类型的对象。

• setAutoCommit(boolean autoCommit):设置事务是否自动提交。

• commit() :在链接上提交事务。

• rollback() :在此链接上回滚事务。

4、Statement 接口

用于执行静态 SQL 语句并返回它所生成结果的对象。

由 createStatement 创建,用于发送简单的 SQL 语句(不支持动态绑定)。

4.1常用方法

• execute(String sql):执行参数中的 SQL,返回是否有结果集。

• executeQuery(String sql):运行 select 语句,返回 ResultSet 结果集。

• executeUpdate(String sql):运行 insert/update/delete 操作,返回更新的行数。

• addBatch(String sql) :把多条 sql 语句放到一个批处理中。

• executeBatch():向数据库发送一批 sql 语句执行。

5、PreparedStatement 接口

继承自 Statement 接口,由 preparedStatement 创建,用于发送含有一个或多个参数的 SQL语句。

PreparedStatement 对象比 Statement 对象的效率更高,并且可以防止 SQL 注入,所以我们一般都使用 PreparedStatement。

5.1常用方法

• addBatch()把当前 sql 语句加入到一个批处理中。

• execute() 执行当前 SQL,返回个 boolean 值

• executeUpdate()运行 insert/update/delete 操作,返回更新的行数。

• executeQuery() 执行当前的查询,返回一个结果集对象

• setDate(int parameterIndex, Date x)向当前SQL语句中的指定位置绑定一个java.sql.Date

值。

• setDouble(int parameterIndex, double x)向当前 SQL 语句中的指定位置绑定一个 double

• setFloat(int parameterIndex, float x)向当前 SQL 语句中的指定位置绑定一个 float 值

• setInt(int parameterIndex, int x)向当前 SQL 语句中的指定位置绑定一个 int 值

• setString(int parameterIndex, String x)向当前 SQL 语句中的指定位置绑定一个 String 值

6、ResultSet 接口

ResultSet 提供检索不同类型字段的方法。

6.1常用方法

• getString(int index)、getString(String columnName)

获得在数据库里是 varchar、char 等类型的数据对象。

• getFloat(int index)、getFloat(String columnName)

获得在数据库里是 Float 类型的数据对象。

• getDate(int index)、getDate(String columnName)

获得在数据库里是 Date 类型的数据。

• getBoolean(int index)、getBoolean(String columnName)

获得在数据库里是 Boolean 类型的数据。

• getObject(int index)、getObject(String columnName)

获取在数据库里任意类型的数据。

6.2ResultSet 对结果集进行滚动的方法

• next():移动到下一行。

• Previous():移动到前一行。

• absolute(int row):移动到指定行。

• beforeFirst():移动 resultSet 的最前面。

• afterLast() :移动到 resultSet 的最后面。

7、CallableStatement 接口

继承自 PreparedStatement 接口,由方法 prepareCall 创建,用于调用数据库的存储过程。

 

以上是关于JDBC简介的主要内容,如果未能解决你的问题,请参考以下文章

MySQL—JDBC

java JDBC连接mysql

Mysql java JDBC驱动jar包

java中 MySQL与驱动jdbc连接不上,想请教高手:jdbc驱动:mysql-connector-java-5.1.18-bin.jar怎么用啊?

Java:jdbc连接mysql数据库

mysql的驱动jar包叫啥