JavaWeb 24 JDBC 复习 && 介绍 junit 作用

7.5 JDBC 复习


JDBC:Java DataBase Connect (Java 连接数据库)

在这里插入图片描述
需要 jar 包 的支持:

  • java.sql
  • javax.sql
  • mysql-conneter-java
package com.muquanyu.test;

import java.sql.*;

public class TestJdbc {
    public static void main(String[] args) throws ClassNotFoundException, SQLException {
        //设置 配置信息
        String url = "jdbc:mysql://localhost:3306/jdbc?" +
                "useUnicode=true&charaterEncoding=utf8&" +
                "useSSL=true&serverTimezone=UTC";//如果报错,把ssl 改成 false

        String username = "root";
        String password = "123123";

        //加载驱动
        Class.forName("com.mysql.cj.jdbc.Driver");

        //连接数据库
        Connection connection = DriverManager.getConnection(url, username, password);

        Statement statement = connection.createStatement();
        String sqlA = "insert into `people`(`id`,`name`,`password`,`email`,`birthday`) values(?,?,?,?,?)";
        PreparedStatement preparedStatement = connection.prepareStatement(sqlA);
        preparedStatement.setInt(1,4);
        preparedStatement.setString(2,"小白");
        preparedStatement.setString(3,"123123");
        preparedStatement.setString(4,"xb@qq.com");
        preparedStatement.setDate(5,new Date(new java.util.Date().getTime()));

        int i = preparedStatement.executeUpdate();
        
        if(i >= 0){
            System.out.println("插入成功!");
        }

        String sql = "select* from `people`";

        ResultSet resultSet = statement.executeQuery(sql);

        while(resultSet.next()){
            System.out.println(resultSet.getObject("id")+"|"+
                    resultSet.getObject("name")
            );
        }

        resultSet.close();
        statement.close();
        connection.close();
    }
}

在这里插入图片描述


7.5.1 事务

要么都成功,要么都失败!

必须满足ACID 原则:主要是为了保证数据的安全。

整体流程

  1. 开启事务
  2. 事务提交 commit()
  3. 事务回滚 rollback()
  4. 关闭事务

举例:

转账 -->
A:1000
B:1000
A --200–> B
A:800
B:1200

如果服务器崩溃了呢,可能 A 扣除了 200元,但 B 没有 到账 200元。如果发生这种事情,我们是不准许的。所以 必须 回滚到 转账前 的 状态。

  • 介绍 junit 作用

junit 一般 你新建一个 web-app 都会给你自动导入进去,这东西是干啥的呢?答:就是 给你提供随时 都可以运行方法的 功能。俗称 测试 Test。

<dependency>
            <groupId>junit</groupId>
            <artifactId>junit</artifactId>
            <version>4.12</version>
</dependency>

只要在 一个方法的上面加一个 @Test 的注解 ,就可以 随时随地的运行该方法了。

package com.muquanyu.test;

import org.junit.Test;

public class TestJunit {

    @Test
    public void test(){
        System.out.println("我是 Junit 让运行的方法!");
    }

}

在这里插入图片描述

use jdbc;
create table `account`(
    `id` int primary key auto_increment,
    `name` varchar(40),
    `money` decimal
)engine=innodb charset=utf8mb4;

insert into account(`name`,money) values ('A','1000');
insert into account(`name`,money) values ('B','1000');
insert into account(`name`,money) values ('C','1000');


Set autocommit = 0;#关闭自动提交事务

start transaction;#开启事务

update account set money = money-200 where name='A';
update account set money = money+200 where name='B';

commit;

rollback;

Set autocommit = true;#关闭自动提交事务
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我会尽力解答你的问题。 JavaWeb之页面跳转: 在JavaWeb中,实现页面跳转有多种方式,其中最常见的是使用重定向和转发。 重定向是指服务器返回一个HTTP响应,告诉客户端请求的资源已经被移到一个新的位置,客户端需要重新发送请求到这个新的位置。重定向可以通过以下代码实现: ```java response.sendRedirect("newpage.jsp"); ``` 转发是指服务器直接将请求转发到另一个资源,客户端并不知道这个过程发生了。转发可以通过以下代码实现: ```java request.getRequestDispatcher("newpage.jsp").forward(request, response); ``` JavaWeb数据库连接: 在JavaWeb中,连接数据库是非常常见的操作,可以使用JDBC或者ORM框架来实现。 使用JDBC连接数据库的步骤如下: 1. 加载数据库驱动程序 ```java Class.forName("com.mysql.jdbc.Driver"); ``` 2. 获取数据库连接 ```java Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/test", "root", "password"); ``` 3. 创建Statement对象 ```java Statement stmt = conn.createStatement(); ``` 4. 执行SQL语句 ```java ResultSet rs = stmt.executeQuery("SELECT * FROM user"); ``` 5. 处理查询结果集 ```java while (rs.next()) { // 处理每一行数据 } ``` 6. 释放资源 ```java rs.close(); stmt.close(); conn.close(); ``` ORM框架可以帮助我们更方便地操作数据库,比如使用MyBatis,只需要编写SQL语句和映射文件即可。例如: 1. 编写SQL语句 ```xml <select id="getUserById" resultType="User"> SELECT * FROM user WHERE id = #{id} </select> ``` 2. 编写映射文件 ```xml <resultMap id="userResultMap" type="User"> <id property="id" column="id"/> <result property="name" column="name"/> <result property="age" column="age"/> </resultMap> ``` 3. 获取SqlSession对象 ```java SqlSession sqlSession = sqlSessionFactory.openSession(); ``` 4. 执行查询操作 ```java User user = sqlSession.selectOne("getUserById", 1); ``` 5. 释放资源 ```java sqlSession.close(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值