当前位置: 首页 > article >正文

【web】JDBC

项目连接数据库

右侧导航栏找到databsae

如果没有驱动,先下载驱动

填写数据库用户名密码

勾选对应的表即可

JDBC代码流程

1,配置信息

2,加载驱动   从MySQL Connector/J 5.1版本开始,推荐使用com.mysql.cj.jdbc.Driver这个新的驱动类。

3,链接数据库

4,向数据库发送SQL的对象statement:CURD

5,编写sql

6,执行查询SQL,返回一个ResultSet  结果集

7,关闭链接,释放资源  一定要做,先开的后关

代码流程如下:

public class TestIdbc {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //配置信息
        //useUnicode=ture&characterEncoding=utf-8解决中文乱码问题
        String url="jdbc:mysql://localhost:3306/jdbc?useUnicode=ture&characterEncoding=utf-8";
        String username="root";
        String password="123456";
        //1,加载驱动   从MySQL Connector/J 5.1版本开始,推荐使用com.mysql.cj.jdbc.Driver这个新的驱动类。
        Class.forName("com.mysql.cj.jdbc.Driver");
        //2,链接数据库
        Connection cnno= DriverManager.getConnection(url,username,password);
        //3,向数据库发送SQL的对象statement:CURD
        Statement sta=cnno.createStatement();
        //4,编写sql
        String sql="select * from user";
        //5,执行查询SQL,返回一个ResultSet  结果集
        ResultSet rs=sta.executeQuery(sql);

        //4,编写sql
        // String sql="update user set name='张三' where id=1";
        //5,执行查询SQL,返回一个int 修改的数据条数
       // int rs=sta.executeUpdate(sql);

        while (rs.next()){
            System.out.println("id="+rs.getObject("id"));
            System.out.println("name="+rs.getObject("name"));
            System.out.println("password="+rs.getObject("password"));
            System.out.println("age="+rs.getObject("age"));
            System.out.println("address="+rs.getObject("address"));
        }

        //6,关闭链接,释放资源  一定要做,先开的后关
        rs.close();
        sta.close();
        cnno.close();
    }

预编译sql 

public class TestIdbc2 {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //配置信息
        //useUnicode=ture&characterEncoding=utf-8解决中文乱码问题
        String url="jdbc:mysql://localhost:3306/jdbc?useUnicode=ture&characterEncoding=utf-8";
        String username="root";
        String password="123456";
        //1,加载驱动   从MySQL Connector/J 5.1版本开始,推荐使用com.mysql.cj.jdbc.Driver这个新的驱动类。
        Class.forName("com.mysql.cj.jdbc.Driver");
        //2,链接数据库
        Connection cnno= DriverManager.getConnection(url,username,password);
         //3,编写sql
        String sql="insert into user(id,name,password,address,age,eamil) values (?,?,?,?,?,?)";
        //4,预编译
        PreparedStatement preparedStatement= cnno.prepareStatement(sql);

        preparedStatement.setInt(1,3);//给第一个占位符?的赋值为1
        preparedStatement.setString(2,"我们");//给第二一个占位符?的赋值为1
        preparedStatement.setString(3,"12345");
        preparedStatement.setString(4,"成都");
        preparedStatement.setString(5,"18");
        preparedStatement.setString(6,"11.qq.com");
        //5,执行sql
        int i=preparedStatement.executeUpdate();
        if(i > 0){
            System.out.println("成功");
        }

        //6,关闭链接,释放资源  一定要做,先开的后关
        preparedStatement.close();
        cnno.close();
    }
}

JDBC事务 

 ACID原则:保证数据的安全性,要么都成功,要么都不成功

开启事务 start transaction;

事务提交 commit()

事务回滚 rollback()

关闭事务

单元测试依赖junit

    <!--单元测试  方法上加@Test即可运行测试-->
        <dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.13.2</version>
            <scope>test</scope>
        </dependency>

事务案例

public class TestIdbc3 {
    public static void main(String[] args){
        //配置信息
        //useUnicode=ture&characterEncoding=utf-8解决中文乱码问题
        String url="jdbc:mysql://localhost:3306/jdbc?useUnicode=ture&characterEncoding=utf-8";
        String username="root";
        String password="123456";
        Connection cnno = null;
        try {
            //1,加载驱动   从MySQL Connector/J 5.1版本开始,推荐使用com.mysql.cj.jdbc.Driver这个新的驱动类。
            Class.forName("com.mysql.cj.jdbc.Driver");
            //2,链接数据库
            cnno= DriverManager.getConnection(url,username,password);
            //通知数据库开启是事务
            cnno.setAutoCommit(false);
            //3,编写sql
            String sql="update account set money = money-100 where name='A'";
           // 执行sql
           cnno.prepareStatement(sql).executeUpdate();

           //制造错误
            int i=1/0;
            
            String sql2="update account set money = money+100 where name='B'";
            // 执行sql
            cnno.prepareStatement(sql2).executeUpdate();

            cnno.commit();


        } catch (Exception e) {
            try {
                //如果出现异常,通知数据库回滚
                cnno.rollback();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
            e.printStackTrace();
        }finally {
            //6,关闭链接,释放资源  一定要做,先开的后关
            try {
                cnno.close();
            } catch (SQLException throwables) {
                throwables.printStackTrace();
            }
        }

    }
}


http://www.kler.cn/a/355170.html

相关文章:

  • 音视频入门基础:MPEG2-PS专题(5)——FFmpeg源码中,解析PS流中的PES流的实现
  • ffmpeg之yuv格式转h264
  • Flask 快速入门
  • 一文理解ssh,ssl协议以及应用
  • Mac M2基于MySQL 8.4.3搭建(伪)主从集群
  • 《普通逻辑》学习记录——命题的判定与自然推理
  • 浏览器缓存得学习
  • 【MySQL】MySQL的简单了解详解SQL分类数据库的操纵方法
  • 电脑技巧:优化Edge浏览器占用C盘空间的解决方案
  • linux中vi编辑器中进入编辑模式的三种进入方式a,i,o,A,I,O六种方式的区别
  • JAVA智能代驾跑腿系统一站式服务系统源码小程序
  • django5入门【02】创建新的django程序
  • git版本控制软件,操作方法
  • 【三极管低频放大器添加一级适应负载变化】2021-11-21 11:49
  • ubuntu下安装mysql遇到的问题
  • 第一个servlet程序
  • 高可用之限流-06-slide window 滑动窗口 sentinel 源码
  • 【LeetCode:349. 两个数组的交集 + 哈希表】
  • MySQL(B站CodeWithMosh)——2024.10.12(15)
  • OPC Router快速打通设备层与influxDB数据通讯
  • 矢量网络分析仪工作原理
  • Docker system
  • 数学学习——积化和差、和差化积
  • 2025 -中医儿科学 -考研-执业
  • vue 导出文件空白 导出EXCEL打不开
  • CTFHUB技能树之SQL——UA注入