20145205 《Java程序设计》第9周学习总结
教材学习内容总结
第十六章
JDBC简介
撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找
JDBC目的:让Java程序设计人员在撰写数据库操作程序时可以有个统一的接口,无须依赖特定的数据库API,“写一个Java程序,操作所有数据库”
连接数据库
联机数据库,需要在classpath
中设定JDBC驱动程序
基本数据库操作相关JDBC接口或类是为位于java.sql
包中
Connection
接口的操作对象是数据库联机代表对象
使用Statement、ResultSet
Statement
是SQL描述的代表对象,可以使用executeUpdate()
、executeQuery()
等方法来执行SQL。
Statement
的executeUpdate()
方法用于SELECT
等查询数据库的SQL,返回int结果,表示数据变动的笔数
Statement
的executeQuery()
方法返回java.sql.ResultSet
对象,代表查询结果。
Statement
的execute()
方法用来执行SQL,返回true
表示SQL执行将返回ResultSet
作为查询结果。
使用PreparedStatement
、CallableStatement
如果有些操作只是SQL语句当中某些参数会有所不同,其余的SQL子句皆相同,则可以使用java.sql.PreparedStatement
。调用clearParametere()
清除设置的参数,之后就能再次使用这个
PreparedStatement
实例。
如果撰写数据库的预存程序,并想要使用JDBC来调用,则可使用java.sql.CallableStatement
。必须调用prepareCall()
建立CallableStatement
异常,可以使用registerOutParameter()
注册输出参数。
使用DataSource
取得联机
让MessageDAO
依赖于java.sql.DataSource
接口,可以通过其定义的getConnection()
方法取得Connection
。
日后要修改数据库服务器主机位置,为了打算重复利用Connection
对象而想要加入联机池机制等情况,这个MessageDAO
都不用修改。
联机相关信息可以使用.properties设定。
使用ResultSet
卷动、更新数据建立Statement
或PreparedStatement
实例时,可以指定结果集类型与并行方式。
批次更新
批次更新的限制是,SQL不能使SELECT,否则会抛出异常。
要支持批次更新,必须在JDBC URL 上附加rewriteBatchedStatements
=true
参数才有实际的作用。
Blob
与Clob
BLOB
用于存储大量的二进制数据,像是图档、影音档等;CLOB
用于存储大量的文字数据。
可以把BLOB
字段对应byte[]
或输入\输出串流。
交易简介
在交易管理时,仅想要撤回某个SQL执行点,则可以设定存储点。
通过JDBC得知数据库是否支持某个隔离行为设定,可以通过Connection
的getMetaData()
取得DatabaseMetadata
对象,通过DatabaseMetadata
的supportTransaction-IsolationLevel()
得知是否支持某个隔离行为。
metadata
简介Metadata
即“诠读数据的数据”,可以通过connection
的getMetaData()
方法取得
DatabaseMetaData
对象,可以取得数据库整体信息,而ResultSet
表示查询到的数据,可以通过ResultSet
的getMetaData()
方法,取得ResultSetMetaData
对象。
RowSet
简介javax.sql.RowSet
接口,代表数据的列集合。可以对列集合进行增删改查。通过setCommand()
设定查询指令,通过execute()
执行查询指令以填充数据。
其他(感悟、思考等,可选)
本周因为个人的一些事情对于学习比较懈怠,没有很好的区分开生活和学习,让生活中的事情影响了学习,但是人本来就是感性的,也是我们区别于蛮夷的分界线,面对挫折或是困难或是低谷或是发现人心难测更或是世道艰险,我们难度真的可以一带而过,去机械的做自己的工作?即使是干了几十年的老医生,面对死亡尚且难过多日,更不说事情发生在自己的身上的时候,那个中滋味又能与谁堪说,欠下总会补上的,但是错过的就是错过了。
学习进度条
代码行数(新增/累积) | 博客量(新增/累积) | 学习时间(新增/累积) | 重要成长 | |
---|---|---|---|---|
目标 | 4500行 | 25篇 | 350小时 | |
第一周 | 100/100 | 1/2 | 15/15 | |
第二周 | 150/250 | 1/3 | 12/27 | |
第三周 | 400/650 | 1/4 | 22/49 | |
第四周 | 510/1160 | 1/5 | 32/81 | |
第五周 | 831/1991 | 1/6 | 35/116 | |
第六周 | 945/1991 | 2/6 | 26/142 | |
第七周 | 236/2227 | 3/9 | 18/160 | |
第八周 | 267/2494 | 2/11 | 18/178 | |
第九周 | 136/2620 | 2/13 | 10/188 |
参考资料
20145205 《Java程序设计》第9周学习总结的更多相关文章
- 20145213《Java程序设计》第九周学习总结
20145213<Java程序设计>第九周学习总结 教材学习总结 "五一"假期过得太快,就像龙卷风.没有一点点防备,就与Java博客撞个满怀.在这个普天同庆的节日里,根 ...
- 20145213《Java程序设计》第二周学习总结
20145213<Java程序设计>第二周学习总结 教材学习内容总结 本周娄老师给的任务是学习教材的第三章--基础语法.其实我觉得还蛮轻松的,因为在翻开厚重的书本,一股熟悉的气息扑面而来, ...
- 20145213《Java程序设计》第一周学习总结
20145213<Java程序设计>第一周学习总结 教材学习内容总结 期待了一个寒假,终于见识到了神秘的娄老师和他的Java课.虽说算不上金风玉露一相逢,没有胜却人间无数也是情理之中,但娄 ...
- 21045308刘昊阳 《Java程序设计》第九周学习总结
21045308刘昊阳 <Java程序设计>第九周学习总结 教材学习内容总结 第16章 整合数据库 16.1 JDBC入门 16.1.1 JDBC简介 数据库本身是个独立运行的应用程序 撰 ...
- 20145330孙文馨 《Java程序设计》第一周学习总结
20145330孙文馨 <Java程序设计>第一周学习总结 教材学习内容总结 刚开始拿到这么厚一本书说没有压力是不可能的,开始从头看觉得很陌生进入不了状态,就稍微会有一点焦虑的感觉.于是就 ...
- 20145337 《Java程序设计》第九周学习总结
20145337 <Java程序设计>第九周学习总结 教材学习内容总结 数据库本身是个独立运行的应用程序 撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的增删查找 JDBC可以 ...
- 20145337 《Java程序设计》第二周学习总结
20145337 <Java程序设计>第二周学习总结 教材学习内容总结 Java可分基本类型与类类型: 基本类型分整数(short.int.long).字节(byte).浮点数(float ...
- 20145218《Java程序设计》第一周学习总结
20145218 <Java程序设计>第一周学习总结 教材学习内容总结 今天下午看了Java学习的视频,感觉很是新奇,之前觉得Java学起来是艰难枯燥的,但通过第一章的学习觉得如果自己可以 ...
- 《Java程序设计》第九周学习总结
20145224 <Java程序设计>第九周学习总结 第十六章 整合数据库 JDBC入门 ·数据库本身是个独立运行的应用程序 ·撰写应用程序是利用通信协议对数据库进行指令交换,以进行数据的 ...
- 《Java程序设计》第二周学习总结
20145224陈颢文<Java程序设计>第二周学习总结 教材学习内容总结 一.类型.变量与运算符 1.类型 整数: 可细分为为short整数(占2字节),int整数(占4字节),long ...
随机推荐
- Github.com上有哪些比较有趣的PHP项目?
链接就不贴了,可以在github上进行搜索.这里就不列举 symfony.laravel 这些大家都知道的项目了.只列举比较有意思的. swoole, C扩展实现的PHP异步并行网络通信框架,可以重新 ...
- 用Bitbucket搭建博客初探
本博客是搭建在GitHub上的静态博客,但是由于GitHub免费账户不能创建私有仓库,导致有些东西不想放在GitHub上. 前两天,在免费资源部落上发现了Bitbucket,它和GitHub类似,也是 ...
- SET基本数据类型
aaarticlea/png;base64,iVBORw0KGgoAAAANSUhEUgAAAO4AAADZCAIAAACo85tgAAAgAElEQVR4Aey9SdAs13XnV/P8jW8e8D
- time和datetime时间戳---python
time模块 time模块提供各种操作时间的函数 说明:一般有两种表示时间的方式: 1.时间戳的方式(相对于1970.1.1 00:00:00以秒计算的偏移量),时间戳是惟一的 2.以数 ...
- C# mongodb 驱动操作(Z)
Query.All("name", "a", "b");//通过多个元素来匹配数组 Query.And(Query.EQ("nam ...
- nginx配置文件或目录404和403
对于Nginx web目录下的文件,如果不想用户访问那么可以配置返回404或者403状态,默认情况下对于目录来说,如果目录下没有默认文档,那么默认返回是403,也就是不允许查看目录列表,但是如果知道静 ...
- JavaScript高级程序设计学习笔记--事件
HTML事件处理程序 <input type="button" value="Click Me" onclick"showMessage()&q ...
- SQL入门语句之INSERT、UPDATE和DELETE
一.SQL入门语句之INSERT insert语句的功能是向数据库的某个表中插入一个新的数据行 1.根据对应的字段插入相对应的值 insert into table_name(字段A, 字段B, 字段 ...
- 如何破解mac版UltraEdit?
Rodolfo教你如何破解UtralEdit? 第一步:去官网下载原载,先运行一次: 第二步:在终端里执行下面代码就可以破解完成!printf '\x31\xC0\xFF\xC0\xC3\x90' | ...
- C语言中字符串结束符'\0'
转自:http://www.cnblogs.com/kaituorensheng/archive/2013/12/09/3464462.html 本质 '\0'就是8位的00000000,因为字符类型 ...