java 连接 firebird

2023-10-30 16:49
文章标签 java 连接 firebird

本文主要是介绍java 连接 firebird,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java中使用fb(jaybird)
到这里下载最新版的jaybird(fb的jdbc Driver)
http://www.firebirdsql.org/index.php?op=files&id=jaybird
它是4类型jdbc驱动,根本不需要odbc中转,是效率最好的类型(具体见jdbc驱动类型说明)。而且它实现大部分jdbc2.0接口。

解压后看看docs/faq.html,里面有大多你想要的答案。

为扮装高手帮助“懒人”,我就继续罗嗦下去(多时候我讨厌重复和教条,那像上年纪的老太婆,不过这次我鼓起勇气和精神继续写吧)。。。

将jaybird-X.X.XJDK_X.X.zip(注意,它是zip非jar)解压到任意目录,将其中的jaybird-full-X.X.X.jar(对,它才是完整的驱动包!)拷贝到你的CLASS_PATH目录中,然后在你的java代码里连接你的数据库吧

URL格式如下:
标准格式 jdbc:firebirdsql:[//host[:port]/]<database>
旧格式 jdbc:firebirdsql:[host[/port]:]<database>
jdbc例子:
Class.forName("org.firebirdsql.jdbc.FBDriver");
Connection conn = DriverManager.getConnection("jdbc:firebirdsql:localhost/3050:/firebird/test.gdb", "sysdba", "masterkey");

tomcat发布方式:
#1 单应用使用firebird,将驱动拷贝到应用的WEB-INF/lib/里;
#2 多应用使用firebird(全局),将驱动拷贝到{$tomcat_install_dir}/common/lib/里;
至此你可以在程序里采用jdbc方式访问你的数据库了。但,多数时候,这样有点土,你当然可以用jndi方式,如何定义jndi和使用它,请g-tomcat吧。我这里给个结果:
<Resource name="jdbc/mydb" auth="Container"
 type="javax.sql.DataSource"
 driverClassName="org.firebirdsql.jdbc.FBDriver"
 url="jdbc:firebirdsql:localhost/3050:mydb" username="sysdba"
 password="masterkey" maxActive="20" maxIdle="10" maxWait="10000" />
spring里
<bean id="dataSource" class="org.springframework.jndi.JndiObjectFactoryBean">
 <property name="jndiName" value="java:comp/env/jdbc/mydb" />
</bean>

如果你一时冲动想切换到嵌入方式(既然用了webServer,还用嵌入方式fb,我也只能说是一时冲动了~~),那也是简单的,
#1 把URL换成这个格式:
jdbc:firebirdsql:embedded:<database>
#2 把jaybird21.dll拷贝到windows/system32或在jvm启动时加入-Djava.library.path=<jaybird21.dll所在目录>参数
#3 确保你的PATH环境变量里有你的fb嵌入式目录,因为jaybird21.dll其实是fbembed.dll的代理


最后说说字符编码:
假设你的数据库编码被定义成UTF-8,那么你在windows下要小心中文乱码问题,在linux下也可能会出现(多时候linux用utf-8编码),这里我就不罗嗦什么大道理了。
server在windows下,你假设你启动jvm按正常方式启动(没定义file.encoding参数),那么你的数据库URL应该是
jdbc:firebirdsql:[//host[:port]/]<database>?lc_ctype=gbk
但,由于fb目前对gbk支持不好,在你企图录入偏僻字时还是会出错,为了避免这个问题,我一般连jvm的编码也定义成utf-8(这样lc_ctype可以不加,也可以lc_ctype=utf-8。当然这样做你需要注意数

据录入时中文编码转换,因为windows用户的中文是gbk编码的,需要转到utf-8,这对java来说很容易,反之亦然,不清楚的g吧,这个问题超出本次讨论,当然这里也可能牵涉一个web常规中文乱码问题

,请g),这就没这个问题了,不过来了一个不大的问题,这样的软件不符合国标~~。

这篇关于java 连接 firebird的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

SpringBoot 中 CommandLineRunner的作用示例详解

《SpringBoot中CommandLineRunner的作用示例详解》SpringBoot提供的一种简单的实现方案就是添加一个model并实现CommandLineRunner接口,实现功能的... 目录1、CommandLineRunnerSpringBoot中CommandLineRunner的作用

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2

Java日期类详解(最新推荐)

《Java日期类详解(最新推荐)》早期版本主要使用java.util.Date、java.util.Calendar等类,Java8及以后引入了新的日期和时间API(JSR310),包含在ja... 目录旧的日期时间API新的日期时间 API(Java 8+)获取时间戳时间计算与其他日期时间类型的转换Dur

java对接海康摄像头的完整步骤记录

《java对接海康摄像头的完整步骤记录》在Java中调用海康威视摄像头通常需要使用海康威视提供的SDK,下面这篇文章主要给大家介绍了关于java对接海康摄像头的完整步骤,文中通过代码介绍的非常详细,需... 目录一、开发环境准备二、实现Java调用设备接口(一)加载动态链接库(二)结构体、接口重定义1.类型

SpringBoot读取ZooKeeper(ZK)属性的方法实现

《SpringBoot读取ZooKeeper(ZK)属性的方法实现》本文主要介绍了SpringBoot读取ZooKeeper(ZK)属性的方法实现,强调使用@ConfigurationProperti... 目录1. 在配置文件中定义 ZK 属性application.propertiesapplicati

Java Multimap实现类与操作的具体示例

《JavaMultimap实现类与操作的具体示例》Multimap出现在Google的Guava库中,它为Java提供了更加灵活的集合操作,:本文主要介绍JavaMultimap实现类与操作的... 目录一、Multimap 概述Multimap 主要特点:二、Multimap 实现类1. ListMult

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

SpringBoot整合Apache Flink的详细指南

《SpringBoot整合ApacheFlink的详细指南》这篇文章主要为大家详细介绍了SpringBoot整合ApacheFlink的详细过程,涵盖环境准备,依赖配置,代码实现及运行步骤,感兴趣的... 目录1. 背景与目标2. 环境准备2.1 开发工具2.2 技术版本3. 创建 Spring Boot

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos

Java反射实现多属性去重与分组功能

《Java反射实现多属性去重与分组功能》在Java开发中,​​List是一种非常常用的数据结构,通常我们会遇到这样的问题:如何处理​​List​​​中的相同字段?无论是去重还是分组,合理的操作可以提高... 目录一、开发环境与基础组件准备1.环境配置:2. 代码结构说明:二、基础反射工具:BeanUtils