简介
Firebird是一个跨平台的关系资料库系统,目前能够运行在Windows、linux和各种Unix作业系统上,提供了大部分SQL-99标準的功能。它既能作为多使用者环境下的资料库伺服器运行,也提供嵌入式资料库的实现。
Firebird脱胎于Borland公司的开源版资料库Interbase6.0,是一个完全非商业化的产品,用C和C++开发。由于与interbase的血缘关系,大部分interbase的开发工具可以直接套用到Firebird开发中。Firebird使用Mozilla Public License v.1.1许可证发行。
一个firebird资料库伺服器能够管理多个独立的资料库,每一个资料库同时可支持多个客户端连结。总之:它是一个开源的,强大的,可以自由使用的资料库(即使是商业上的使用)
历史发展
Firebird基于开源Interbase6.0,它是Borland公司2000年发布的一个开源版本。关于Interbase的最早历史可以追溯到 1984年,因此,这个资料库已经有30岁了。
特点:
1、Firebird是一个真正的关系资料库,支持存储过程、视图、触发器、事务等大型关系资料库的所有特徵;
2、Firebird支持SQL92的绝大部分命令,并且支持大部分SQL99命令,新版Firebird 2.0对SQL99的支持更完整;
3、Firebird源码基于成熟的商业资料库Interbase,有良好的稳定性,与Interbase有良好的兼容性;
4、不用考虑授权费用(免费),不用担心将来有一天你或你的客户因为使用盗版而被资料库开发商告上法庭;
5、发布简易,安装档案只有几M,且高度可定製,客户端的分发也很简单,只需一个DLL档案;
6、Firebird的一嵌入式伺服器版本,不用安装,直接运行,基于单机开发首选;
7、Firebird的运行效率非常高;
8、具备高度可移植性,可在Linux,Unix,MacOS,Windows,Solaris系统下运行,而且资料库格式完全一样,不用修改;
9、开发环境支持良好,Delphi,C++Builder不用通过ODBC连线,直接用原生开发接口开发基于Firebird的程式。
特点
支持原子性,并发性,隔离性等概念。
支持事务的多个版本功能,
使用PSQL(Procedure SQL),你可以建立强大的存储过程来处理服务上的所有资料,你可以使用select Stored Procedure的形式,使用存储过程,以得到一个虚拟的表结构的结果。这样的话,你就可以很容易的在报表中使用它。
存储过程和触发器可以引发事件,这个事件可以被客户端程式监听到
生成子也称为序列,它可以很容易的实现自动增加的栏位。它是一个INT64的长度,因此,它可以用在一个事务中,也可以用在其它很多方面。
主要信息
唯读资料库
我们可以把资料库存放在CD中,形成一个唯读资料库。如果我们的应用程式
也在光碟上,再加上嵌入式的FB资料库伺服器,便可以得到一个无与伦比的
CDLIVE(即只用光碟就可以运行起来)套用。
全事务控製
一个客户端可以存在多个并发的事务。并且每一个事务都可以独立的进行控製,两段提交功能可以保证资料库的一致性。锁最佳化机製也支持多个事务的储存点。
线上备份
不需要停止资料库即可进行备份,一个备份进程产生一个资料库当前的快照。因此,使用者可以在备份期间持续的工作,即实现24x7(每天24小时,每周7天) 的操作。
触发器
每一个表可以有多个并发的行级触发器,可以在插入前,插入后,更新前,更新后,移除前,移除后进行触发。我们可以在触发器中写入PSQL语句,默认值,产生异常,firebird现在支持统一触发器,即可以一个触发器中,一次性管理插入,更新,移除的操作。
扩展函式
我们可以使用C语言,C++,DELPHI写UDF,使用UDF(使用者定义函式馆)可以很容易的挂入资料库引擎中以扩展我们需要的功能
字元集
Firebird实现了很多国际标準的字元集,包括Unicode。
SQL标準兼容
Firebird 实现了全部SQL92所要求的功能,实现了SQL99最常用的的要求。包括但不限于FULL/LEFT/RIGHT [OUTER] JOIN , UNION, DISTINCT ,子查询(IN, EXISTS),内部函式 (AVG, SUM, MIN, MAX, COALESCE, CASE, ..), 主键,外键,唯一索引以及所有通用的资料类型。
Firebird还实现了域,栏位级别的约束,视图,异常,规则和许可权管理,更多的详细信息,请参考Firebird发布通知和参考手册。
硬体需求
Firebird可以工作最常见的硬体环境中,甚至非常差的硬体中,也能很好的工作,当然,硬体的要求依赖于你想做什麽,例如,你有多少个并发使用者等等。
有效的平台支持
Firebrid在常见的平台上都可运行,如Linux和Windows(包括Windows终端伺服器)其它支持的平台包括(MAC OS(苹果机), Solaris及HP-UX)
把资料库从一个平台转到另一个平台,非常的容易,只要备份资料库,然后,再到另一个平台上恢复即可。
可连线性
Firebird 支持一系列的连线方法,目前,可以通过原生的DELPHI,C++组件连线,也可以通过ODBC,JDBC,PHP,OLEDB,DbExpress进行连线。原生的函式馆提供了直接调用Firebird的API函式(fbclient.dll/.so)的能力。
物理限製
Firebird支持非常巨大的资料库,资料库可以分成多个物理档案。每个档案的大小依赖于作业系统的限製。当前一个资料库档案最大的理论限製是64T (即64000G),因此,常见的限製通常是作业系统的限製以及磁碟空间的限製。
伺服器引擎版本
当前有三个伺服器版本。
标準伺服器:每一个客户连线将引发一个伺服器进程(支持多处理器)
超级伺服器:一相伺服器进程模组管理所有的客户端连线,当前不支持多处理器。
嵌入伺服器:整个伺服器引擎就是一个动态库,只支持在地通过IO进行调用。
但是,所有的伺服器都使用一种资料库格式,因此,你可以很方便的在不同的引擎之间共享资料库档案的资料。
协定
Firebird协定使用IPL(interbasepublic license)和IDPL(Initial Developer's Public License),这种协定类似于Mozilla协定。你可以完全的自由使用并且可以自由的部署在你的客户套用上。
你不需要公开你的原始码。当然,如果你对资料库引擎本身做了修改或修正,则应该公布原始码。
工具
有很多的工具支持Firebird。包括自由的,免费的和商业的。
包括开发工具,管理工具,诊断工具等等。
支持和资源
IPPhonex公司也提供专业的商业支持。在他们网站上,也有很多有用的专业信息及常见问题的解答等。
团队
Firebird有一系列的使用者支持的团队和新闻组,您可以寻求线上支持。您可以
查看项目主页上的全部新闻组列表。



















