201621123063《java程序设计》第14周实验总结

1. 本周学习总结

1.1 以你喜欢的方式(思维导图或其他)归纳总结与数据库相关内容。

201621123063《java程序设计》第14周实验总结_第1张图片

2. 使用数据库技术改造你的系统

2.1 简述如何使用数据库技术改造你的系统。要建立什么表?截图你的表设计。

图书借阅系统使用数据库存储馆藏图书信息,要建立图书信息表

201621123063《java程序设计》第14周实验总结_第2张图片

id作为主键

将图书表从数据库中读出:
数据库图表:
201621123063《java程序设计》第14周实验总结_第3张图片

成功读取并放入JTable显示:
201621123063《java程序设计》第14周实验总结_第4张图片

2.2 系统中使用到了JDBC中什么关键类?

Connection:获得与数据库的连接
DriverManger:驱动管理器,注册驱动
PreparedStatement:Statement子类,预编译SQL语句后让数据库执行
ResultSet:获取查询结果集

2.3 截图数据库相关模块的关键代码。关键行需要加注释。

201621123063《java程序设计》第14周实验总结_第5张图片

3. 代码量统计

3.1 统计本周完成的代码量

需要将每周的代码统计情况融合到一张表中。

周次 行数 新增行数 文件数 新增文件数
1 226 226 45 45
2 377 377 7 7
3 712 281 42 9
4 166 166 2 2
5 253 253 4 4
6 484 484 9 9
7 269 269 1 1
8 301 32 5 4
9 447 447 7 7
10 401 26 9 0
11 1262 1262 18 18
12 965 965 12 12
13 887 887 9 9
14 675 675 10 10

选做:4. 数据库学习指导

1. MySQL数据库基本操作

建立数据库,将自己的姓名、学号作为一条记录插入。(截图,需出现自己的学号、姓名)
201621123063《java程序设计》第14周实验总结_第6张图片

在自己建立的数据库上执行常见SQL语句

2. 使用JDBC连接数据库与Statement

2.1 使用Statement操作数据库。完成实验任务书-题目2。截图其中的public static void displayAll()与public static int insert(Student stu)的关键代码并出现自己的学号。

201621123063《java程序设计》第14周实验总结_第7张图片

201621123063《java程序设计》第14周实验总结_第8张图片

2.2 如果要完成根据指定姓名查询学生数据,即完成函数public Student findStuByName(String name),其中的sql语句怎么写?

String sql = "select * from students WHERE name = "+name;

2.3 你认为使用JDBC操作数据库的套路是什么?

①加载数据库驱动
②建立数据库连接
③创建数据库操作对象
④定义操作的SQL语句
⑤执行数据库操作
⑥获取并操作结果集
⑦close()关闭对象
参考:实验任务书-题目2

3. PreparedStatement与参数化查询

3.1 使用PreparedStatement,编写public Student findStuByName(String name),实现根据name进行查找, 。(粘贴关键代码及运行截图,运行截图中需出现学号,比较2.2,说明两种实现的不同)

public static Student findStuByName(String name)
    {
        String URL = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false";
        String userName = "root";
        String password = "123456";
        Connection conn = null;
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;
        Student student = null;
        String sql = "select*from students where name = ?";
        
        try {
            conn = DriverManager.getConnection(URL, userName, password);
            preparedStatement = conn.prepareStatement(sql);
            preparedStatement.setString(1, name);
            resultSet = preparedStatement.executeQuery();
            while(resultSet.next())
            {
                student = new Student(resultSet.getInt("id"),resultSet.getString("stuno"),resultSet.getString("name"),resultSet.getInt("age"),resultSet.getDate("birthdate"));
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
             if (resultSet != null) {
                    try {
                        resultSet.close();
                        resultSet.close();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
                }
                if (preparedStatement != null) {
                    try {
                        preparedStatement.close();
                        preparedStatement = null;
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }

                }
                if (conn != null)
                    try {
                        conn.close();
                        conn = null;
                    } catch (SQLException e) {
                        e.printStackTrace();
                    } 
        }
            return student;
    }

运行截图:

不同:PreparedStatement 的执行效率高于Statement,Statement每次执行sql语句,相关数据库都要执行sql语句的编译,Preparedstatement是预编译的。

3.2 如果要实现模糊查找,怎么修改?比如编写public List findStusByName(String name),可根据name进行模糊匹配,如将姓名中包含zhang的同学都找出来。

public static List findStusByName(String name)
    {
        String URL = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf-8&useSSL=false";
        String userName = "root";
        String password = "123456";
        Connection conn = null;
        PreparedStatement preparedStatement = null;
        ResultSet resultSet = null;
        String sql = "select*from students where name like ?";
        List students = new ArrayList<>();
        try {
            conn = DriverManager.getConnection(URL, userName, password);
            preparedStatement = conn.prepareStatement(sql);
            preparedStatement.setString(1, "%"+name+"%");
            resultSet = preparedStatement.executeQuery();
            while(resultSet.next())
            {
                Student student = new Student(resultSet.getInt("id"),resultSet.getString("stuno"),resultSet.getString("name"),resultSet.getInt("age"),resultSet.getDate("birthdate"));
                students.add(student);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        } finally {
             if (resultSet != null) {
                    try {
                        resultSet.close();
                        resultSet.close();
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }
                }
                if (preparedStatement != null) {
                    try {
                        preparedStatement.close();
                        preparedStatement = null;
                    } catch (SQLException e) {
                        e.printStackTrace();
                    }

                }
                if (conn != null)
                    try {
                        conn.close();
                        conn = null;
                    } catch (SQLException e) {
                        e.printStackTrace();
                    } 
        }
        return students;
    }

测试数据:
201621123063《java程序设计》第14周实验总结_第9张图片
运行截图:
201621123063《java程序设计》第14周实验总结_第10张图片

201621123063《java程序设计》第14周实验总结_第11张图片

6. 事务处理

6.1 使用代码与运行结果证明你确实实现了事务处理功能,并说明事务处理时在编码时需要注意哪些?注意:要比较运行成功与运行失败两种情况下对数据库的更改情况。(粘贴一段你认为比较有价值的代码,出现学号)

201621123063《java程序设计》第14周实验总结_第12张图片
测试数据:

更改前:

更改后:

运行失败:数据库中数据没有变化
201621123063《java程序设计》第14周实验总结_第13张图片
注意:数据库操作要分步进行,不能同时进行多个操作

6.2 你觉得什么时候需要使用事务处理?

对数据库的数据进行连续操作时,为了保证数据的一致性和正确性,需要使用事务处理。当对数据库的数据进行操作失败时,事务处理可以让所有的数据回滚到进行操作之前的数据。

选做:5.课外阅读

5.2 代码结构中Dao,Service,Controller,Util,Model是什么意思,为什么划分

Dao: Data Access Object,负责数据存取
Service:服务,完成一些指定的工作
Controller:控制器,所有的指令都由控制器发出
Util:工具,常用来处理和业务逻辑没有关系的数据
Model:模型,描述了一个类型数据的定义,通常是各数据的集合

划分好处:
①划分代码结构可以让代码具有良好的可移植性
②可以让多人协作并行开发更容易
③开发时能对程序的结构有更清晰的概念

5.3 mysq数据库管理工具navicat基本使用方法

201621123063《java程序设计》第14周实验总结_第14张图片
可以直接在可视化图表中对数据进行一些常规操作,在查询中可以用代码语句对数据库进行增删改查和事务控制

你可能感兴趣的:(201621123063《java程序设计》第14周实验总结)