20165228 2017-2018-2 《Java程序设计》第7周学习总结

教材学习内容总结

  • MySQL数据库管理系统安装和初始化
  • 使用MySQL建立连接和数据库、表
  • 使用JDBC:(1)与一个数据库建立连接。

    (2)向数据库发送SQL语句。

    (3)处理数据库返回的结果。
  • 应用程序负责加载的JDBC-MySQL数据库驱动,代码如下:
try{  Class.forName("com.mysql.jdbc.Driver");
}
catch(Exception e){}
  • 应用程序要和MySQL数据库服务器管理的数据库students(在11.3节建立的数据库)建立连接
  • 使用Connection getConnection(java.lang.String) 方法建立连接的代码如下:
Connection con;
String uri =
"jdbc:mysql://192.168.100.1:3306/students?user=root&password=&useSSL=true";
try{
con = DriverManager.getConnection(uri); //连接代码
}
catch(SQLException e){
System.out.println(e);
}
  • 使用Connection getConnection(java.lang.String, java.lang.String, java.lang.String)方法建立连接的代码如下:
Connection con;
String uri = "jdbc:mysql:// 192.168.100.1:3306/students? useSSL=true";
String user ="root";
String password ="";
try{
con = DriverManager.getConnection(uri,user,password); //连接代码
}
catch(SQLException e){
System.out.println(e);
}
  • 如果数据库的表中的记录有汉字,那么在建立连接时需要额外多传递一个参数characterEncoding,并取值gb2312或utf-8
String uri =
"jdbc:mysql://localhost/students?useSSL=true&characterEncoding=utf-8";
con = DriverManager.getConnection(uri, "root",""); //连接代码
  • 查询操作:

    1、得到SQL查询语句对象
try{  Statement sql=con.createStatement();
}
catch(SQLException e ){}

2、这个对象就可以调用相应的方法实现对数据库中表的查询和修改,并将查询结果存放在一个ResultSet类声明的对象

ResultSet rs = sql.executeQuery("SELECT * FROM students");

也就是说SQL查询语句对数据库的查询操作将返回一个ResultSet对象,ResultSet对象是按“列”(字段)组织的数据行构成。

  • 关闭连接:

    ResultSet对象和数据库连接对象(Connection对象)实现了紧密的绑定,一旦连接对象被关闭,ResultSet对象中的数据立刻消失。这就意味着,应用程序在使用ResultSet对象中的数据时,就必须始终保持和数据库的连接,直到应用程序将ResultSet对象中的数据查看完毕
con.close();

此后,程序将无法获取ResultSet对象中的数据

  • 顺序查询:

    指ResultSet对象一次只能看到一个数据行,使用next()方法移到下一个数据行,next()方法最初的查询位置,即游标位置,位于第一行的前面。next()方法向下(向后、数据行号大的方向)移动游标,移动成功返回true,否则返回false
  • 使用下述方法获得一个Statement对象,从而得到一个可滚动的结果集
Statement stmt = con.createStatement(int type ,int concurrency);
  • 条件和排序查询:

    1. where子语句

    一般格式:
select 字段 from 表名 where 条件
    2. 排序
用order by子语句对记录排序
select * from mess where name like '%林%' order by name
  • 更新操作
update  表 set 字段 = 新值 where <条件子句>
  • 添加操作
insert into 表(字段列表) values (对应的具体的记录)

insert into 表 values (对应的具体的记录)
  • 删除操作
delete from  表名 where <条件子句>
  • 使用预处理语句和通配符
  • 通用查询:

    编写一个类,只要用户将数据库名、SQL语句传递给该类对象,那么该对象就用一个二维数组返回查询的记录。
  • 事务:

    事务由一组SQL语句组成,所谓事务处理是指:应用程序保证事务中的SQL语句要么全部都执行,要么一个都不执行
  • JDBC事务处理步骤:

    1.用setAutoCommit(booean b)方法关闭自动提交模式

    2.用commit()方法处理事务

    3.用rollback()方法处理事务失败

教材学习中的问题和解决过程

  • 问题1:教材中提到“JDBC操作不同的数据库仅仅是连接方式上的差异而已”,连接方式有什么差异呢?
  • 问题1解决方案:参考JDBC各种数据库连接方式

代码调试中的问题和解决过程

  • 问题1:在按照配套PPT使用windows安装MySqlt初始data时出错

  • 问题1解决方案:进入C:/windows/system32 ,找到cmd,通过管理员身份运行cmd,在mysql目录的bin子目录下输入mysqld --initialize-insecure可以初始化成功

代码托管

(statistics.sh脚本的运行结果截图)

上周考试错题总结

  • 错题1:

    下列关于HashMap泛型类常用方法的介绍,正确的是 ACD

    A.public boolean isEmpty()如果此映射不包含键-值映射关系,则返回 true。

    B.public V get(Object key)返回指定键所映射的值;如果此映射不包含该键的映射关系,则抛出异常。

    C.public V put(K key, V value) 在此映射中关联指定值与指定键。如果该映射以前包含了一个该键的映射关系,则以先定义的值为准。

    D.public Object clone()返回此 HashMap 实例的浅表副本:并不复制键和值本身。
  • 解析:查询API。B项:如果此映射不包含该键的映射关系,则返回null。C项:如果该映射以前包含了一个该键的映射关系,则旧值被替换。
  • 错题2:

    下列关于TreeSet泛型类常用方法的介绍,正确的是 BCD

    A.public boolean contains(Object o) 如果此 set 包含指定的元素,则返回 true。如果指定对象无法与该 set 中的当前元素进行比较,或不包含,则返回false。

    B.public boolean add(E e)将指定的元素添加到此 set。如果此 set 已经包含这样的元素,则该调用不改变此 set 并返回 false。

    C.public boolean addAll(Collection<? extends E> c)将指定 collection 中的所有元素添加到此 set 中。如果此 set 由于调用而发生更改,则返回 true。

    D.public E lower(E e) 返回此 set 中严格小于给定元素的最大元素;如果不存在这样的元素,则返回 null。
  • 解析:A项:如果指定对象无法与该 set 中的当前元素进行比较,则抛出ClassCastException异常。查询API。B项:如果此映射不包含该键的映射关系,则返回null。C项:如果该映射以前包含了一个该键的映射关系,则旧值被替换。
  • 错题3:

    String类中的length()方法用来获取一个String对象的字符序列的长度,单位为字节。 B

    A.true

    B.false
  • 解析:长度等于字符串中 Unicode 代码单元的数量。
  • 错题4:

    public boolean startsWith(String prefix)方法,如果参数是空字符串,则抛出异常。 B

    A.true

    B.false
  • 解析:返回的结果是true
  • 错题5:

    下列关于public int compareTo(String anotherString)的说法,正确的是 ACDE

    A.按字典顺序比较两个字符串。该比较基于字符串中各个字符的 Unicode值。

    B.如果按字典顺序此 String 对象位于参数字符串之前,则比较结果为一个正整数。

    C.如果它们在一个或多个索引位置上的字符不同,假设 k 是这类索引的最小值,compareTo 返回这两个字符串在位置 k 处两个char 值的差,即值:this.charAt(k)-anotherString.charAt(k)

    D.如果没有字符不同的索引位置,则较短字符串的字典顺序在较长字符串之前。在这种情况下,compareTo 返回这两个字符串长度的差

    E.compareTo 只在方法 equals(Object) 返回 true 时才返回 0。
  • 解析:查询API。B项:返回一个负整数。
  • 错题6:

    下列关于substring方法的说法,正确的是 ACD

    A.public String substring(int beginIndex)返回的子字符串从指定索引处的字符开始,直到此字符串末尾。

    B.public String substring(int beginIndex, int endIndex) 子字符串从指定的 beginIndex 处开始,直到索引 endIndex处的字符。

    C."emptiness".substring(9)返回值为""。

    D."smiles".substring(1, 5)返回值为"mile"。

    E.若beginIndex 大于 endIndex,则substring(int beginIndex, int endIndex)返回-1。
  • 解析:查询API。B项:直到索引 endIndex - 1 处的字符。E项:抛出IndexOutOfBoundsException异常
  • 错题7:

    下列说法错误的是 D

    A.java.util包中的Data类重写了toString()方法。

    B.Arrays和Point都继承了toString方法。

    C.调用x.toString()方法的地方可以用""+x代替。

    D.定义int[] Numbers = {1, 2, 3}; String s1 = ""+Numbers;,则System.out.println(s1);调用了toString方法,可以将数组输出。
  • 解析:D项:若想打印数组,数组必须调用静态方法Arrays.toString,也就是将以上程序中的String s1 = ""+Numbers;改为String s1 = Arrays.toString(Numbers);。如果要打印多维数组,则需要调用Arrays.deepToString方法。
  • 错题8:

    下列关于字符串与字符数组、字节数组的说法,正确的是 ACD

    A.getChars (int srcBegin, int srcEnd, char[] dst, int dstBegin)方法的返回值为空。

    B.srcEnd是字符串中要复制的最后一个字符的索引。

    C.srcBegin 大于 srcEnd时,会抛出IndexOutOfBoundsException异常。

    D.要复制到 dst 子数组的字符从索引 dstBegin 处开始,并结束于索引dstbegin + (srcEnd-srcBegin) - 1
  • 解析:查询API。B项:srcEnd是字符串中要复制的最后一个字符之后的索引。
  • 错题9:

    下列关于正则表达式的说法,正确的是 ABDE

    A.\ba\w*\b匹配以字母a开头的单词

    B.\d+匹配1个或更多连续的数字。

    C.\b\w{6}\b 匹配6个及以上字符的单词。

    D.[0-9]代表的含意与\d就是完全一致的:一位数字

    E.\S+匹配不包含空白符的字符串。

    F.(\d{1,3}.){3}\d{1,3}用来匹配 IP地址。
  • 解析:C项:\b\w{6}\b 匹配刚好6个字符的单词。F项: IP地址中每个数字都不能大于255,该表达式忽略了这个约束条件。正确的是((2[0-4]\d|25[0-5]|[01]?\d\d?).){3}(2[0-4]\d|25[0-5]|[01]?\d\d?)。

结对及互评

  • 博客中值得学习的或问题:

    要素全面

    很认真细致

    排版简介美观
  • 代码中值得学习的或问题:

    代码中文件分类简洁

    很认真

其他(感悟、思考等,可选)

本周学习了如何安装和使用MySQL数据库管理系统,建立连接,关闭链接,以及查询、添加、删除等各种操作

学习进度条

代码行数(新增/累积) 博客量(新增/累积) 学习时间(新增/累积) 重要成长
目标 5000行 25篇 400小时
第一周 235/235 1/1 15/15
第二周 224/459 2/3 15/30
第三周 443/902 1/4 15/73
第四周 577/1479 2/6 17/90
第五周 1222/2360 1/7 14/104
第六周 1527/3294 1/8 14/118
第七周 591/3883 1/9 14/132
  • 计划学习时间:15小时
  • 实际学习时间:14小时

20165228 2017-2018-2 《Java程序设计》第7周学习总结的更多相关文章

  1. 学号 20175212 《Java程序设计》第九周学习总结

    学号 20175212 <Java程序设计>第九周学习总结 教材学习内容总结 一.MySQL数据库管理系统 1.在官网上下载并安装MySQL 2.在IDEA中输入测试代码Connectio ...

  2. 20145213《Java程序设计》第九周学习总结

    20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...

  3. 20145213《Java程序设计》第二周学习总结

    20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...

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

    20145213<Java程序设计>第一周学习总结 教材学习内容总结 期待了一个寒假,终于见识到了神秘的娄老师和他的Java课.虽说算不上金风玉露一相逢,没有胜却人间无数也是情理之中,但娄 ...

  5. 21045308刘昊阳 《Java程序设计》第九周学习总结

    21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...

  6. 20145330孙文馨 《Java程序设计》第一周学习总结

    20145330孙文馨 <Java程序设计>第一周学习总结 教材学习内容总结 刚开始拿到这么厚一本书说没有压力是不可能的,开始从头看觉得很陌生进入不了状态,就稍微会有一点焦虑的感觉.于是就 ...

  7. 20145337 《Java程序设计》第九周学习总结

    20145337 <Java程序设计>第九周学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC可以 ...

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

    20145337 <Java程序设计>第二周学习总结 教材学习内容总结 Java可分基本类型与类类型: 基本类型分整数(short.int.long).字节(byte).浮点数(float ...

  9. 20145218《Java程序设计》第一周学习总结

    20145218 <Java程序设计>第一周学习总结 教材学习内容总结 今天下午看了Java学习的视频,感觉很是新奇,之前觉得Java学起来是艰难枯燥的,但通过第一章的学习觉得如果自己可以 ...

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

    20145224 <Java程序设计>第九周学习总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的 ...

随机推荐

  1. 【LeetCode】字符串匹配

    给定目标串 haystack 和模式串 needle ,返回 needle 在 haystack 中第一次出现的位置下标,若 needle 不是 haystack 的子串则返回 -1. 1. Brut ...

  2. GitHub 简单用法

    1. GitHub账号的申请 首先打开Github主页,https://github.com 如果你没有登录过的话会打开如下图的界面(登录过你就不用看这段了), 注册画面如下: 注意右侧不是登陆界面而 ...

  3. zookeeper 选举和同步

    节点状态: // org.apache.zookeeper.server.quorum.QuorumPeer.ServerState public enum ServerState { LOOKING ...

  4. Find a way out of the ClassLoader maze

    June 6, 2003 Q: When should I use Thread.getContextClassLoader() ? A: Although not frequently asked, ...

  5. python匿名函数以及return语句

  6. WINDOWS 端口查看

    查看Windows下所有使用的端口 netstat -ano 查看Windows下某一个特定的端口 netstat -ano | find "8080"   查看windows下所 ...

  7. HTML编辑笔记1

    1.编写html ①新建一个记事本(以.html结尾) ②右击选择打开方式为文档 ③编写内容 ④用浏览器查看内容 2.html编写格式 <html> <head></he ...

  8. day35 数据库介绍和初识sql

    今日内容: 1. 代码: 简易版socketsever 2.数据库(mysql)简单介绍和分类介绍 3.mysql root修改密码 4.修改字符集编码 5.初识sql语句 1.简易版socketse ...

  9. Top k问题的讨论(三种方法的java实现及适用范围)

    在很多的笔试和面试中,喜欢考察Top K.下面从自身的经验给出三种实现方式及实用范围. 合并法 这种方法适用于几个数组有序的情况,来求Top k.时间复杂度为O(k*m).(m:为数组的个数).具体实 ...

  10. Java数值类型之间转换

    Java之间的数值转换如图所示,实心箭头代表无数据丢失,虚线箭头代表可能丢失 例如:123456789是一个大的整数,包含的位数比float类型能够表达的位数多,但这个数转换为float类型时,将会得 ...