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

学习笔记

Chapter 16整合数据库

16.1 JDBC入门

16.1.1 JDBC简介

  1. SUN公司为了简化、统一对数据库的操作,定义了一套Java操作数据库的规范(接口),称之为JDBC。这套接口由数据库厂商去实现,这样,开发人员只需要学习jdbc接口,并通过jdbc加载具体的驱动,就可以操作数据库。
  2. JDBC全称为:Java Data Base Connectivity(java数据库连接),它主要由接口组成。
  3. 组成JDBC的2个包:
java.sql
javax.sql
  1. 开发JDBC应用需要以上2个包的支持外,还需要导入相应JDBC的数据库实现(即数据库驱动)。

16.1.2 连接数据库

  1. 注册Driver操作对象

    (1)JDBC程序中的DriverManager用于加载驱动,并创建与数据库的链接,这个API的常用方法:

    DriverManager.registerDriver(new Driver()) DriverManager.getConnection(url, user, password)。

    (2)在实际开发中并不推荐采用registerDriver方法注册驱动。原因有二:

    1)查看Driver的源代码可以看到,如果采用此种方式,会导致驱动程序注册两次,也就是在内存中会有两个Driver对象。

    2)程序依赖mysql的api,脱离mysql的jar包,程序将无法编译,将来程序切换底层数据库将会非常麻烦。

    (3)推荐方式:Class.forName("com.mysql.jdbc.Driver"):

    采用此种方式不会导致驱动对象在内存中重复出现,并且采用此种方式,程序仅仅只需要一个字符串,不需要依赖具体的驱动,使程序的灵活性更高。
  2. 取得Connection操作对象

    (1)Jdbc程序中的Connection,它用于代表数据库的链接,Collection是数据库编程中最重要的一个对象,客户端与数据库所有交互都是通过connection对象完成的,这个对象的常用方法:
	createStatement():创建向数据库发送sql的statement对象。
 prepareStatement(sql) :创建向数据库发送预编译sql的PrepareSatement对象。
 prepareCall(sql):创建执行存储过程的callableStatement对象。
 setAutoCommit(boolean autoCommit):设置事务是否自动提交。
 commit() :在链接上提交事务。
 rollback() :在此链接上回滚事务。

16.1.3 使用Statement、ResultSet

  1. Jdbc程序中的ResultSet用于代表Sql语句的执行结果。Resultset封装执行结果时,采用的类似于表格的方式。ResultSet 对象维护了一个指向表格数据行的游标,初始的时候,游标在第一行之前,调用ResultSet.next() 方法,可以使游标指向具体的数据行,进行调用方法获取该行的数据。
  2. ResultSet既然用于封装执行结果的,所以该对象提供的都是用于获取数据的get方法:
  3. 获取任意类型的数据,例如:
getObject(int index) getObject(string columnName)
  1. 获取指定类型的数据,例如:
getString(int index)
getString(String columnName)
  1. ResultSet还提供了对结果集进行滚动的方法:
	next():移动到下一行
 Previous():移动到前一行
 absolute(int row):移动到指定行
 beforeFirst():移动resultSet的最前面。
 afterLast() :移动到resultSet的最后面。
  1. Statement在执行executeQuery()、executeUpdate()时,如果有些部分是动态的数据,必须用+连字符串接字符串以组成完整的SQL语句。
  2. 如果有些操作只是SQL语句当中某些参数不同,其余SQL子句皆相同,使用java.sql.PrepareStatement,使用Connection的preparedStatement()方法建立好预先编译好的SQL语句,用“?”代替参数中会变动的部分,需要真正指定参数执行时,再使用setInt()、setString()等方法指定“?”处应有的参数。
  3. 执行executeQuery()或executeUpdate()方法后,可以调用clearParameters()清除设置的参数,之后就能再次使用这个PreparedStatement实例。
  4. java.sql.CallableStatement的API使用与PreparedStatement差别不大,除了必须调用prepareCall()建立CallableStatement异常之外,一样是使用setXXX()设定参数,查询操作使用executeQuery(),更新操作使用executeUpdate(),使用registerOutParameter()注册输出参数。
  5. 日期在JDBC中,并不是使用java.util.Date,这个对象可代表的日期格式是“年、月、日、时、分、秒、毫秒”,JDBC表示日期,用java.sql.Date,日期格式是“年、月、日”,表示时间使用java.sql.Time,时间格式为“时、分、秒”,java.sql.Timestamp格式“时、分、秒、微秒”。

16.2 JDBC进阶

16.2.1 使用DataSource取得联机

  1. MessageDAO依赖于javax.sql.DataSource接口,可以通过其自定义的getConnection()方法取得Connection。

16.2.32使用ResultSet卷动、更新

  1. ResultSet时可默认使用next()移动数据光标至下一笔数据,而后使用getXXX()方法来取得数据。
  2. 使用Connection的createStatement()或prepareStatement()方法建立Statement或PreparedStatement实例时,可以指定结果集类型与并行方式。
  3. 使用absolute()、afterlast()、beforeFirst()、first()、last()进行绝对位置移动,使用relative()、previous()、next()进行相对位置移动,成功返回true,使用isAfterLast()、isBeforeFirst()、isFirst()、isLast()判断目前位置。
  4. 结果集类型可以指定3种设定:
ResultSet.TYPE_FORWARD_ONLY(默认)
ResultSet.TYPE_SCROLL_INSENSITIVE
ResultSet.TYPE_SCROLL_SENSITIVE
  1. 更新设定有两种指定:
ResultSet.CONCUR_READ_ONLY(默认)
ResultSet.CONCUR_UPDATABLE

16.2.3 批次更新

  1. 使用addBatch()方法来收集SQL,并使用executeBatch()方法将所收集的SQL传送出去.
  2. SQL的执行顺序就是addBath()时的顺序.

    16.2.4 Blob与Clob
  3. 文档写入数据库,可以在数据库表格字段上使用BLOB(Binary Large Object),用于存储大量的二进制数据或CLOB数据类型(Character Large Object),用于储存大量的文字数据.
  4. JDBC中提供了java.sql.Blob与java.sql.Clob两个类分别代表BLOB与CLOB数据.
  5. 通过PreparedStatement的setBlob()来设定Blob对象,读取数据时,可以通过ResultSet的getBlob()取得Blob对象。

    16.2.5 交易简介
  6. JDBC可以操作可以操作Connection的setAutoCommit()方法,给它false自变量,提示数据库开始交易。
  7. 下达一连串的SQL语句后,自行调用Connection的commit(),提示数据库确认操作,中间发生错误,调用rollback(),提示数据库撤销所有的执行。
  8. 隔离行为的支持上,JDBC可以通过Connection的getTransactionIsolation()取得数据库目前的隔离行为设定,通过setTransactionIsolation()可提示数据库设定指定的隔离行为,可设定常数是定义在Connection上。

    16.2.6 metadata简介
  9. JDBC,通过Connection的getMetaData()方法取得DatabasemetaData对象,通过该对象提供的方法取得数据库整体信息,Result表示查询到的数据。

    16.2.7 RowSet简介
  10. RowSet定义了列列集合基本行为,其下有JdbcRowSet(联机式的)、CachedRowSet(脱机式的)、FilteredRowSet、JoinRowSet与WebRowSet五个标准列操作子接口,定义在javax.sql.rowset。

代码托管截图

学习进度条

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

  1. 201521123027 <java程序设计>第九周学习总结

    1.本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结异常相关内容. 2.书面作业 Q1.常用异常 题目5-1 1.1 截图你的提交结果(出现学号) 1.2 自己以前编写的代码中经常出现什 ...

  2. 20145220java程序设计第九周学习总结

    20145220java程序设计第九周学习总结 教材学习内容总结 JBDC是用于执行SQL的解决方案,开发人员使用JDBC的标准接口,数据库厂商对接口直接操作,开发人员无须接触底层数据可驱动程序的差异 ...

  3. 201771010134杨其菊《面向对象程序设计java》第九周学习总结

                                                                      第九周学习总结 第一部分:理论知识 异常.断言和调试.日志 1.捕获 ...

  4. 201521044152<java程序设计>第一周学习总结

    本周学习总结 java开发时间虽然很短,但是发展迅速,已成为现在非常流行的一门语言,很开心能有幸学习java.第一周学习了java的平台,运行环境jdk以及jrt等等新名词,还了解了eclipse的基 ...

  5. 20145304 刘钦令 Java程序设计第二周学习总结

    20145304 <Java程序设计>第2周学习总结 教材学习内容总结 java可区分基本类型和类类型(即参考类型)两大类型系统. 基本类型主要可区分为整数.字节.浮点数.字符与布尔. 整 ...

  6. 20145304 刘钦令 Java程序设计第一周学习总结

    20145304<Java程序设计>第1周学习总结 教材学习内容总结 1995年5月23日,是公认的Java的诞生日,Java正式由Oak改名为Java. Java的三大平台是:Java ...

  7. 201621123007 Java程序设计第一周 学习总结

    第一周-Java基本概念 201621123007 <Java程序设计> 第一周学习总结 1. 本周学习总结 java是面向对象的一类语言,三大特征:封装性,继承性,多态性. jdk jr ...

  8. 马凯军201771010116《面向对象与程序设计Java》第九周学习总结

    一.理论知识部分 异常.日志.断言和调试 1.异常:在程序的执行过程中所发生的异常事件,它中断指令的正常执行. 2.Java的异常处理机制可以控制程序从错误产生的位置转移到能够进行错误处理的位置. 3 ...

  9. 201521123063 JAVA程序设计 第二周学习总结

    1.本周学习重点(2.27-3.5) java中的数组 以二维数组为例,数组名为scores,则 (1)先声明数组 int[][] scores;或int scores[][];或int[] scor ...

  10. 《Java》第九周学习总结

    下载mysql 选择mysql的管理软件 idea可以直接连接 然后用库运行程序,但是没有截图,,因为想在navicat上试试,可惜速度太慢了 打开idea又很慢,所以明天再更新

随机推荐

  1. base64图片解析

    大家可能注意到了,网页上有些图片的src或css背景图片的url后面跟了一大串字符,比如:data:image/png;base64, iVBORw0KGgoAAAANSUhEUgAAAAEAAAAk ...

  2. Python 常用资源

    Python:https://www.python.org/ftp/python/ Django:https://www.djangoproject.com/download/

  3. 1.1 VGA(图像显示卡),Graphics Card(图形加速卡),Video Card(视频加速卡),3D Accelerator Card 和 GPU(图形处理器)

    1.1 VGA(图像显示卡),Graphics Card(图形加速卡),Video Card(视频加速卡),3D Accelerator Card 和 GPU(图形处理器) 对这些概念之前也没怎么了解 ...

  4. ChromeExtension 写一个extension

    demo: https://github.com/rayshen/iExtensionDemo 使用: 1.打开扩展页面:chrome://extensions/ 2. 里面包含文件的结构是这样: 1 ...

  5. 多线程入门-第五章-线程的调度与控制之yield

    yield与sleep类似,只是不能指定暂停多长时间,并且只能让同优先级的线程有执行的机会,让位时间不固定. /* yield使用 */ public class ThreadTest04 { pub ...

  6. Ubuntu 下 chromium浏览器的标签乱码

    最近使用ubuntu系统,安装了个chromium浏览器,标题不会乱码,不过标签乱码,火狐浏览器没有这个问题,强大的互联网告诉我是少字体的原因,执行下面的指令即可. sudo apt-get inst ...

  7. VI乱码, cat 和 more正常

    今天在做一个东西的时候发现,vi乱码,cat,more这个文件汉字显示也正常,查了网上很多东西最后发现按一种说法改对了: 应该是格式化的问题! 比如man手册的文件有一些格式标记,你用man   ,c ...

  8. JavaScript json和字符串互转

    JavaScript内置json和字符串互转的函数JSON,不需要引入外部组件 JSON.stringify(obj)将JSON转为字符串. JSON.parse(string)将字符串转为JSON格 ...

  9. Linux进程虚拟地址空间管理2

    2017-04-12 前篇文章对Linux进程地址空间的布局以及各个部分的功能做了简要介绍,本文主要对各个部分的具体使用做下简要分析,主要涉及三个方面:1.MMAP文件的映射过程 2.用户 内存的动态 ...

  10. Spring Bean声明周期

    Bean的生命周期 理解Spring Bean的生命周期很容易.当一个bean被实例化时,它可能需要执行一些初始化使它转换成可用状态.同样,当bean不再需要,并且从容器中移除时,可能需要做一些清除工 ...