数据库学习----JDBC

本文介绍了JDBC的概念,包括JDBC简介、数据库驱动、JDBC测试代码的编写,详细阐述了JDBC中的核心对象如URL、DriverManager、Statement和ResultSet。还探讨了Statement对象在CRUD操作中的应用,并提出创建JDBC工具类以优化数据库操作。最后,文章重点讨论了SQL注入问题,推荐使用PreparedStatement来防止SQL注入,以提高代码的安全性和可维护性。
摘要由CSDN通过智能技术生成
一、什么是JDBC?
1、JDBC简介

JDBC(Java DataBase Connectivity)是SUN 公司为了简化开发人员的(对数据库的统一)操作,提供了一个(Java操作数据库的)规范,俗称 JDBC。JDBC是Java和数据库之间的一个桥梁,是一个规范而不是一个实现,能够执行SQL语句。它由一组用Java语言编写的类和接口组成。各种不同类型的数据库都有相应的实现。
在这里插入图片描述

2、数据库驱动

在这里插入图片描述
在应用程序中通过数据库驱动和数据库进行数据的交互。

二、编写JDBC测试代码

测试的数据库代码:

CREATE DATABASE jdbcStudy CHARACTER SET utf8 COLLATE utf8_general_ci;

USE jdbcStudy;

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,'zhansan','123456','zs@sina.com','1980-12-04'),
(2,'lisi','123456','lisi@sina.com','1981-12-04'),
(3,'wangwu','123456','wangwu@sina.com','1979-12-04');
1、导入jar包,添加数据库驱动

在项目目录下创建一个 lib 目录,将自己下载好的 jar 包拷贝进去,
在这里插入图片描述
然后右击 lib 目录,添加即可。
在这里插入图片描述

2、JDBC测试代码:
package com.hang.demo01;

import java.sql.*;

public class JDBCTest {
   
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
   
        //1、加载驱动
        Class.forName("com.mysql.jdbc.Driver");

        //2、用户信息和URL
        String url = "jdbc:mysql://localhost:3306/jdbcstudy?useUnicode=true&characterEncoding=utf8&useSSL" +
                "=true";
        String name = "root";
        String password = "11235813";
        //3、连接成功,获得数据库对象connection
        Connection connection = DriverManager.getConnection(url, name, password);

        // 4、获取执行SQL的对象statement
        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"));
            System.out.println("------------------------------");

        }

        //6、释放连接
        resultSet.close();
        statement.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值