JavaDB(Derby)数据库使用

本文档介绍了如何使用JavaDB(Derby)作为内嵌数据库来构建小型管理系统,包括安装Derby,创建数据库,项目中连接数据库的内嵌模式,以及遇到的问题和解决方案。在内嵌模式下,通过IDEA配置数据库连接,成功插入数据并实现了程序的数据库交互。

因为项目需要,做一个单机运行的小型管理系统。
本使用的是java+mysql实现,然后使用exe4j打包成exe运行。
但目标机器不但要配置jre环境,也要安装mysql数据库。

注:关于如何使用户不用配置数据库。目前的解决方案有:

  • 让用户连接到远程mysql服务器
  • 编写文档,教用户安装java和mysql(注意指定版本)
  • 使用批处理文件,帮用户全部安装配置。

注:现在不是mysql+java的程序嘛,有什么方法可以制作成那种类似客户端的软件程序吗,就那种一点击安装就给用户把环境配好库建好的那种吗?
目前没有答案。

考虑到javaDB是内嵌数据库。现尝试使用java+javaDB构建系统。

开发环境:java1.8
IDE:Intell IDEA


一、 安装javaDB(Derby)

首先,javaDB环境配置
https://jingyan.baidu.com/article/f7ff0bfc76874a2e27bb137a.html

1.下载derby数据库放在一个位置中,我把他放在了D:\java\jdk1.8\db中。
2.配置环境变量。配置’path’变量,D:\java\jdk1.8\db\bin是DB目录下的bin目录
在这里插入图片描述
3.然后我们就安装成功derby数据库了。现在测试一下。
打开cmd。输入sysinfo进行测试。
在这里插入图片描述
可以看到derby安装成功。

二、创建derby数据库

  1. 创建数据库,首先先选择一个路径,用来存放数据库内容的。

就存放在E:\QuesManager\myderby目录下吧。
首先进入该目录。
在这里插入图片描述
在该目录下输入ij在这里插入图片描述
然后我们开始创建一个名为project的数据库,并连接该数据库
在这里插入图片描述
这时可以看到我们myderby文件夹下已经有了一个project的数据库
在这里插入图片描述
然后我们就可以建表了。
我们建一个user_info表,并插入数据。(注意:这里有个坑!!!user应该是关键字!!!我刚开始想建一个名为user的表半天弄不好!!!改成user_inf0后好了!!!)
在这里插入图片描述
INSERT INTO user_info VALUES (‘guanliyuan’, ‘123’, ‘guanliyuan’);
INSERT INTO user_info VALUES (‘tikuyuan’, ‘123’, ‘tikuyuan’);
INSERT INTO user_info VALUES (‘zujuanyuan’, ‘123’, ‘zujuanyuan’);
INSERT INTO user_info VALUES (‘组卷测试1’, ‘4568’, ‘zujuanyuan’);
在这里插入图片描述
可以看到插入数据成功。

三、项目连接数据库

3.1 内嵌模式连接derby

二种是内嵌模式,即是通过文件的形式.
我使用的编译器是idea
在项目中添加数据库
在这里插入图片描述
然后开始连接测试
在这里插入图片描述
【注意】这里有一个问题,刚开始test connection时候总是连接错误,报XJ040错误,后来知道是因为窗口ij还在连接数据库,是ij和web应用同时只能有一个连接当前这个derby数据库你把ij关掉web应用就可以正常连接数据库,把web应用停掉ij就可以正常连接数据库,我把刚才做建表建库的ij窗口关掉后就可以正常连接了。

连接成功后可以看到数据库内容了
![在这里插入图片描述](https://img-blog.csdnimg.cn/20190901202737377.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NpbmF0XzM4MzY4NjU4,size_16,co
记得在程序开始之前给项目中引入连接derby的jar包如下
在这里插入图片描述
然后我们开始编写程序

【问题】如何解决 方案"root"不存在的问题

3.2 网络模式连接derby

一种是网络模式,通过网络的链接形式(通常我们的mysql/oracle数据库,都是IP+端口),

【问题】使用ij连接数据库时如何进行可视化管理

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值