]> granicus.if.org Git - postgresql/commitdiff
Subject: Bug in SQLForeignKeys()
authorBruce Momjian <bruce@momjian.us>
Tue, 23 Jan 2001 20:36:30 +0000 (20:36 +0000)
committerBruce Momjian <bruce@momjian.us>
Tue, 23 Jan 2001 20:36:30 +0000 (20:36 +0000)
Query used for checking foreign key triggers
returns too many results when there're more than one foreign
key in a table. It happens because only table's oid is used to
link between pg_trigger with INSERT check and pg_trigger with
UPDATE/DELETE check.

I think there should be enough to add following conditions
into WHERE clause of that query:
        AND     pt.tgconstrname = pg_trigger.tgconstrname
        AND     pt.tgconstrname = pg_trigger_1.tgconstrname

/Constantin

src/interfaces/odbc/info.c
src/interfaces/odbc/pgtypes.c

index 165fd0bcaee58ddc3e503dcc427ef84cfdc99eed..cebc305da3eca01fd8bf8b7c51ac00204bb280c9 100644 (file)
@@ -2368,7 +2368,9 @@ Int2 result_cols;
                                                                "AND (pg_proc.proname LIKE '%%upd') "
                                                                "AND (pg_proc_1.proname LIKE '%%del') "
                                                                "AND (pg_trigger.tgrelid=pt.tgconstrrelid) "
-                                                               "AND (pg_trigger_1.tgrelid = pt.tgconstrrelid))", 
+                                                               "AND (pg_trigger.tgconstrname=pt.tgconstrname) "
+                                                               "AND (pg_trigger_1.tgrelid=pt.tgconstrrelid) "
+                                                               "AND (pg_trigger_1.tgconstrname=pt.tgconstrname))", 
                                fk_table_needed);               
 
                result = SQLExecDirect(htbl_stmt, tables_query, strlen(tables_query));
index 4263eea7b85cd5af098430fcba39d4ef5083aca6..ebee8ab262f55eff03741817143a4a1e7bfd65a4 100644 (file)
@@ -217,7 +217,9 @@ Int2 pgtype_to_sqltype(StatementClass *stmt, Int4 type)
        case PG_TYPE_XID:
        case PG_TYPE_INT4:          return SQL_INTEGER;
 
-       case PG_TYPE_INT8:                      return SQL_BIGINT;
+       /* Change this to SQL_BIGINT for ODBC v3 bjm 2001-01-23 */
+       case PG_TYPE_INT8:                      return SQL_CHAR;
+
        case PG_TYPE_NUMERIC:           return SQL_NUMERIC;
 
        case PG_TYPE_FLOAT4:        return SQL_REAL;