博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第14周 数据库
阅读量:5040 次
发布时间:2019-06-12

本文共 3083 字,大约阅读时间需要 10 分钟。

0. 本周课程设计发布

Java课程设计

1. 本周学习总结

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

1109836-20170528175413125-542183498.png

2. 书面作业

1. MySQL数据库基本操作

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

在自己建立的数据库上执行常见SQL语句(截图)
-参考:实验任务书-题目1
打开mysql,输入密码,结果密码没设置好是空密码,输入SQL语句后面还要加“;”。。。
1109836-20170528152914828-907240020.png
show databases展示数据库
1109836-20170528152923485-89439264.png
设置了一个test1
1109836-20170528153229985-1820527021.png
重新设置了一个,desc student显示student相关数据
1109836-20170528153234047-1704234813.png
插入了我的姓名学号;
1109836-20170528153252438-173948803.png
一系列的删除更改操作
1109836-20170528192243610-262968907.png

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

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

1109836-20170528184001157-1145358091.png

1109836-20170528184642547-2036483136.png

2.2 你认为使用JDBC操作数据库的套路是什么?有那几点需要注意。

1.DriverManager装载数据库所需驱动到JVM2.connection创建连接3.创建Statement实例4.执行sql语句5.关闭链接释放资源

-参考:实验任务书-题目2

3. PreparedStatement与参数化查询

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

这段代码很有意思,盯着她看了好久

1109836-20170528192942610-1103166459.png

1109836-20170528193021907-1480798015.png

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

//201521044152       long t1=System.currentTimeMillis();//处理1000个学生信息for(int i=0;i<1000;i++){    String strSql = "insert into students(stuno,name,birthdate,age) values(?,?,?,?)";    pStatement = con.prepareStatement(strSql);    pStatement.setString(1, "007");    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 粘贴一段你认为比较有价值的代码,并说明为什么要摘取这段代码。出现学号

//201521044152public boolean add(Student stu){    boolean flag=true;    String sql= "insert into lin (Name,ID) values(?,?)";    try{        pst=conn.prepareStatement(sql);        pst.setString(1,stu.name);        pst.setInt(2,stu.id);        int i=pst.executeUpdate();        if(i==0){            flag=false;        }    }catch (Exception e)    {        e.printStackTrace();    }    finally {        try {            pst.close();        }catch(SQLException e) {}    }    return flag;}public void TdiplayAllStudent(List
t) { for(int i=0;i
t) { Map
map=new HashMap
(); for(int i=0;i
map=new HashMap
();//取出Student,放到Map中

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

对于比较大型的项目,使用DAO时分工比较明细,方便后期维护,DAO提供给用户的接口只有DAO的接口,如果用户想添加数据,可以调用DAO的create()函数即可,不需要对数据库在进行复杂的好多操作

参考:实验任务书-题目5

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

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

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

使用文件存储与管理的实现以文件为单位的数据共享,而使用数据库存储与管理的实现是以记录和字段为单位的数据共享;使用文件操作数据,需要打开文件和关闭文件,而用    数据库来操作数据,只需要输入密码打开数据库输入命令来实现数据的存储等功能,更加简单;使用文件存储与管理,硬盘空间浪费严重,容易造成数据的不一致;使用数据库存储与管理中,数据可以被多个用户、多个应用共享使用,减少了存储空间的浪费,空间利用比较合理,提高了数据的一致性和完整性。

选做:6. 批量更新测试

数据库课程上,需要测试索引对查找的加速作用。然而在几百或几千的数据量上进行操作无法直观地体验到索引的加速作用。现希望编写一个程序,批量插入1000万条数据,且该数据中的某些字段的内容可以随机生成。

6.1 截图你的代码(出现学号)、统计运行时间

6.2 计算插入的速度到底有多快?(以条/秒、KB/秒两种方式计算)

选做:7. 事务处理

7.1 使用代码与运行结果证明你确实实现了事务处理功能。(粘贴一段你认为比较有价值的代码,出现学号)

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

参考:实验任务书-题目4

选做 8. 数据库连接池

使用数据库连接池改写题目5

参考:实验任务书-题目4

数据连接池参考资料

3. 码云

3.1. 码云代码提交记录

在码云的项目中,依次选择“统计-Commits历史-设置时间段”, 然后搜索并截图

1109836-20170528202428813-267146489.png

4.课外阅读

转载于:https://www.cnblogs.com/mz201521044152/p/6915810.html

你可能感兴趣的文章
次序+“选择不重复的记录”(3)——最大记录
查看>>
Codeforces 450 C. Jzzhu and Chocolate
查看>>
[Unity3D]Unity3D游戏开发MatchTarget的作用攀登效果实现
查看>>
ACdream 1115 Salmon And Cat (找规律&amp;&amp;打表)
查看>>
JSON、JSONP、Ajax的区别
查看>>
AngularJS学习篇(一)
查看>>
【转载】 IP实时传输协议RTP/RTCP详解
查看>>
关于Xshell无法连接centos6.4的问题
查看>>
Linux系统的数据写入机制--延迟写入
查看>>
css3动画——基本准则
查看>>
javaweb常识
查看>>
Java注解
查看>>
时间>金钱
查看>>
元数据元素
查看>>
Visual Studio Code 构建C/C++开发环境
查看>>
web自己主动保存表单
查看>>
lua基金会【五岁以下儿童】I/O文件操作
查看>>
一个小的日常实践——高速Fibonacci数算法
查看>>
创建与删除索引
查看>>
java的基本数据类型
查看>>