Java 生态圈中的嵌入式数据库,哪家强?

很多人可能觉得 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。

2.1、项目引入

因为 Derby 是用 java 编写的,所以集成的时候比较容易,直接通过maven在pom.xml中依赖库文件,即可进行开发!

org.apache.derby

derby

10.14.1.0

runtime

2.2、环境配置

和所有的数据库连接一样,基本都是配置驱动类、连接地址、账号、密码等信息。

String DRIVER_CLASS = “org.apache.derby.jdbc.EmbeddedDriver”;

String JDBC_URL = “jdbc:derby:derbyDB;create=true”;

String USER = “root”;

String PASSWORD = “root”;

说明:

org.apache.derby.jdbc.EmbeddedDriver表示使用derby嵌入式数据库模式。

JDBC_URL中的derbyDB表示创建一个名为derbyDB的临时数据库,如果没有会自动创建。

USER、PASSWORD主要用于客户端登录使用。

2.3、单元测试应用

下面,我们使用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_URL, USER, PASSWORD);

Statement statement = conn.createStatement();

//删除表

statement.execute(“DROP TABLE USER_INF”);

//创建表

statement.execute(“CREATE TABLE USER_INF(id VARCHAR(50) PRIMARY KEY, name VARCHAR(50) NOT NULL, sex VARCHAR(50) NOT NULL)”);

//插入数据

statement.executeUpdate("INSERT INTO USER_INF VALUES(‘1’, ‘程咬金’, ‘男’) ");

statement.executeUpdate("INSERT INTO USER_INF VALUES(‘2’, ‘孙尚香’, ‘女’) ");

statement.executeUpdate("INSERT INTO USER_INF VALUES(‘3’, ‘猴子’, ‘男’) ");

//查询数据

ResultSet resultSet = statement.executeQuery(“select * from USER_INF”);

while (resultSet.next()) {

System.out.println(resultSet.getInt(“id”) + ", " + resultSet.getString(“name”) + ", " + resultSet.getString(“sex”));

}

//关闭连接

statement.close();

conn.close();

}

}

输出结果:

1, 程咬金, 男

2, 孙尚香, 女

3, 猴子, 男

当程序运行完之后,会在当前项目根目录生成一个derbyDB文件夹,里面会存放一些持久化的数据,当下次再连接derbyDB数据库名称时,可以查询出之前插入的历史数据,这个特性可以防止数据丢失!

值得注意的是:derby 对很多 mysql 的关键字并不支持,同时 derby 不支持插入空值。

在之后的版本中,derby 还可以作为一个数据库服务器,通过jar启动单独部署在一台服务器上,在连接地址上加上 IP 和端口号,例如jdbc://derby://localhost:1527/derbyDB。

如果想使用可视化客户端工具来访问和管理derby,可以使用SQuirreL SQL Client客户端,下载地址http://www.squirrelsql.org/#installation。

在目前绝大多数的关于嵌入式数据库应用中,derby 的出场次数还是较少。

三、SQLite

SQLite 是 D.RichardHipp 用一个小型的C库开发的一种强有力的嵌入式关系数据库,虽然功能较 Berkeley DB(商业数据库)稍显逊色,但它简单易学、速度较快,同时提供了丰富的数据库接口,提供了对 SQL92 的大多数支持:支持多表和索引、事务、视图、触发和一系列的用户接口及驱动。

SQLite 不仅支持 Windows/Linux/Unix 等等主流的操作系统,同时能够跟很多程序语言相结合,比如 Tcl、C#、PHP、Java等,还有ODBC接口,比起 Mysql、PostgreSQL 这两款开源的世界著名数据库管理系统来讲,它的处理速度比他们都快,全部源码大致3万行C代码,文件大约 350KB,支持数据库大小至 2TB!

几乎常年占据嵌入式数据库的第一位!

3.1、SQLite安装

3.1.1、windows安装

1.访问 SQLite 下载页面https://www.sqlite.org/download.html。

2.下载sqlite-tools-win32-.zip和sqlite-dll-win32-.zip压缩文件。

3.创建文件夹C:\sqlite,并在此文件夹下解压上面两个压缩文件,将得到 sqlite3.def、sqlite3.dll和sqlite3.exe文件。

4.添加C:\sqlite到PATH环境变量。

最后在命令提示符下,输入sqlite3命令,显示如下结果表示安装成功!

C:>sqlite3

SQLite version 3.7.15.2 2013-01-09 11:53:05

Enter “.help” for instructions

Enter SQL statements terminated with a “;”

3.1.2、linux安装

目前,几乎所有版本的 Linux 操作系统都附带 SQLite。所以,只需要在命令行输入输入sqlite3,即可检查出机器上是否已经安装了 SQLite!

$ sqlite3

SQLite version 3.7.15.2 2013-01-09 11:53:05

Enter “.help” for instructions

Enter SQL statements terminated with a “;”

如果没有看到上面的结果,安装也很简单!

1.访问 SQLite 下载页面https://www.sqlite.org/download.html。

2.下载sqlite-autoconf-*.tar.gz并上传到 linux 服务器。

3.执行安装操作

例如,安装步骤示例:

$ tar xvzf sqlite-autoconf-3071502.tar.gz

$ cd sqlite-autoconf-3071502

$ ./configure --prefix=/usr/local

$ make

$ make install

3.1.3、mac安装

mac安装操作与linux类似。

3.2、项目引入

sqlite 也可以直接通过maven在pom.xml中依赖库文件,即可进行开发!

org.xerial

sqlite-jdbc

3.7.2

3.3、环境配置

String DRIVER_CLASS = “org.sqlite.JDBC”;

String JDBC_URL = “jdbc:sqlite:sqliteDB.db”;

String USER = “root”;

String PASSWORD = “root”;

说明:

org.sqlite.JDBC表示使用sqlite嵌入式数据库模式。

JDBC_URL中的sqliteDB表示创建一个名为sqliteDB的临时数据库,如果没有会自动创建。

USER、PASSWORD主要用于客户端登录使用。

3.4、单元测试应用

下面,来测试一下sqlite是否可以正常使用。

public class SQLiteTest {

/**

  • 以嵌入式(本地)连接方式连接数据库

*/

private static final String JDBC_URL = “jdbc:sqlite:sqliteDB.db”;

private static final String DRIVER_CLASS = “org.sqlite.JDBC”;

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_URL, USER, PASSWORD);

Statement statement = conn.createStatement();

//删除表

statement.execute(“DROP TABLE IF EXISTS USER_INF”);

//创建表

statement.execute(“CREATE TABLE USER_INF(id VARCHAR(50) PRIMARY KEY, name VARCHAR(50) NOT NULL, sex VARCHAR(50) NOT NULL)”);

//插入数据

statement.executeUpdate("INSERT INTO USER_INF VALUES(‘1’, ‘程咬金’, ‘男’) ");

statement.executeUpdate("INSERT INTO USER_INF VALUES(‘2’, ‘孙尚香’, ‘女’) ");

statement.executeUpdate("INSERT INTO USER_INF VALUES(‘3’, ‘猴子’, ‘男’) ");

//查询数据

ResultSet resultSet = statement.executeQuery(“select * from USER_INF”);

while (resultSet.next()) {

System.out.println(resultSet.getInt(“id”) + ", " + resultSet.getString(“name”) + ", " + resultSet.getString(“sex”));

}

//关闭连接

statement.close();

conn.close();

}

}

输出结果:

1, 程咬金, 男

2, 孙尚香, 女

3, 猴子, 男

当程序运行完之后,也会在当前项目的根目录下生成上文自定义的一个名为sqliteDB的文件。

每次操作名为sqliteDB的数据库时候,数据会持久化到sqliteDB文件中,从而防止数据丢失。

如果想使用可视化客户端工具来访问和管理sqliteDB,可以使用navicat来连接,选择生成的sqliteDB文件,输入相应的账号、密码,便可进行管理维护!

最后,附一张自己面试前准备的脑图:

image

面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典

  • Java核心知识整理

image

  • Spring全家桶(实战系列)

image.png

Step3:刷题

既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

以下是我私藏的面试题库:

image

很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。

最后祝愿各位身体健康,顺利拿到心仪的offer!
外链图片转存中…(img-yZhrKjgt-1719261930932)]

面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典

  • Java核心知识整理

[外链图片转存中…(img-sX9GvLNq-1719261930933)]

  • Spring全家桶(实战系列)

[外链图片转存中…(img-I9ttTlUF-1719261930933)]

Step3:刷题

既然是要面试,那么就少不了刷题,实际上春节回家后,哪儿也去不了,我自己是刷了不少面试题的,所以在面试过程中才能够做到心中有数,基本上会清楚面试过程中会问到哪些知识点,高频题又有哪些,所以刷题是面试前期准备过程中非常重要的一点。

以下是我私藏的面试题库:

[外链图片转存中…(img-l0UzcvD7-1719261930934)]

很多人感叹“学习无用”,实际上之所以产生无用论,是因为自己想要的与自己所学的匹配不上,这也就意味着自己学得远远不够。无论是学习还是工作,都应该有主动性,所以如果拥有大厂梦,那么就要自己努力去实现它。

最后祝愿各位身体健康,顺利拿到心仪的offer!

  • 29
    点赞
  • 26
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 最好的嵌入式开发板取决于您的需求和预算。如果您对性能要求较高,推荐 Raspberry Pi;如果您需要一个更小的开发板,推荐 Arduino;如果您需要一个可扩展性更开发板,推荐 BeagleBoard。最终的选择取决于您的项目需求。 ### 回答2: 提到最好的嵌入式开发板,很难给出一个确定的答案,因为最好的开发板取决于具体的需求和使用环境。下面我将列举几款备受推崇的嵌入式开发板,并介绍其特点,希望能对你有所帮助。 1. Raspberry Pi:这是一款广泛使用的低成本开发板,具有大的计算能力和丰富的扩展性。它支持多种操作系统,有丰富的社区和资源支持,适合初学者和开发者。 2. Arduino:Arduino是一款易于上手的开发板,拥有丰富的传感器和模块,可用于广泛的物联网应用。Arduino开发板可扩展性,社区活跃,有大量示例代码可供参考。 3. BeagleBone:BeagleBone 是一款高性能的开源开发板,具有大的功能和丰富的扩展接口。它支持多种操作系统,包括Linux系统,适合用于较复杂的项目开发。 4. NVIDIA Jetson:Jetson系列是专为人工智能应用而设计的嵌入式开发板,具有大的GPU加速能力和较高的算力,适合用于机器学习、计算机视觉等领域的开发。 总而言之,最好的嵌入式开发板因人而异,应根据具体需求选择适合的开发板。如果你是初学者,可以考虑Raspberry Pi或Arduino;如果需要较高性能和丰富的功能,可以考虑BeagleBone或NVIDIA Jetson。在选择时,建议参考用户评价、技术文档和社区支持,以便更好地满足项目需求。 ### 回答3: 嵌入式开发板的选择取决于您的需求和项目要求。目前市场上有许多优秀的嵌入式开发板,下面列举几个知名的开发板。 首先,树莓派(Raspberry Pi)被广大开发者认可为最优秀的嵌入式开发板之一。树莓派具有低成本、丰富的外设接口、大的处理能力和海量的软件资源。它适用于学习、教育和初级嵌入式开发。 其次是Arduino,它是一款开源硬件平台,被广泛应用于嵌入式系统的原型设计和开发。Arduino具有易学易用的特点,适合初学者和教育用途。其丰富的扩展板和库支持,使得Arduino成为了许多创客和爱好者的首选。 除了以上两个开发板,还有许多高性能的嵌入式开发板,如英特尔的英特尔 Galileo、贝叶斯的Jetson Nano等。这些开发板具有更的处理能力和更丰富的外设接口,适用于更为复杂的嵌入式应用需求。 综上所述,最好的嵌入式开发板因人而异,需要根据项目需求和个人喜好来选择。您可以根据开发板的成本、性能、扩展性以及对应的软件生态系统等因素来进行评估和选择。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值