嵌入式数据库知识概括

本文介绍了嵌入式数据库的概念,对比分析了SQLite、Derby和H2这三种开源免费的嵌入式数据库,包括它们的简介、使用方法、性能特点以及适用场景。SQLite因其跨平台和广泛支持而广泛应用,Derby适合Java程序,H2则以其高性能和与MySQL的兼容性受到青睐。
摘要由CSDN通过智能技术生成

嵌入式数据库知识概况

嵌入式数据库

嵌入式数据库(Embedded Database)简介:

  • 从软件角度来说,数据库分类为两种:
    ①第一种:数据库服务器(Database Server)
    ②第二种:嵌入式数据库(Embedded Database)
  • 像 Oracle、PostgreSQL、MySQL 和 SQL Server等这些大家熟知的数据库,我们一般称它为数据库服务器,当然也不排除某些数据库也提供嵌入式版本,例如 MySQL Embedded就是一个嵌入式的数据库。
  • 而像 SQLite、Berkeley DB、Derby、H2、HSQL DB等数据库,一本内嵌在应用程序中,与应用程序一起运行,我们称它为嵌入式数据库。
  • 嵌入式数据库跟数据库服务器最大的区别在于它们运行的地址空间不同。通常,数据库服务器独立地运行一个守护进程(daemon),而嵌入式数据库与应用程序运行在同一个进程。

为何会出现嵌入式数据库呢?

  • 在实际开发中,平时接触最多的应该是数据库服务器,对嵌入式数据库使用的比较少。
  • 在小型的应用程序中,例如小型掌上游戏机,不适合部署高达几百兆的数据库服务器,同时也没有联网的必要,一种轻量级的数据库需求由此诞生!
  • 与常见的数据库相比,嵌入式数据库具有体积小、功能齐备、可移植性、健壮性等特点,例如我们所熟知的 SVN 版本控制软件就使用到了SQLite 作为内置数据库,SQLite 的安装包只有不到 350 KB,在微型机中也有着广泛的应用,例如安卓、IOS等移动设备操作系统都内置了 SQLite 数据库!
  • 鉴于嵌入式数据库的种类比较多,有商业收费的、也有开源免费的!本文主要介绍开源免费版的,例如 DerbySQLiteH2等,下面我们就一起来实践一下各个数据库的配置和用法。

Derby

Derby简介:

  • Derby 可以说是 100% 由 Java 编写的一款数据库,而且是开源免费的,非常小巧,核心部分derby.jar只有 2M!
  • 很多人可能觉得 Derby 不是很热门,但 Derby 已经开发了将近二十年!
    1996 年,一个叫做 Cloudscape, Inc 的新公司成立了,公司的目标是构建一个用 Java 语言编写的数据库服务器。公司的第一个发行版在一年之后推出,后来产品的名称变成 Cloudscape。1999 年,Cloudscape, Inc. 被大型数据库厂商 Informix Software, Inc. 收购。Informix Software 在 2001 年又被 IBM 收购,然后 IBM Cloudscape™ 数据库系统在许多 IBM的产品中被用作内嵌的数据库引擎。2004 年 4 月,IBM 把 Cloudscape 数据库软件赠送给 Apache 软件基金会,从此 Apache Derby项目诞生了。接着 SUN 也为 Derby 捐献了一个团队。在JavaSE6.0中,SUN 将其命名为JavaDB。

Derby使用:

  • 项目引入:因为 Derby 是用 java 编写的,所以集成的时候比较容易,直接通过maven在pom.xml中依赖库文件,即可进行开发!
<!--derby数据库--> 
<dependency> 
    <groupId>org.apache.derby</groupId> 
    <artifactId>derby</artifactId> 
    <version>10.14.1.0</version> 
    <scope>runtime</scope> 
</dependency> 
  • 环境配置:和所有的数据库连接一样,基本都是配置驱动类、连接地址、账号、密码等信息。
    ①org.apache.derby.jdbc.EmbeddedDriver表示使用derby嵌入式数据库模式。
    ②JDBC_URL中的derbyDB表示创建一个名为derbyDB的临时数据库,如果没有会自动创建。
    ③USER、PASSWORD主要用于客户端登录使用。
String DRIVER_CLASS = "org.apache.derby.jdbc.EmbeddedDriver"; 
String JDBC_URL = "jdbc:derby:derbyDB;create=true"; 
String USER = "root"; 
String PASSWORD = "root"; 

单元测试应用:

  • 下面,我们使用JDBC编写一个测试类,来测试一下derby是否可以正常使用。
public class DerbyTest {
    
 
    /** 
     * 以嵌入式(本地)连接方式连接数据库 
     */ 
    private static final String JDBC_URL = "jdbc:derby:derbyDB;create=true"; 
    private static final String DRIVER_CLASS = "org.apache.derby.jdbc.EmbeddedDriver"; 
    private static final String USER = "root"; 
    private static final String PASSWORD = "root"; 
 
 
    public static void main(String[] args) throws Exception {
    
        //与数据库建立连接 
        Class.forName(DRIVER_CLASS); 
        Connection conn = DriverManager.getConnection(JDBC_U
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值