热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

开发笔记:201621123063《java程序设计》第14周实验总结

1. 本周学习总结1.1 以你喜欢的方式(思维导图或其他)归纳总结与数据库相关内容。2. 使用数据库技术改造你的系统2.1 简述如何使用数据库技术改造你的系统。要建立什么表?截图你的表设计。图书借阅系

1. 本周学习总结

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

技术分享图片

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

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

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

技术分享图片

id作为主键

将图书表从数据库中读出:
数据库图表:
技术分享图片

成功读取并放入JTable显示:
技术分享图片

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

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

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

技术分享图片

3. 代码量统计

3.1 统计本周完成的代码量

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















































































































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

选做: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


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基本使用方法

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




































推荐阅读
  • Java太阳系小游戏分析和源码详解
    本文介绍了一个基于Java的太阳系小游戏的分析和源码详解。通过对面向对象的知识的学习和实践,作者实现了太阳系各行星绕太阳转的效果。文章详细介绍了游戏的设计思路和源码结构,包括工具类、常量、图片加载、面板等。通过这个小游戏的制作,读者可以巩固和应用所学的知识,如类的继承、方法的重载与重写、多态和封装等。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • Java中包装类的设计原因以及操作方法
    本文主要介绍了Java中设计包装类的原因以及操作方法。在Java中,除了对象类型,还有八大基本类型,为了将基本类型转换成对象,Java引入了包装类。文章通过介绍包装类的定义和实现,解答了为什么需要包装类的问题,并提供了简单易用的操作方法。通过本文的学习,读者可以更好地理解和应用Java中的包装类。 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • JavaSE笔试题-接口、抽象类、多态等问题解答
    本文解答了JavaSE笔试题中关于接口、抽象类、多态等问题。包括Math类的取整数方法、接口是否可继承、抽象类是否可实现接口、抽象类是否可继承具体类、抽象类中是否可以有静态main方法等问题。同时介绍了面向对象的特征,以及Java中实现多态的机制。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Java String与StringBuffer的区别及其应用场景
    本文主要介绍了Java中String和StringBuffer的区别,String是不可变的,而StringBuffer是可变的。StringBuffer在进行字符串处理时不生成新的对象,内存使用上要优于String类。因此,在需要频繁对字符串进行修改的情况下,使用StringBuffer更加适合。同时,文章还介绍了String和StringBuffer的应用场景。 ... [详细]
  • 自动轮播,反转播放的ViewPagerAdapter的使用方法和效果展示
    本文介绍了如何使用自动轮播、反转播放的ViewPagerAdapter,并展示了其效果。该ViewPagerAdapter支持无限循环、触摸暂停、切换缩放等功能。同时提供了使用GIF.gif的示例和github地址。通过LoopFragmentPagerAdapter类的getActualCount、getActualItem和getActualPagerTitle方法可以实现自定义的循环效果和标题展示。 ... [详细]
  • 本文详细介绍了Java中vector的使用方法和相关知识,包括vector类的功能、构造方法和使用注意事项。通过使用vector类,可以方便地实现动态数组的功能,并且可以随意插入不同类型的对象,进行查找、插入和删除操作。这篇文章对于需要频繁进行查找、插入和删除操作的情况下,使用vector类是一个很好的选择。 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • 先看官方文档TheJavaTutorialshavebeenwrittenforJDK8.Examplesandpracticesdescribedinthispagedontta ... [详细]
  • 本文介绍了Java中Hashtable的clear()方法,该方法用于清除和移除指定Hashtable中的所有键。通过示例程序演示了clear()方法的使用。 ... [详细]
  • 纠正网上的错误:自定义一个类叫java.lang.System/String的方法
    本文纠正了网上关于自定义一个类叫java.lang.System/String的错误答案,并详细解释了为什么这种方法是错误的。作者指出,虽然双亲委托机制确实可以阻止自定义的System类被加载,但通过自定义一个特殊的类加载器,可以绕过双亲委托机制,达到自定义System类的目的。作者呼吁读者对网上的内容持怀疑态度,并带着问题来阅读文章。 ... [详细]
  • Week04面向对象设计与继承学习总结及作业要求
    本文总结了Week04面向对象设计与继承的重要知识点,包括对象、类、封装性、静态属性、静态方法、重载、继承和多态等。同时,还介绍了私有构造函数在类外部无法被调用、static不能访问非静态属性以及该类实例可以共享类里的static属性等内容。此外,还提到了作业要求,包括讲述一个在网上商城购物或在班级博客进行学习的故事,并使用Markdown的加粗标记和语句块标记标注关键名词和动词。最后,还提到了参考资料中关于UML类图如何绘制的范例。 ... [详细]
  • Java学习笔记之使用反射+泛型构建通用DAO
    本文介绍了使用反射和泛型构建通用DAO的方法,通过减少代码冗余度来提高开发效率。通过示例说明了如何使用反射和泛型来实现对不同表的相同操作,从而避免重复编写相似的代码。该方法可以在Java学习中起到较大的帮助作用。 ... [详细]
author-avatar
里枯萎
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有