201521123018 《Java程序设计》第14周学习总结
1. 本章学习总结

2. 书面作业
1. MySQL数据库基本操作
建立数据库,将自己的姓名、学号作为一条记录插入。(截图,需出现自己的学号、姓名)
在自己建立的数据库上执行常见SQL语句(截图)
- 添加自己的信息到表students,将表students的学生信息展示 
  
- 再添加一个信息,并删除 
  
- 展示students表中的全部学号 
  
- 将名字改变 
  
-参考:实验任务书-题目1
2. 使用JDBC连接数据库与Statement
2.1 使用Statement操作数据库。(粘贴一段你认为比较有价值的代码,出现学号)
//201521123018
try {
    conn = DriverManager.getConnection(URL,userName,password);
    Statement statement = conn.createStatement();
    ResultSet resultSet = statement.executeQuery(sql);
    //JDBC连接数据库
    while(resultSet.next()){
        int id = resultSet.getInt("id");
        String stuno = resultSet.getString("stuno");
        String name = resultSet.getString("name");
        System.out.print("id="+id+" stuno="+stuno+" name="+name);
    }
} catch (SQLException e) {
    e.printStackTrace();
}finally{
    if(conn!=null)
        try {
            conn.close();
        } catch (SQLException e) {
            e.printStackTrace();
        }
    conn = null;
}
2.2 你认为使用JDBC操作数据库的套路是什么?有那几点需要注意。
- 装载驱动
- 与数据库建立连接(Connection)
- 向数据库发送SQL语句(Statement)
- 获得和处理查询或更新语句返回的结果
- 关闭连接,释放资源
-参考:实验任务书-题目2
3. PreparedStatement与参数化查询
3.1 使用PreparedStatement根据用户指定的查询条件进行查询。(粘贴一段你认为比较有价值的代码,出现学号)
//201521123018
String strSql = "select * from students where Id < ?";//举例,查询条件为id<10的学生信息
pStatement = con.prepareStatement(strSql);
pStatement.setInt(1, 10);
rs = pStatement.executeQuery();
while(rs.next()){
    System.out.println(rs.getInt("id"));
    System.out.println(rs.getString("stuno"));
    System.out.println(rs.getString("name"));
    System.out.println(rs.getInt("age"));
}
pStatement.close();//立即释放资源
3.2 批量更新-批量插入1000个学生,统计整个操作所消耗的时间。对比普通方法插入与使用executeBatch方法所消耗的时间。(使用JUint4测试,需要出现时间对比截图)
//201521123018
long t1=System.currentTimeMillis();
//处理1000个学生信息
for(int i=0;i<1000;i++){
    String strSql = "insert into students(stuno,name) values(?,?)";
    pStatement = con.prepareStatement(strSql);
    pStatement.setString(1, "2015000");
    pStatement.setString(2, "杰克");
    pStatement.addBatch();//添加到同一个批处理中
}
long t2=System.currentTimeMillis();
Calendar c=Calendar.getInstance();
c.setTimeInMillis(t2-t1);
System.out.println("耗时: " + c.get(Calendar.MINUTE) + "分 " + c.get(Calendar.SECOND) + "秒 " + c.get(Calendar.MILLISECOND) + " 微秒");
int[] arr=pStatement.executeBatch();//执行批处理
pStatement.executeUpdate();
pStatement.close();//立即释放资源
System.out.println(Arrays.toString(arr));

参考:实验任务书-题目3
4. JDBCUtil与DAO
4.1 粘贴一段你认为比较有价值的代码,并说明为什么要摘取这段代码。出现学号
//201521123018
//函数,遍历该List,将学生的姓名与年龄输出
public void TdiplayAllStudent(List<Student> t) {
    for(int i=0;i<t.size();i++){
        System.out.println(t.get(i).toString());
    }
}
//将List中的所有Student取出,放入Map中,其中key为学生的姓名,value为相应的学生对象
public void MAPdiplayAllStudent(List<Student> t) {
    Map<String,Student> map=new HashMap<String,Student>();
    for(int i=0;i<t.size();i++){
        map.put(t.get(i).getName(), t.get(i));
    }
}
Map<String,Integer> map=new HashMap<String,Integer>();
//将ResultSet中的学生信息,构造成一个个的Student对象,并放入List中
@Override
public List<Student> getAllStudents() {
    List<Student> t=new ArrayList<>();
    Connection conn = null;
    Statement stat = null;
    ResultSet rs = null;
    String sql = "select * from student";//表中有id和name这列
    try {
        conn = JDBCUtil.getConnection();
        stat = conn.createStatement();
        rs = stat.executeQuery(sql);
        while(rs.next()){
            int id = rs.getInt("id");
            String name = rs.getString("name");
            Student student0=new Student(id,name);
            t.add(student0);
        }
    }catch (SQLException sqle) {
        sqle.printStackTrace();
    }catch(Exception e){
        e.printStackTrace();
    }finally{
        JDBCUtil.realeaseAll(rs,stat, conn);
    }
    return t;
}
4.2 使用DAO模式访问数据库有什么好处?
DAO模式的使用相当于建立一个接口,接口中定义了此应用程序中将会用到的所有方法。在程序中,当需要和数据进行交互的时候则使用这个接口,并且编写一个单独的类来实现这个接口上的方法,代码之间的板块分配很清晰,而且在后期对程序的修改,只需对DAO模式中的某个方法修改即可,不需要整个项目都进行修改
参考:实验任务书-题目5
5. 使用数据库改造购物车系统
5.1 使用数据库改造以前的购物车系统(应有图形界面)。如果以前为完成购物车系统,可编写基于数据库的学生管理系统。包括对学生的增删改查,要求使用。
5.2 相比较使用文件,使用数据库存储与管理数据有何不一样?
3. PTA实验总结及码云上代码提交记录
3.1本周Commit历史截图
在码云的项目中,依次选择“统计-Commits历史-设置时间段”,然后搜索并截图,如下图所示
3.2 实验总结
实验碰到的问题、思考、收获与解决方案
201521123018 《Java程序设计》第14周学习总结的更多相关文章
- 2018面向对象程序设计(Java)第14周学习指导及要求
		2018面向对象程序设计(Java)第14周学习指导及要求(2018.11.29-2018.12.2) 学习目标 (1) 掌握GUI布局管理器用法: (2) 掌握各类Java Swing组件用途及 ... 
- 面向对象程序设计(JAVA) 第14周学习指导及要求
		2019面向对象程序设计(Java)第14周学习指导及要求 (2019.11.29-2019.12.2) 学习目标 (1)掌握GUI布局管理器用法: (2)掌握Java Swing文本输入组件用途 ... 
- 20145213《Java程序设计》第二周学习总结
		20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ... 
- 21045308刘昊阳 《Java程序设计》第九周学习总结
		21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ... 
- 201521123038 《Java程序设计》 第九周学习总结
		201521123038 <Java程序设计> 第九周学习总结 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. 2. 书面作业 本次PTA作业题集异常 ... 
- 20155303 2016-2017-2 《Java程序设计》第二周学习总结
		20155303 2016-2017-2 <Java程序设计>第二周学习总结 教材学习内容总结 『注意』 "//"为单行批注符: "/*"与&quo ... 
- 20175221 2018-2019-2 《Java程序设计》第一周学习总结
		20175221 2018-2019-2 <Java程序设计>第一周学习总结 教材学习内容总结 本周通过观看书本配套视频,学到了如解释器,编译器等一些简单概念. 还懂得了java的一些简单 ... 
- 20175314 《Java程序设计》第九周学习总结
		20175314 <Java程序设计>第九周学习总结 教材学习内容总结 根据课本的介绍下载了MySQL和Navicat for MySQL并成功对后者进行破解 MySQL客户端管理工具(如 ... 
- 20175314 《Java程序设计》第二周学习总结
		20175314 <Java程序设计>第二周学习总结 教材学习内容总结 我在APPstore上发现了一个可以支持我们在IOS系统上学习实践Java程序的开发环境,只需要购买专业版就可以使用 ... 
- 20155312 2016-2017-2 《Java程序设计》第九周学习总结
		20155312 2016-2017-2 <Java程序设计>第九周学习总结 课堂内容总结 两个类有公用的东西放在父类里. 面向对象的三要素 封装 继承 多态:用父类声明引用,子类生成对象 ... 
随机推荐
- oracle 11gR2 RAC安装手册
			--oracle 11gR2 RAC安装手册 -----------------------------2013/10/29 参考三思笔记 http://files.cnblogs.com/jackh ... 
- 【转载】Linux的inode的理解
			本文转在是博主为了以后温习.请访问原文链接 http://www.cnblogs.com/itech/archive/2012/05/15/2502284.html 一.inode是什么? 理解ino ... 
- js 小数计算为啥和想象中不一样!
			今天遇到了一个比较有趣的事,如果要你计算0.1+0.2等于多少你会怎么回答? "0.3啊!"你可能都不会考虑.我也一样,当a=0.1,b=0.2时 if(a+b === 0.3){ ... 
- - Templates should only be responsible for mapping the state to the UI. Avoid placing tags with side-effects in your templates, such as <script>, as they will not be parsed.
			vue.js报错如下: - Templates should only be responsible for mapping the state to the UI. Avoid placing ta ... 
- centos下安装jenkins
			To use this repository, run the following command: sudo wget -O /etc/yum.repos.d/jenkins.repo https: ... 
- DesignPatternPrinciple(设计模式原则)一
			设计模式六大原则(1):单一职责原则 定义:不要存在多于一个导致类变更的原因.通俗的说,即一个类只负责一项职责. 问题由来:类T负责两个不同的职责:职责P1,职责P2.当由于职责P1需求发生改变而需 ... 
- python 学习网站
			python 文档库 docs.python.org/2/library/index.html python 第三方模块查找 pypi.python.org 
- 使用TenforFlow 搭建BP神经网络拟合二次函数
			使用简单BP神经网络拟合二次函数 当拥有两层神经元时候,拟合程度明显比一层好 并出现如下警告: C:\Program Files\Python36\lib\site-packages\matplotl ... 
- collection 模块
			关于一些 特殊数据类型的模块 namedtuple顾名思义,一个带有名字的元祖,他也是跟对象有关的一个 from collections import namedtuple phone = named ... 
- 再起航,我的学习笔记之JavaScript设计模式16(享元模式)
			### 享元模式 **享元模式(Flyweight):** 运用共享技术有效地支持大量的细粒度的对象,避免对象间拥有相同内容造成多余的开销. 上回我们在组合模式中创建了文章列表类,这次我们要向不同的文 ... 
