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

1. 本周学习总结

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

1123710-20171223151046865-1272412367.png

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

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

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

1123710-20171223143905709-692988804.png

id作为主键

将图书表从数据库中读出:
数据库图表:
1123710-20171223145817928-1492810286.png

成功读取并放入JTable显示:
1123710-20171223150238990-2111306099.png

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

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

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

1123710-20171223150811631-1410208424.png

3. 代码量统计

3.1 统计本周完成的代码量

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

周次行数新增行数文件数新增文件数
12262264545
237737777
3712281429
416616622
525325344
648448499
726926911
83013254
944744777
104012690
11126212621818
129659651212
1388788799
146756751010

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

1. MySQL数据库基本操作

建立数据库,将自己的姓名、学号作为一条记录插入。(截图,需出现自己的学号、姓名)
1123710-20171220194344662-1975736299.png

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

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

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

1123710-20171222162528818-1783305718.png

1123710-20171222161746068-1571673924.png

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;
    }

运行截图:
1123710-20171222231327287-734082693.png
1123710-20171222231334928-1641509997.png

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

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

public static List<Student> 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<Student> 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;
    }

测试数据:
1123710-20171222233124600-790991884.png
运行截图:
1123710-20171222233208600-1776078279.png

1123710-20171222233151350-349211365.png

6. 事务处理

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

1123710-20171223141943631-1123053007.png
测试数据:
1123710-20171223142123287-423984194.png

更改前:
1123710-20171223142032162-813851338.png
更改后:
1123710-20171223142154318-898799006.png

运行失败:数据库中数据没有变化
1123710-20171223144755771-1054425955.png
注意:数据库操作要分步进行,不能同时进行多个操作

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

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

选做:5.课外阅读

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

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

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

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

1123710-20171220194412162-767999941.png
可以直接在可视化图表中对数据进行一些常规操作,在查询中可以用代码语句对数据库进行增删改查和事务控制

转载于:https://www.cnblogs.com/Yelz/p/8068064.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值