201521123038 《Java程序设计》 第十四周学习总结


1. 本周学习总结

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

  • 接口
  • DriverManager:加载驱动、建立连接
  • Connection:数据库连接
  • Statement:处理连接中的SQL语句
  • ResultSet:处理结果集
  • 释放资源顺序
  • ResultSet
  • Statement
  • Connection
  • PreparedStatement比普通的Statement对象使用起来更加灵活,更有效率,多次执行sql语句时建议使用

  • 多次对数据库进行操作,可以将获得连接与释放连接的操作封装起来,提供访问数据库的统一入口


2. 书面作业

1. MySQL数据库基本操作

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

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


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

2.1 使用Statement操作数据库。(粘贴一段你认为比较有价值的代码,出现学号)

  • 查询表内记录数量

//201521123038
sql = "select count(*) from students";
rs = statement.executeQuery(sql);
if(rs.next()){
resultNum = rs.getInt(1);
System.out.println("数据库存在"+resultNum+"条记录数据库");
}
  • 警告提示Establishing SSL connection without server's identity verification is not recommended,原因是就是使用JDBC和数据库连接时,JDBC版本与MySQL版本不兼容,MySQL的版本更高一些。

  • String URL = "jdbc:mysql://localhost:3306/test";修改为String URL = "jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=GBK&useSSL=false";

运行结果:

2.2 使用JDBC操作数据库主要包含哪几个步骤?

  • 装载JDBQ驱动,使用 Class.forName(driverName),jdbc4.0不需要手动加载
  • 创建数据库的连接(Connection)
  • 创建SQL语句(Statement)
  • 通过语句获得结果集(ResultSet)
  • 处理结果集
  • 关闭JDBC对象,释放资源

3. PreparedStatement与参数化查询

3.1 使用PreparedStatement根据用户指定的查询条件进行查询。(粘贴一段你认为比较有价值的代码,出现学号)

  • 查找语句

//201521123038
System.out.println("\n查找major=ne\n");
strSql = "select * from students where major = ?";
pStatement = con.prepareStatement(strSql);
pStatement.setString(1, "ne");
rs = pStatement.executeQuery();
System.out.println("学号\t\t姓名\t出生日期\t\t专业");
while(rs.next()){ System.out.print(rs.getString("stuno")+"\t\t");
System.out.print(rs.getString("name")+"\t");
System.out.print(rs.getDate("birthdate")+"\t");
System.out.print(rs.getString("major")+"\t\n");
}
  • 取数据有通过列的下标取数据和通过列名取数据两种方法,最好使用后者

运行结果:

3.2 批量更新-批量插入1000个学生,统计整个操作所消耗的时间。对比普通方法插入与使用executeBatch方法所消耗的时间。(使用JUint4测试,需要出现时间对比截图)

时间对比:


4. JDBCUtil与DAO

4.1 粘贴一段你认为比较有价值的代码,出现学号


//201521123038
@Override
public int add(Student student) {
Connection conn = null;
PreparedStatement pstat = null;
String sql = "insert into students(id,name) values(?,?) ";
int result = -1; try {
conn = JDBCUtil.getConnection();//建立连接
pstat = conn.prepareStatement(sql);
pstat.setInt(1, student.getId());
pstat.setString(2, student.getName());
result = pstat.executeUpdate(); }catch (SQLException sqle) {
sqle.printStackTrace();
}catch(Exception e){
e.printStackTrace();
}finally{
JDBCUtil.realeaseAll(null,pstat, conn);
}
return result>0?1:-1;
}

4.2 使用DAO模式访问数据库有什么好处?

  • 创建JDBCUtil,将获得连接与释放连接的操作封装起来,提供访问数据库的统一入口。在进行主要操作的时候不用编写处理数据库的全部代码,避免出错,增加代码的安全性。
  • 创建Dao接口,实现面向接口编程,可以有不同的实现类。

5. 使用数据库改造购物车系统

5.1 使用数据库改造以前的购物车系统(应有图形界面)。如果以前未完成购物车系统,可编写基于数据库的学生管理系统。包括对学生的增删改查,要求使用。

diplayAllStudent代码,其他功能都大同小异:

运行结果:

5.2 相比较使用文件,使用数据库存储与管理数据有何不一样?

  • 文件管理容易发生因操作失误导致的文件删除或者内容更改,相较之下数据库安全性更高
  • 数据库处理数据比文件处理效率更高,例:制作APP需要庞大的后台数据,使用文件不方便管理,一般大型开发都要使用数据库存储
  • 写入数据时使用文件虽然比使用数据库操作代码方便,但是查询和统计文件中的数据不如使用数据库方便

3. 码云

3.1. 码云代码提交记录

201521123038 《Java程序设计》 第十四周学习总结的更多相关文章

  1. 201521123038 《Java程序设计》 第四周学习总结

    201521123038 <Java程序设计> 第四周学习总结 1. 本周学习总结 1.1 尝试使用思维导图总结有关继承的知识点. 1.2 使用常规方法总结其他上课内容. 1.通过 ins ...

  2. 201871010106-丁宣元 《面向对象程序设计(java)》第十四周学习总结

    201871010106-丁宣元 <面向对象程序设计(java)>第十四周学习总结 正文开头: 项目 内容 这个作业属于哪个课程 https://home.cnblogs.com/u/nw ...

  3. 20165235 祁瑛 2018-3 《Java程序设计》第四周学习总结

    20165235 祁瑛 2018-3 <Java程序设计>第四周学习总结 教材学习内容总结 第五单云总结 (一)子类与继承1.java中子类只能有一个父类,在类名前用extends标记.2 ...

  4. 20145213《Java程序设计》第四周学习总结

    20145213<Java程序设计>第四周学习总结 教材学习内容总结 本周任务是学习面向对象的继承.接口以及之后的如何活用多态.(还真是路漫漫其修远兮啊!)教材也是延续上周艰深晦涩的语言风 ...

  5. 20145330《Java程序设计》第四周学习总结

    20145330<Java程序设计>第四周学习总结 一周两章新知识的自学与理解真的是很考验和锻炼我们,也对前面几章我们的学习进行了检测,遇到忘记和不懂的知识就再复习前面的,如此巩固也让我对 ...

  6. 20145337《Java程序设计》第四周学习总结

    20145337<Java程序设计>第四周学习总结 教材学习内容总结 继承与多态 继承 继承,避免多个类间重复定义共同行为 符合DRY(Don't Repeat Yourself)原则,多 ...

  7. 20145218 《Java程序设计》第四周学习总结

    20145218 <Java程序设计>第四周学习总结 教材学习内容总结 继承 继承共同行为 继承基本上就是避免多个类间重复定义共同行为. 继承的三个好处:减少代码冗余:维护变得简单:扩展变 ...

  8. 《Java程序设计》第四周学习总结

    20145224-陈颢文 <Java程序设计>第四周学习总结 教材学习内容总结 第六章 继承与多态 ·继承就是面向对象中,子类继承父类,避免重复的行为定义.重复再程序设计上是非常不好的信号 ...

  9. 20155304 2016-2017-2 《Java程序设计》第四周学习总结

    20155304 2016-2017-2 <Java程序设计>第四周学习总结 教材学习内容总结 第六章 继承: 概念: 面向对象中,为避免多个类间重复定义共同行为.(简单说就是将相同的程序 ...

  10. 201521123061 《Java程序设计》第四周学习总结

    201521123061 <Java程序设计>第四周学习总结 1. 本章学习总结 (1)思维导图: --- (2)上课内容总结: 第四周学习了Java中的继承与多态,思维导图中已经给出了本 ...

随机推荐

  1. tomcat websocket 实现网页在线即时聊天

    背景介绍 近一个月完成了公司的一个项目,负责即时聊天部分 寻找了一下,决定使用websocket,要问原因的话,因为tomcat 自带相关消息收发的API,用起来方便 闲话少叙,进入实现步骤 使用工具 ...

  2. ubuntu安装新版QQ

    我一直无法解决Ubuntu QQ问题,而最近我重装ubuntu之后在网络上找到与QQ相关的内容,网上有大神开发出了新版的wineQQ,解决了我们对QQ的需求.经过尝试,完成了QQ安装 如图 安装的是w ...

  3. [日推荐] 『闲聊助手』人工智能小程序,仅此一款!-极乐商店store.dreawer.com

    肾phone的siri有用过吗?小编无聊时就撩一下她!但有个问题就是要是没有肾phone在身边怎么撩???现在有伙伴@wx_Volcano_Li76 开发一款小程序,可以等同于siri,想什么时候撩就 ...

  4. RSA,Miller-Rabin素数测试的源流及其证明

    一.RSA与公钥加密系统的起源与影响. 为了更好地突出公钥加密系统相对私钥加密系统的优势,让我们从这两个问题开始: 这个世界上如果没有公钥加密系统会怎么样呢?全用私钥加密系统会出现什么问题呢? 首先, ...

  5. C#异步编程(async and await)及异步方法同步调用

    1.什么是异步? 异步操作通常用于执行完成时间可能较长的任务,如打开大文件.连接远程计算机或查询数据库=异步操作在主应用程序线程以外的线程中执行.应用程序调用方法异步执行某个操作时,应用程序可在异步方 ...

  6. web本地存储

    Web本地存储 通过本地存储(Local Storage),web 应用程序能够在用户浏览器中对数据进行本地的存储. 在 HTML5 之前,应用程序数据只能存储在 cookie 中,包括每个服务器请求 ...

  7. jquery的2.0.3版本源码系列(1)总体结构

    为什么选择2.X版本,而不是1.X版本,因为2.X不兼容IE6/7/8,所以少了兼容代码,让我们更专注于jquery原理的代码. 一共有8830行. 1.1 匿名函数自执行 首先,匿名函数的作用是,把 ...

  8. Struts拦截器解析

    内建拦截器可以去struts-core.jar中的struts-default.xml文件中查看: 在没有引用内建拦截器时,已经帮我们指定了一个默认的拦截器: 使用的软件为MyEclipse:很强大!

  9. python进阶学习(三)

    本节通过SQLite了解数据库操作 ------------------------- 数据库支持 使用简单的纯文本只能实现有退限的功能,所需要引入数据库,完成更强大的功能,本节使用的简单数据库SQL ...

  10. 关于idea的使用心得

    开发java多年,所在的项目组一直都在使用的eclipse或者myeclipse,今天偶然的机会接触到了idea,感觉优化的确实不错,下面是我的一些使用心得: