jdbc快速开始

文章目录

jdbc 就是使用java语言操作关系型数据库的一套api

jdbc本质:

  • 官方(sun公司)定义的一套操作所有关系型数据库的规则,就是接口
  • 各个数据库厂商去实现这套接口,提供数据库驱动jar包
  • 我们可以使用这套接口编程,真正执行的代码就是驱动jar包中的实现类

jdbc的好处

  • 各个数据库常熟使用相同的接口,java代码不需要针对不同的数据库分别开发
  • 可随时替换底层数据库,访问数据库的java代码基本不动

快速开始

  1. maven导入mysql驱动

    xml 复制代码
    <!-- mysql 驱动 -->
    <dependency>
        <groupId>com.mysql</groupId>
        <artifactId>mysql-connector-j</artifactId>
        <version>8.0.33</version>
    </dependency>
    <!--单元测试-->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
        <version>RELEASE</version>
        <scope>compile</scope>
    </dependency>
  2. java代码

    java 复制代码
    String url = "jdbc:mysql://127.0.0.1:3306/db1";
    String username = "root";
    String password = "root1234";
    String className = "com.mysql.cj.jdbc.Driver";
    
    // 1. 注册驱动
    try {
        // 这个可以不用写,mysql驱动里面配置了
        // 会自动加载jar包中META-INF/services/java.sql.Driver文件中的驱动类
    //            Class.forName(className);
        // 2. 获取连接
        Connection conn = DriverManager.getConnection(url, username, password);
        // 3. 定义sql语句
        String sql = "update account set money = 2000 where id = 1";
        // 4. 获取执行sql的对象 statement
        Statement statement = conn.createStatement();
        // 5. 执行sql语句
        int count = statement.executeUpdate(sql);
        // 6. 处理结果
        System.out.println("count: " + count);
        // 7. 释放资源
        statement.close();
        conn.close();
    } catch (Exception e) {
        throw new RuntimeException(e);
    }

参考文献

1. 黑马程序员JavaWeb基础教程

相关推荐
冷雨夜中漫步21 分钟前
Claude Code源码分析——Claude Code Agent Loop 详细设计文档
java·开发语言·人工智能·ai
直奔標竿27 分钟前
Java开发者AI转型第二十六课!Spring AI 个人知识库实战(五)——联网搜索增强实战
java·开发语言·人工智能·spring boot·后端·spring
快乐非自愿43 分钟前
Redis--SDS字符串与集合的底层实现原理
数据库·redis·缓存
这儿有一堆花1 小时前
住宅代理(Residential Proxy)技术指南
开发语言·数据库·php
one_love_zfl1 小时前
java面试-微服务组件篇
java·微服务·面试
一只大袋鼠1 小时前
Java进阶:CGLIB动态代理解析
java·开发语言
环流_1 小时前
HTTP 协议的基本格式
java·网络协议·http
爱滑雪的码农1 小时前
Java基础十三:Java中的继承、重写(Override)与重载(Overload)详解
java·开发语言
【 】4231 小时前
C++&STL(Standard Template Library,标准模板库)
java·开发语言·c++
茉莉玫瑰花茶1 小时前
LangChain 核心组件 [ 2 ]
java·数据库·langchain