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

1. 本周学习总结

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

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

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

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

id作为主键

将图书表从数据库中读出:
数据库图表:

成功读取并放入JTable显示:

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

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

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

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数据库基本操作

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

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

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

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

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

测试数据:

运行截图:

6. 事务处理

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


测试数据:

更改前:

更改后:

运行失败:数据库中数据没有变化

注意:数据库操作要分步进行,不能同时进行多个操作

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

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

选做:5.课外阅读

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

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

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

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


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

posted @ 2017-12-23 15:11  Yelz  阅读(395)  评论(0编辑  收藏  举报