java嵌入式db_Java DB嵌入式模式

java嵌入式db

Java DB是基于Java编程语言和SQL的关系数据库管理系统。 这是Apache软件基金会的开源Derby项目的Oracle版本。 Java SE 7 SDK中包含Java DB。

Java DB有两个部署选项: EmbeddedNetwork Server

这篇文章是关于嵌入式部署或模式的。

1.嵌入式


在嵌入式模式下:

  • 该数据库只能从一个应用程序访问。
  • 应用程序和数据库之间没有网络连接。
  • 应用程序和数据库在同一JVM(Java虚拟机)中运行。

使用JDBC(Java数据库连接)从Java应用程序访问数据库。 通常,数据库由访问数据库的应用程序启动和停止。 并且,不需要数据库管理。

图片

启动Java DB

从应用程序启动Java DB。 首先,加载数据库JDBC驱动程序。 接下来,使用连接URL连接到数据库。

  • 该驱动程序包含在Java DB中: org.apache.derby.jdbc.EmbeddedDriver
  • 连接URL格式为: jdbc:derby:databaseName; URLAttributes;
  • 一个示例连接URL是jdbc:derby:SampleDB; create = true; ,其中数据库名称为SampleDB ,“ create = true”为属性名称/值对。

以下是使用JDBC启动数据库的示例Java方法:

/** The method creates a Connection object. Loads the embedded driver,* starts and connects to the database using the connection URL.*/
public static Connection createDatabaseConnection()throws SQLException, ClassNotFoundException {String driver = "org.apache.derby.jdbc.EmbeddedDriver";Class.forName(driver);String url = "jdbc:derby:sampleDB";Connection c = DriverManager.getConnection(url);return c;
}

通过上述方法创建的Connection对象用于使用SQL访问数据库对象和数据。 sampleDB是数据库的名称。

注意: derby.jar库必须位于使用Java DB Embedded的应用程序的类路径中。 该库包含驱动程序。 它包含在Java DB中。

使用“ ij”以交互方式访问Java DB数据库

ij是Java DB附带的命令行工具。 ij是用于在Java DB数据库上运行交互式查询的JDBC工具。 这位于Java DB安装的\ bin目录中。

启动ij,创建数据库并运行SQL命令来创建和访问数据:

os prompt> ij
ij> CONNECT 'jdbc:derby:testDB;create=true';
ij> Enter SQL commands here…

这将在当前目录中创建一个名为testDB的数据库并连接到该数据库。 Java DB数据库以与数据库名称相同的名称存储在目录内的文件中。

2.用法示例

一个示例用法是使用嵌入式数据库的基于Java Swing的桌面应用程序。 首次启动应用程序时,将创建数据库及其对象。 随后,应用程序创建或访问数据库中的数据。 该应用程序还具有在线备份数据库功能(即,在打开数据库时创建备份副本)和从备份数据库副本功能进行还原 。 数据库随应用程序关闭。

3.从多个客户端连接到嵌入式Java DB

可以从多个客户端访问嵌入式模式下的Java DB。 一个示例是部署在Web服务器上并连接到数据库的Java Servlet应用程序。 Java DB数据库在Web服务器上配置为DataSource类型的资源。 Servlet应用程序启动数据库并创建Connection对象。 Connection对象是使用DataSource对象而不是DriverManager创建的。 多个Web客户端通过应用程序访问数据库数据。

image2

一个例子

  • 在Web服务器上配置数据源资源
  • 从Servlet访问数据库(使用配置的数据源)

该配置适用于Apache Tomcat 6 Web服务器。 以下代码示例使用Java Servlet(Java EE),JNDI(Java命名和目录接口)和JDBC API。

3.1.1。 在Web服务器上配置数据源资源

这称为上下文配置。 这将JDBC数据源的JNDI名称定义为Web应用程序中使用的Java DB数据库的资源(用于JNDI查找)。 另外,指定资源参数。

以下条目已添加到文件“ /META-INF/context.xml”中。 META-INF目录将位于Web应用程序部署WAR文件的根目录中。

<Context><Resourcename="jdbc/testDB"auth="Container"type="javax.sql.DataSource"username=""password=""driverClassName="org.apache.derby.jdbc.EmbeddedDriver"url="jdbc:derby:testDB"/>
</Context>
  • name:是数据源资源的JNDI名称。
  • url:指定格式为jdbc:derby:databaseName; URLAttributes;的JDBC数据库连接URL 并且, testDB是要连接的Java DB数据库的名称。

请注意,应用程序从Derby系统目录访问嵌入式数据库。 默认情况下,当前目录(JVM系统属性user.dir )是系统目录。

对于Java DB,可以通过设置JVM系统属性derby.system.home来指定Derby系统目录(可选)。 在操作系统命令提示符下使用“ java”命令(例如, java -Dderby.system.home = D:\ mydatabases MyApplication )或在Java程序中(使用java.lang.System类的setProperty() )设置此参数。 。

注意:嵌入式数据库驱动程序(derby.jar)将放置在“ CATALINA_HOME \ lib”目录中。 CATALINA_HOME是Tomcat的安装目录。

3.1.2。 从Servlet访问数据库

以下Java代码显示了使用已配置的DataSource资源访问Java DB数据库的servlet类。 该代码假定已经创建了数据库(使用另一个应用程序或使用ij进行交互)。

public class TestServlet extends HttpServlet {
private Connection conn;
/** Method executes when the servlet is created.* Accesses the DataSource object and creates the Connection object.*/
@Override
public void init()throws ServletException {InitialContext cxt = null;DataSource ds = null;try {cxt = new InitialContext();ds = (DataSource)cxt.lookup("java:/comp/env/jdbc/testDB");}catch (NamingException ex) {throw new ServletException("naming context error", ex);}try {conn = ds.getConnection();}catch (SQLException ex) {throw new ServletException("connection error", ex);}
} // init()
/** Method to handle a Http Get request.* The Connection object created in init() is used to access the* database data using JDBC API. */@Overridepublic void doGet(HttpServletRequest req, HttpServletResponse resp)throws ServletException, IOException {...Statement stmnt = conn.createStatement();ResultSet rs = stmnt.executeQuery("SELECT * FROM test_table");...}
} // TestServlet

4.网络服务器(又名服务器)

在这种模式下,可以通过网络(客户端-服务器配置)从多个客户端访问Java DB。 数据库和应用程序在不同的JVM中运行。 使用JDBC从Java应用程序访问服务器上的数据库。

以下是服务器使用情况的示例。

启动服务器

使用提供的批处理程序(位于Java DB安装的\ bin目录中)从Windows命令提示符下启动和停止服务器: startNetworkServer.batstopNetworkServer.bat

从客户端应用程序访问Java DB

加载驱动程序并使用连接URL连接到数据库。

  • 驱动程序是: org.apache.derby.jdbc.ClientDriver
  • 连接URL格式为: jdbc:derby:// server:port / databaseName; URLAttributes;
  • server是主机名(或ip地址), port是服务器正在侦听客户端请求的端口号(默认为1527)。

以下是使用JDBC启动数据库的示例Java方法:

/** The method creates a Connection object. Loads the client driver,* starts and connects to the database using the connection URL.*/
public static Connection createDatabaseConnection()throws SQLException, ClassNotFoundException {String driver = "org.apache.derby.jdbc.ClientDriver";Class.forName(driver);String url = "jdbc:derby://localhost:1527/sampleDB";Connection c = DriverManager.getConnection(url);return c;
}

通过上述方法创建的Connection对象用于使用SQL访问数据库对象和数据。 sampleDB是数据库的名称。

注意: derbyclient.jar库必须位于客户端应用程序的类路径中,才能启动和访问Java DB数据库。 该库包含驱动程序。 它包含在Java DB中。

5.参考

  • Apache Derby>文档(10.8手册):http://db.apache.org/derby/manuals/index.html
  • Oracle的Java DB:http://www.oracle.com/technetwork/java/javadb/overview/index.html
  • 作者的Java DB备份和还原博客文章:http://www.javaquizplayer.com/blog.html
  • 作者开发和部署(并使用Java DB Embedded)基于Java Swing的桌面应用程序:http://www.scribonotes.com

翻译自: https://www.javacodegeeks.com/2013/07/java-db-embedded-mode.html

java嵌入式db

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/348358.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

群晖备份linux分区,数据丢失的后悔药,群晖NAS备份方案详解

“秒速开机”——据说90%的人都是因为这句话而知道的SSD固态硬盘。相比于机械硬盘&#xff0c;SSD固态硬盘开机快、关机快、打开软件快、载入数据快、拷贝快、删除也快——既快乐、又爽快&#xff0c;更是大块人心!然而&#xff0c;SSD固态硬盘已经可以完全取代机械硬盘了吗&am…

tg3269c网卡驱动linux,TP-Link3269C网卡驱动官方版

TG-3269C驱动是一款能够安装于由普联发布的无线网卡驱动&#xff0c;通过此安装驱动我们手机和其他无线设备才能连接上无线网卡并进行上网&#xff0c;同时如果你的网卡经常出现断开和重连、网络不稳定等情况可以通过重新安装驱动&#xff0c;查看是否是硬件的问题&#xff0c;…

使用Spring Security,Thymeleaf和Okta保护Java应用程序的安全

永不再构建身份验证 –喜欢构建用户管理&#xff1f; 使用Okta&#xff0c;您可以在几分钟内为您的应用程序添加社交登录&#xff0c;多因素身份验证和OpenID Connect支持。 立即创建一个免费的开发者帐户。 在构建Java应用程序时&#xff0c;用户管理是至关重要的考虑因素。 …

红旗linux添加usb无线网卡,在Ubuntu 8.10中安装无线网卡RTL8187SE驱动

本人的笔记本是微星的Wind U90&#xff0c;自带的无线网卡是RTL8187SE。这款无线网卡在一般的Linux下是没有驱动的&#xff0c;微星的官方也仅仅提供在OpenSUSE下的驱动。为了在我的Ubuntu下使用这个网卡&#xff0c;只能自己动手了。还好&#xff0c;有了互联网上各位大侠和微…

将Google reCaptcha与Spring Boot应用程序结合使用

介绍 Google的reCaptcha是一个用于防止漫游器向您的公共表单提交数据或访问您的公共数据的库。 在本文中&#xff0c;我们将研究如何将reCaptcha与基于Spring Boot的Web应用程序集成 设置验证码 您应该从管理面板创建API密钥。 您必须创建一个示例应用程序&#xff0c;如下所…

探索 HTTP 请求的世界:get 和 post 的奥秘(上)

&#x1f90d; 前端开发工程师&#xff08;主业&#xff09;、技术博主&#xff08;副业&#xff09;、已过CET6 &#x1f368; 阿珊和她的猫_CSDN个人主页 &#x1f560; 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 &#x1f35a; 蓝桥云课签约作者、已在蓝桥云…

linux 书签管理工具,在书签管理工具中使用Ubuntu字体

通过便捷书签管理程序(Bookmarklet&#xff0c;一种在浏览器中存放书签URL地址的应用程序)来在大多数的网站上推广使用Ubuntu系统的默认字体。——读者米格尔费尔南迪斯米格尔在他的想法产生之前告诉我们说&#xff1a;“我发现Ubuntu系统的字体在提高可读性上超过了绝大多数的…

linux18.2安装界面,Ubuntu 18.10下安装Grub Customizer 5.1.0配置grub2图形化界面

配置Grub2/burg引导装载程序Grub Customizer 5.1.0新增加对Ubuntu 18.10的支持&#xff0c;我们可以用PPA源来安装&#xff0c;同时还支持Ubuntu 18.04、16.04、14.04。Grub Customizer简介Grub Customizer是用来配置Grub/burg引导装载程序的图形工具&#xff0c;此次发布的5.1…

使用Eclipse和Open Liberty的Java EE 8上的Java 9

几周前&#xff0c;我写了一篇文章&#xff0c;标题为哪个IDE和服务器支持Java EE 8和Java9 &#xff0c;着眼于Java 9和Java EE 8之间的当前运行状态。您可以期待事情发展很快&#xff0c;我们现在有了一些alpha和支持Java 9和Java EE 8的开发版本。这些是– Payara 5 –适用…

Java命令行界面(第28部分):getopt4j

getopt4j的页面将其描述为“一个根据GNU样式解析命令行参数的库。” 然后&#xff0c; 页面介绍getopt4j &#xff1a;“getopt4j库旨在以与glibc &#xff08;GNU C运行时库&#xff09;中的C getopt&#xff08;&#xff09;函数相同的方式解析命令行选项。 与原始产品相比&a…

新版ipados可以编辑C语言吗,iPadOS新增了五个有用的功能,看你需不需要

主屏幕上的可自定义小部件苹果通过“ iOS 14”对“小工具”进行了大修&#xff0c;引入了新的设计&#xff0c;功能和自定义选项。这些“小部件”也出现在在iPhone上&#xff0c;您可以抓住任何小部件并将其添加到应用程序图标旁边的“主屏幕”中&#xff0c;但是不能在“ iPad…

c 语言已知两点求第三点,已知3点座标,求第一点到第二点和第三点构成的直线的距离。...

已知3点座标&#xff0c;求第一点到第二点和第三点构成的直线的距离。以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容&#xff0c;让我们赶快一起来看一下吧&#xff01;已知3点座标&#xff0c;求第一点到第二点和第三点构成的直线的距离。解…

android 组合属性动画,Android属性动画组合(sequence串行、together并行)

在android中用原生api实现一系列复杂动画会很麻烦&#xff0c;所以对属性动画进行了一定封装&#xff0c;让使用起来更简单&#xff0c;能够按照人的思维依次编写动画。简单效果&#xff1a;使用方法&#xff1a;添加依赖&#xff1a;dependencies { compile"com.steven:A…

jta atomikos_带有Atomikos示例的Tomcat中的Spring JTA多个资源事务

jta atomikos在本教程中&#xff0c;我们将向您展示如何使用Atomikos Transaction Manager在Tomcat服务器中实现JTA多个资源事务。 Atomicos事务管理器为分布式事务提供支持。 这些是多阶段事务&#xff0c;通常使用多个数据库&#xff0c;必须以协调的方式提交。 分布式事务由…

台电+android+电话,通话系统_台电 G17s_平板电脑评测-中关村在线

通话系统将两张联通3G的SIM卡插入台电G17s之后&#xff0c;我们来感受一下它通话系统的使用是否令人满意。和一般的双卡Android手机平板一样&#xff0c;该机也不支持热插拔&#xff0c;需要将机器彻底关闭后插入SIM卡再开机。并且在开机后屏幕会弹出SIM卡信息&#xff0c;并询…

功能Java示例 第2部分–讲故事

这是称为“ Functional Java by Example”的系列文章的第2部分。 我在本系列的每个部分中发展的示例是某种“提要处理程序”&#xff0c;用于处理文档。 在上一部分中&#xff0c;我从一些原始代码开始&#xff0c;并应用了一些重构来描述“什么”而不是“如何”。 为了帮助代…

OpenHub框架–下一个有趣的功能

这是有关OpenHub框架的系列文章中的第三篇&#xff0c;第一篇介绍OpenHub框架 &#xff0c;第二篇介绍异步消息传递模型 。 该系列的最后一篇文章将更详细地介绍其他一些有趣的功能&#xff0c;并说明为什么OpenHub可以成为您的集成项目的理想选择的原因。 节流 节流是一种功…

ubuntu生成密钥和证书_基于浏览器的密钥生成以及与浏览器的密钥/证书存储的交互...

ubuntu生成密钥和证书想象以下情况&#xff1a; 您需要从访问您的网站的用户那里获取一个密钥&#xff08;在非对称情况下为用户的公共密钥 &#xff09;&#xff0c;并希望浏览器记住私有部分&#xff0c;而不会因冗长的导入过程而困扰用户。 老实说&#xff0c;实际上&#…

android数据流分类,【Android工程之类】1 MVVM架构 - MVVM与单向数据流

前言这个系列将讲述使用MVVM架构、LiveData、Room、Kodein、Retrofit、EventBus来建立一个统一的、优雅的、可维护的TODO程序&#xff0c;本系列分为多个章节&#xff0c;从0开始一步一步引入这些优秀的库。下图展示的是Jetpack组件库包含的内容&#xff0c;这套的架构方案的核…

java ssl证书_Java安全教程–创建SSL连接和证书的分步指南

java ssl证书在有关应用JEE安全性的系列文章中&#xff0c;我们为您提供了另一个有关如何在Java EE应用程序中创建SSL连接和创建证书的详细教程。 如我们之前的文章中所述&#xff0c; 安全套接字层&#xff08;SSL&#xff09;/传输层安全性&#xff08;TLS&#xff09;将启用…