8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-22 20:03:02 +01:00
firebird-mirror/doc/README.intl

199 lines
5.5 KiB
Plaintext
Raw Normal View History

2005-07-05 03:19:47 +02:00
Firebird INTL
=============
Author: Adriano dos Santos Fernandes <adrianosf at uol.com.br>
Architecture
------------
Firebird allow you to specify character sets and collations in every field/variable declaration.
You can also specify the default character set at database create time and every CHAR/VARCHAR declaration that omit character set will use it.
At attachment time you can specify the character set that the client want to read all the strings.
If you don't specify one, NONE is assumed.
There are two specials character sets: NONE and OCTETS.
Both can be used in declarations but OCTETS can't be used in attachment.
They are very similar with the exception that space of NONE is ASCII 0x20 and space of OCTETS is 0x00.
They are specials because they don't follow the rule of others character sets regarding conversions.
With others character sets conversion is performed with CHARSET1->UNICODE->CHARSET2. With NONE/OCTETS the bytes is just copied: NONE/OCTETS->CHARSET2 and CHARSET1->NONE/OCTETS.
Enhancements
------------
Well-formedness checks
----------------------
Some character sets (specially multi-byte) don't accept everything.
2005-07-21 07:44:11 +02:00
Now, the engine verifies if strings are wellformed when assigning from NONE/OCTETS and strings sent by the client (the statement string and parameters).
2005-07-05 03:19:47 +02:00
Uppercase
---------
In FB 1.5.X only ASCII characters are uppercased in character sets default collation order (without collation specified). Ex:
isql -q -ch dos850
SQL> create database 'test.fdb';
SQL> create table t (c char(1) character set dos850);
SQL> insert into t values ('a');
SQL> insert into t values ('e');
SQL> insert into t values ('<27>');
SQL> insert into t values ('<27>');
SQL>
SQL> select c, upper(c) from t;
C UPPER
====== ======
a A
e E
<09> <20>
<09> <20>
In FB 2.0 the result is:
C UPPER
====== ======
a A
e E
<09> <20>
<09> <20>
Maximum string length
---------------------
2005-07-21 07:44:11 +02:00
In FB 1.5.X the engine doesn't verify logical length of MBCS strings.
2005-07-05 03:19:47 +02:00
Hence a UNICODE_FSS field can accept three (maximum length of one UNICODE_FSS character) times more characters than what's declared in the field size.
For compatibility purpose this was maintained for legacy character sets but new character sets (UTF8, for example) don't suffer from this problem.
NONE as attachment character set
--------------------------------
2005-07-21 07:44:11 +02:00
When NONE is used as attachment character set, the sqlsubtype member of XSQLVAR has the character set number of the read field, instead of always 0 as in previous versions.
2005-07-05 03:19:47 +02:00
BLOBs and collations
--------------------
Allow usage of DML COLLATE clause with BLOBs. Ex:
select blob_column from table where blob_column collate unicode = 'foo';
New character sets and collations
---------------------------------
UTF8 character set
------------------
2005-07-21 07:44:11 +02:00
The UNICODE_FSS character set has a number of problems: it's an old version of UTF8, accepts malformed strings and doesn't enforce correct maximum string length. In FB 1.5.X UTF8 it's an alias to UNICODE_FSS.
2005-07-05 03:19:47 +02:00
Now UTF8 is a new character set, without these problems of UNICODE_FSS.
UNICODE collations (for UTF8)
-----------------------------
UCS_BASIC works identical as UTF8 without collation specified (sorts in UNICODE code-point order).
UNICODE sorts using UCA (Unicode Collation Algorithm).
Sort order sample:
isql -q -ch dos850
SQL> create database 'test.fdb';
SQL> create table t (c char(1) character set utf8);
SQL> insert into t values ('a');
SQL> insert into t values ('A');
SQL> insert into t values ('<27>');
SQL> insert into t values ('b');
SQL> insert into t values ('B');
SQL> select * from t order by c collate ucs_basic;
C
======
A
B
a
b
<09>
SQL> select * from t order by c collate unicode;
C
======
a
A
<09>
b
B
Brazilian collations
--------------------
Two case-insensitive/accent-insensitive collations was created for Brazil: PT_BR/WIN_PTBR (for WIN1252) and PT_BR (for ISO8859_1).
Sort order and equality sample:
isql -q -ch dos850
SQL> create database 'test.fdb';
SQL> create table t (c char(1) character set iso8859_1 collate pt_br);
SQL> insert into t values ('a');
SQL> insert into t values ('A');
SQL> insert into t values ('<27>');
SQL> insert into t values ('b');
SQL> select * from t order by c;
C
======
A
a
<09>
b
SQL> select * from t where c = '<27>';
C
======
a
A
<09>
Drivers
-------
2005-07-21 07:44:11 +02:00
New character sets and collations are implemented through dynamic libraries and installed in the server with a manifest file in intl subdirectory. For an example see fbintl.conf.
2005-07-05 03:19:47 +02:00
Not all implemented character sets and collations need to be listed in the manifest file. Only those listed are available and duplications are not loaded.
2005-07-05 17:25:27 +02:00
After installed in the server, they should be registered in the database's system tables (rdb$character_sets and rdb$collations).
One script file with stored procedures to register/unregister is provided in misc/intl.sql.
2006-12-16 02:41:59 +01:00
2006-12-19 09:36:48 +01:00
In FB 2.1, don't use misc/intl.sql for collations anymore, now a DDL command exists for this task.
2006-12-16 02:41:59 +01:00
Syntax:
CREATE COLLATION <name>
FOR <charset>
[ FROM <base> | FROM EXTERNAL ('<name>') ]
[ NO PAD | PAD SPACE ]
[ CASE SENSITIVE | CASE INSENSITIVE ]
[ ACCENT SENSITIVE | ACCENT INSENSITIVE ]
[ '<specific-attributes>' ]
2007-03-30 15:11:29 +02:00
Notes:
2007-03-31 08:50:01 +02:00
1) Specific attributes should be separated by semicolon.
2007-03-30 15:11:29 +02:00
2006-12-16 02:41:59 +01:00
Examples:
1) CREATE COLLATION UNICODE_ENUS_CI
FOR UTF8
FROM UNICODE
CASE INSENSITIVE
'LOCALE=en_US';
2) CREATE COLLATION NEW_COLLATION
FOR WIN1252
PAD SPACE;
-- NEW_COLLATION should be declared in .conf file in root/intl directory