1. 本周学习总结
1.1 以你喜欢的方式(思维导图或其他)归纳总结与数据库相关内容。
2. 使用数据库技术改造你的系统
2.1 简述如何使用数据库技术改造你的系统。要建立什么表?截图你的表设计。
图书借阅系统使用数据库存储馆藏图书信息,要建立图书信息表。
id
作为主键
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 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;
}
6. 事务处理
6.1 使用代码与运行结果证明你确实实现了事务处理功能,并说明事务处理时在编码时需要注意哪些?注意:要比较运行成功与运行失败两种情况下对数据库的更改情况。(粘贴一段你认为比较有价值的代码,出现学号)
运行失败:数据库中数据没有变化
注意:数据库操作要分步进行,不能同时进行多个操作
6.2 你觉得什么时候需要使用事务处理?
对数据库的数据进行连续操作时,为了保证数据的一致性和正确性,需要使用事务处理。当对数据库的数据进行操作失败时,事务处理可以让所有的数据回滚到进行操作之前的数据。
选做:5.课外阅读
5.2 代码结构中Dao,Service,Controller,Util,Model是什么意思,为什么划分
Dao: Data Access Object,负责数据存取
Service:服务,完成一些指定的工作
Controller:控制器,所有的指令都由控制器发出
Util:工具,常用来处理和业务逻辑没有关系的数据
Model:模型,描述了一个类型数据的定义,通常是各数据的集合
划分好处:
①划分代码结构可以让代码具有良好的可移植性
②可以让多人协作并行开发更容易
③开发时能对程序的结构有更清晰的概念