8
0
mirror of https://github.com/FirebirdSQL/firebird.git synced 2025-01-25 04:43:03 +01:00
firebird-mirror/doc/ambiguity.txt

92 lines
2.4 KiB
Plaintext
Raw Normal View History

Alias handling and ambiguous field detecting has been improved in FB2.0.
Changes:
2005-01-28 07:52:37 +01:00
a) When an alias is present on a table, that alias must be used or no alias at
all, the tablename only is not valid anymore.
b) Fields without qualifier can now be used in a higher scope level. Own scope
level is checked first and ambiguous field checking is done on scope level.
Author:
Arno Brinkman <firebird@abvisie.nl>
Examples:
a)
1.
2005-01-28 07:52:37 +01:00
When an alias is present it must be used or no alias at all must be used.
This query was allowed in FB1.5 and earlier versions:
SELECT
RDB$RELATIONS.RDB$RELATION_NAME
FROM
RDB$RELATIONS R
but will now correctly report an error that the field
"RDB$RELATIONS.RDB$RELATION_NAME" couldn't be found.
2005-01-28 07:52:37 +01:00
Use this (preferred):
SELECT
R.RDB$RELATION_NAME
FROM
RDB$RELATIONS R
or this statement:
SELECT
RDB$RELATION_NAME
FROM
RDB$RELATIONS R
2.
The statement below will now correctly use the FieldID from the subselect
2005-01-28 07:52:37 +01:00
and from the updating table:
UPDATE
TableA
SET
FieldA = (SELECT SUM(A.FieldB) FROM TableA A WHERE A.FieldID = TableA.FieldID)
In firebird it's possible to give an alias by an update statement, but by
many other database vendors this isn't supported. These SQL statements are
2005-01-28 07:52:37 +01:00
now better interchangeable between other SQL database products.
3.
2005-01-28 07:52:37 +01:00
This example didn't run correctly in FB1.5 and earlier:
SELECT
RDB$RELATIONS.RDB$RELATION_NAME,
R2.RDB$RELATION_NAME
FROM
RDB$RELATIONS
JOIN RDB$RELATIONS R2 ON
(R2.RDB$RELATION_NAME = RDB$RELATIONS.RDB$RELATION_NAME)
If RDB$RELATIONS contains 90 records, it would return 90 * 90 = 8100 records,
but in FB2.0 it will correctly return 90 records.
b)
1.
This failed in FB1.5, but is possible in FB2.0:
SELECT
(SELECT RDB$RELATION_NAME FROM RDB$DATABASE)
FROM
RDB$RELATIONS
2.
Ambiguity checking in sub-selects. The query below did run on FB1.5
2005-01-28 07:52:37 +01:00
without reporting an ambiguity, but will report it in FB2.0:
SELECT
(SELECT
FIRST 1 RDB$RELATION_NAME
FROM
RDB$RELATIONS R1
JOIN RDB$RELATIONS R2 ON
(R2.RDB$RELATION_NAME = R1.RDB$RELATION_NAME))
FROM
RDB$DATABASE