18. JDBC 数据库编程
数据持久技术概述
把数据保存到数据库中只是一种数据持久化方式。凡是将数据保存到存储介质中,需要的时候能够找到它们,并能够对数据进行修改,这些就属于数据持久化。
Java 中数据持久化技术有很多:
1. 文本文件
通过 Java I/O 流技术将数据保存到文本文件中,然后进行读写操作,这些文件一般是结构化的文档,如 XML、JSON 和 CSV 等文件。结构化文档就是文件内部采取某种方式将数据组织起来。
2. 对象序列化
序列化用于将某个对象以及它的状态写到文件中,它保证了被写入的对象之间的关系,当需要这个对象时,可以完整地从文件重新构造出来,并保持原来的状态。在 Java 中实现 java.io.Serilizable 接口的对象才能被序列化和反序列化。Java 还提供了两个流:ObjectInputStream 和 ObjectOutputStream。但序列化不支持事务处理、查询或者向不同的用户共享数据。序列化只适用于最简单的应用,或者在某些无法有效地支持数据库的嵌入式系统中。
3. 数据库
将数据保存数据库中是不错的选择,数据库的后面是一个数据库管理系统,它支持事务处理、并发访问、高级查询和SQL语言。Java 对象保存到数据库中主要的技术有:JDBC1、EJB2 和 ORM3 框架等。JDBC 是本书重点介绍的技术。
MySQL 数据库管理系统
介绍 JDBC 技术一定会依托某个数据库管理系统 (Database Management System,缩写 DBMS),还会使用 SQL 语句,所以本节先介绍一下数据库管理系统。
数据库管理系统负责对数据进行管理、维护和使用。现在主流数据库管理系统有 Oracle、SQL Server、DB2、Sysbase 和 MySQL 等,本节介绍 MySQL 数据库管理系统使用和管理。


