Commit a4402ecc authored by Marc G. Fournier's avatar Marc G. Fournier

Fixes a bug in 'create index'

Submitted by: Dan McGuirk <mcguirk@indirect.com>
parent d6fa4d95
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: pg_amop.h,v 1.2 1996/07/20 08:19:11 scrappy Exp $ * $Id: pg_amop.h,v 1.3 1996/08/15 07:42:06 scrappy Exp $
* *
* NOTES * NOTES
* the genbki.sh script reads this file and generates .bki * the genbki.sh script reads this file and generates .bki
...@@ -219,11 +219,11 @@ DATA(insert OID = 0 ( 403 408 462 5 btreesel btreenpage )); ...@@ -219,11 +219,11 @@ DATA(insert OID = 0 ( 403 408 462 5 btreesel btreenpage ));
* nbtree name_ops * nbtree name_ops
*/ */
DATA(insert OID = 0 ( 403 409 660 1 btreesel btreenpage )); DATA(insert OID = 0 ( 403 1181 660 1 btreesel btreenpage ));
DATA(insert OID = 0 ( 403 409 661 2 btreesel btreenpage )); DATA(insert OID = 0 ( 403 1181 661 2 btreesel btreenpage ));
DATA(insert OID = 0 ( 403 409 93 3 btreesel btreenpage )); DATA(insert OID = 0 ( 403 1181 93 3 btreesel btreenpage ));
DATA(insert OID = 0 ( 403 409 663 4 btreesel btreenpage )); DATA(insert OID = 0 ( 403 1181 663 4 btreesel btreenpage ));
DATA(insert OID = 0 ( 403 409 662 5 btreesel btreenpage )); DATA(insert OID = 0 ( 403 1181 662 5 btreesel btreenpage ));
/* /*
* nbtree char16_ops * nbtree char16_ops
...@@ -453,11 +453,11 @@ DATA(insert OID = 0 ( 404 430 647 5 btreesel btreenpage )); ...@@ -453,11 +453,11 @@ DATA(insert OID = 0 ( 404 430 647 5 btreesel btreenpage ));
* nobtree name_ops * nobtree name_ops
*/ */
DATA(insert OID = 0 ( 404 409 660 1 btreesel btreenpage )); DATA(insert OID = 0 ( 404 1181 660 1 btreesel btreenpage ));
DATA(insert OID = 0 ( 404 409 661 2 btreesel btreenpage )); DATA(insert OID = 0 ( 404 1181 661 2 btreesel btreenpage ));
DATA(insert OID = 0 ( 404 409 93 3 btreesel btreenpage )); DATA(insert OID = 0 ( 404 1181 93 3 btreesel btreenpage ));
DATA(insert OID = 0 ( 404 409 663 4 btreesel btreenpage )); DATA(insert OID = 0 ( 404 1181 663 4 btreesel btreenpage ));
DATA(insert OID = 0 ( 404 409 662 5 btreesel btreenpage )); DATA(insert OID = 0 ( 404 1181 662 5 btreesel btreenpage ));
/* /*
* nobtree text_ops * nobtree text_ops
...@@ -526,7 +526,7 @@ DATA(insert OID = 0 ( 405 430 99 1 hashsel hashnpage )); ...@@ -526,7 +526,7 @@ DATA(insert OID = 0 ( 405 430 99 1 hashsel hashnpage ));
/* /*
* hash table name_ops * hash table name_ops
*/ */
DATA(insert OID = 0 ( 405 409 93 1 hashsel hashnpage )); DATA(insert OID = 0 ( 405 1181 93 1 hashsel hashnpage ));
/* /*
* hash table text_ops * hash table text_ops
*/ */
......
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: pg_amproc.h,v 1.2 1996/07/20 08:19:13 scrappy Exp $ * $Id: pg_amproc.h,v 1.3 1996/08/15 07:42:07 scrappy Exp $
* *
* NOTES * NOTES
* the genbki.sh script reads this file and generates .bki * the genbki.sh script reads this file and generates .bki
...@@ -82,7 +82,7 @@ DATA(insert OID = 0 (403 429 358 1)); ...@@ -82,7 +82,7 @@ DATA(insert OID = 0 (403 429 358 1));
DATA(insert OID = 0 (403 406 689 1)); DATA(insert OID = 0 (403 406 689 1));
DATA(insert OID = 0 (403 407 690 1)); DATA(insert OID = 0 (403 407 690 1));
DATA(insert OID = 0 (403 408 691 1)); DATA(insert OID = 0 (403 408 691 1));
DATA(insert OID = 0 (403 409 359 1)); DATA(insert OID = 0 (403 1181 359 1));
DATA(insert OID = 0 (403 430 374 1)); DATA(insert OID = 0 (403 430 374 1));
DATA(insert OID = 0 (403 431 360 1)); DATA(insert OID = 0 (403 431 360 1));
DATA(insert OID = 0 (403 432 357 1)); DATA(insert OID = 0 (403 432 357 1));
...@@ -108,7 +108,7 @@ DATA(insert OID = 0 (404 429 358 1)); ...@@ -108,7 +108,7 @@ DATA(insert OID = 0 (404 429 358 1));
DATA(insert OID = 0 (404 406 689 1)); DATA(insert OID = 0 (404 406 689 1));
DATA(insert OID = 0 (404 407 690 1)); DATA(insert OID = 0 (404 407 690 1));
DATA(insert OID = 0 (404 408 691 1)); DATA(insert OID = 0 (404 408 691 1));
DATA(insert OID = 0 (404 409 359 1)); DATA(insert OID = 0 (404 1181 359 1));
DATA(insert OID = 0 (404 430 374 1)); DATA(insert OID = 0 (404 430 374 1));
DATA(insert OID = 0 (404 431 360 1)); DATA(insert OID = 0 (404 431 360 1));
DATA(insert OID = 0 (404 432 357 1)); DATA(insert OID = 0 (404 432 357 1));
...@@ -125,7 +125,7 @@ DATA(insert OID = 0 (405 429 454 1)); ...@@ -125,7 +125,7 @@ DATA(insert OID = 0 (405 429 454 1));
DATA(insert OID = 0 (405 406 692 1)); DATA(insert OID = 0 (405 406 692 1));
DATA(insert OID = 0 (405 407 693 1)); DATA(insert OID = 0 (405 407 693 1));
DATA(insert OID = 0 (405 408 694 1)); DATA(insert OID = 0 (405 408 694 1));
DATA(insert OID = 0 (405 409 455 1)); DATA(insert OID = 0 (405 1181 455 1));
DATA(insert OID = 0 (405 430 499 1)); DATA(insert OID = 0 (405 430 499 1));
DATA(insert OID = 0 (405 431 456 1)); DATA(insert OID = 0 (405 431 456 1));
DATA(insert OID = 0 (405 1076 1080 1)); DATA(insert OID = 0 (405 1076 1080 1));
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: pg_opclass.h,v 1.1.1.1 1996/07/09 06:21:17 scrappy Exp $ * $Id: pg_opclass.h,v 1.2 1996/08/15 07:42:09 scrappy Exp $
* *
* NOTES * NOTES
* the genbki.sh script reads this file and generates .bki * the genbki.sh script reads this file and generates .bki
...@@ -34,6 +34,7 @@ ...@@ -34,6 +34,7 @@
CATALOG(pg_opclass) { CATALOG(pg_opclass) {
NameData opcname; NameData opcname;
Oid opcdeftype;
} FormData_pg_opclass; } FormData_pg_opclass;
/* ---------------- /* ----------------
...@@ -47,39 +48,46 @@ typedef FormData_pg_opclass *Form_pg_opclass; ...@@ -47,39 +48,46 @@ typedef FormData_pg_opclass *Form_pg_opclass;
* compiler constants for pg_opclass * compiler constants for pg_opclass
* ---------------- * ----------------
*/ */
#define Natts_pg_opclass 1 #define Natts_pg_opclass 2
#define Anum_pg_opclass_opcname 1 #define Anum_pg_opclass_opcname 1
#define Anum_pg_opclass_opcdeftype 2
/* ---------------- /* ----------------
* initial contents of pg_opclass * initial contents of pg_opclass
* ---------------- * ----------------
*/ */
DATA(insert OID = 406 ( char2_ops )); /*
DATA(insert OID = 407 ( char4_ops )); * putting _null_'s in the (fixed-length) type field is bad
DATA(insert OID = 408 ( char8_ops )); * (see the README in this directory), so just put zeros
DATA(insert OID = 409 ( name_ops )); * in, which are invalid OID's anyway. --djm
DATA(insert OID = 421 ( int2_ops )); */
DATA(insert OID = 422 ( box_ops )); DATA(insert OID = 406 ( char2_ops 409 ));
DATA(insert OID = 423 ( float8_ops )); DATA(insert OID = 407 ( char4_ops 410 ));
DATA(insert OID = 424 ( int24_ops )); DATA(insert OID = 408 ( char8_ops 411 ));
DATA(insert OID = 425 ( int42_ops )); /* OID 409 is already used in table pg_type--this one should be unused */
DATA(insert OID = 426 ( int4_ops )); DATA(insert OID = 1181 ( name_ops 19 ));
DATA(insert OID = 421 ( int2_ops 21 ));
DATA(insert OID = 422 ( box_ops 603 ));
DATA(insert OID = 423 ( float8_ops 701 ));
DATA(insert OID = 424 ( int24_ops 0 ));
DATA(insert OID = 425 ( int42_ops 0 ));
DATA(insert OID = 426 ( int4_ops 23 ));
#define INT4_OPS_OID 426 #define INT4_OPS_OID 426
DATA(insert OID = 427 ( oid_ops )); DATA(insert OID = 427 ( oid_ops 26 ));
DATA(insert OID = 428 ( float4_ops )); DATA(insert OID = 428 ( float4_ops 700 ));
DATA(insert OID = 429 ( char_ops )); DATA(insert OID = 429 ( char_ops 18 ));
DATA(insert OID = 430 ( char16_ops )); DATA(insert OID = 430 ( char16_ops 20 ));
DATA(insert OID = 431 ( text_ops )); DATA(insert OID = 431 ( text_ops 25 ));
DATA(insert OID = 432 ( abstime_ops )); DATA(insert OID = 432 ( abstime_ops 702 ));
DATA(insert OID = 433 ( bigbox_ops)); DATA(insert OID = 433 ( bigbox_ops 0 ));
DATA(insert OID = 434 ( poly_ops)); DATA(insert OID = 434 ( poly_ops 604 ));
DATA(insert OID = 435 ( oidint4_ops)); DATA(insert OID = 435 ( oidint4_ops 910 ));
DATA(insert OID = 436 ( oidname_ops)); DATA(insert OID = 436 ( oidname_ops 911 ));
DATA(insert OID = 437 ( oidint2_ops)); DATA(insert OID = 437 ( oidint2_ops 810 ));
DATA(insert OID = 1076 ( bpchar_ops)); DATA(insert OID = 1076 ( bpchar_ops 1042 ));
DATA(insert OID = 1077 ( varchar_ops)); DATA(insert OID = 1077 ( varchar_ops 1043 ));
DATA(insert OID = 1114 ( date_ops)); DATA(insert OID = 1114 ( date_ops 1082 ));
DATA(insert OID = 1115 ( time_ops)); DATA(insert OID = 1115 ( time_ops 1083 ));
#endif /* PG_OPCLASS_H */ #endif /* PG_OPCLASS_H */
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/commands/Attic/defind.c,v 1.1.1.1 1996/07/09 06:21:20 scrappy Exp $ * $Header: /cvsroot/pgsql/src/backend/commands/Attic/defind.c,v 1.2 1996/08/15 07:42:19 scrappy Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -23,6 +23,7 @@ ...@@ -23,6 +23,7 @@
#include "catalog/index.h" #include "catalog/index.h"
#include "catalog/pg_index.h" #include "catalog/pg_index.h"
#include "catalog/pg_proc.h" #include "catalog/pg_proc.h"
#include "catalog/pg_opclass.h"
#include "nodes/pg_list.h" #include "nodes/pg_list.h"
#include "nodes/plannodes.h" #include "nodes/plannodes.h"
#include "nodes/primnodes.h" #include "nodes/primnodes.h"
...@@ -51,6 +52,7 @@ static void FuncIndexArgs(IndexElem *funcIndex, AttrNumber *attNumP, ...@@ -51,6 +52,7 @@ static void FuncIndexArgs(IndexElem *funcIndex, AttrNumber *attNumP,
Oid *argTypes, Oid *opOidP, Oid relId); Oid *argTypes, Oid *opOidP, Oid relId);
static void NormIndexAttrs(List *attList, AttrNumber *attNumP, static void NormIndexAttrs(List *attList, AttrNumber *attNumP,
Oid *opOidP, Oid relId); Oid *opOidP, Oid relId);
static char *GetDefaultOpClass(Oid atttypid);
/* /*
* DefineIndex -- * DefineIndex --
...@@ -439,14 +441,10 @@ NormIndexAttrs(List *attList, /* list of IndexElem's */ ...@@ -439,14 +441,10 @@ NormIndexAttrs(List *attList, /* list of IndexElem's */
for (rest=attList; rest != NIL; rest = lnext(rest)) { for (rest=attList; rest != NIL; rest = lnext(rest)) {
IndexElem *attribute; IndexElem *attribute;
AttributeTupleForm attform;
attribute = lfirst(rest); attribute = lfirst(rest);
if (attribute->class == NULL) {
elog(WARN,
"DefineIndex: default index class unsupported");
}
if (attribute->name == NULL) if (attribute->name == NULL)
elog(WARN, "missing attribute for define index"); elog(WARN, "missing attribute for define index");
...@@ -459,7 +457,19 @@ NormIndexAttrs(List *attList, /* list of IndexElem's */ ...@@ -459,7 +457,19 @@ NormIndexAttrs(List *attList, /* list of IndexElem's */
"DefineIndex: attribute \"%s\" not found", "DefineIndex: attribute \"%s\" not found",
attribute->name); attribute->name);
} }
*attNumP++ = ((AttributeTupleForm)GETSTRUCT(tuple))->attnum;
attform = (AttributeTupleForm)GETSTRUCT(tuple);
*attNumP++ = attform->attnum;
if (attribute->class == NULL) {
/* no operator class specified, so find the default */
attribute->class = GetDefaultOpClass(attform->atttypid);
if(attribute->class == NULL) {
elog(WARN,
"Can't find a default operator class for type %d.",
attform->atttypid);
}
}
tuple = SearchSysCacheTuple(CLANAME, tuple = SearchSysCacheTuple(CLANAME,
PointerGetDatum(attribute->class), PointerGetDatum(attribute->class),
...@@ -473,6 +483,21 @@ NormIndexAttrs(List *attList, /* list of IndexElem's */ ...@@ -473,6 +483,21 @@ NormIndexAttrs(List *attList, /* list of IndexElem's */
} }
} }
static char *
GetDefaultOpClass(Oid atttypid)
{
HeapTuple tuple;
tuple = SearchSysCacheTuple(CLADEFTYPE,
ObjectIdGetDatum(atttypid),
0, 0, 0);
if(!HeapTupleIsValid(tuple)) {
return 0;
}
return nameout(&(((Form_pg_opclass)GETSTRUCT(tuple))->opcname));
}
/* /*
* RemoveIndex -- * RemoveIndex --
* Deletes an index. * Deletes an index.
......
...@@ -10,7 +10,7 @@ ...@@ -10,7 +10,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/parser/gram.y,v 1.6 1996/08/13 01:29:33 scrappy Exp $ * $Header: /cvsroot/pgsql/src/backend/parser/gram.y,v 1.7 1996/08/15 07:42:29 scrappy Exp $
* *
* HISTORY * HISTORY
* AUTHOR DATE MAJOR EVENT * AUTHOR DATE MAJOR EVENT
...@@ -109,8 +109,8 @@ static Node *makeA_Expr(int op, char *opname, Node *lexpr, Node *rexpr); ...@@ -109,8 +109,8 @@ static Node *makeA_Expr(int op, char *opname, Node *lexpr, Node *rexpr);
ExplainStmt ExplainStmt
%type <str> relation_name, copy_file_name, copy_delimiter, def_name, %type <str> relation_name, copy_file_name, copy_delimiter, def_name,
database_name, access_method, attr_name, class, index_name, database_name, access_method_clause, access_method, attr_name,
var_name, name, file_name, recipe_name class, index_name, var_name, name, file_name, recipe_name
%type <str> opt_id, opt_portal_name, %type <str> opt_id, opt_portal_name,
before_clause, after_clause, all_Op, MathOp, opt_name, opt_unique before_clause, after_clause, all_Op, MathOp, opt_name, opt_unique
...@@ -653,21 +653,25 @@ opt_portal_name: IN name { $$ = $2;} ...@@ -653,21 +653,25 @@ opt_portal_name: IN name { $$ = $2;}
*****************************************************************************/ *****************************************************************************/
IndexStmt: CREATE INDEX index_name ON relation_name IndexStmt: CREATE INDEX index_name ON relation_name
USING access_method '(' index_params ')' access_method_clause '(' index_params ')'
{ {
/* should check that access_method is valid, /* should check that access_method is valid,
etc ... but doesn't */ etc ... but doesn't */
IndexStmt *n = makeNode(IndexStmt); IndexStmt *n = makeNode(IndexStmt);
n->idxname = $3; n->idxname = $3;
n->relname = $5; n->relname = $5;
n->accessMethod = $7; n->accessMethod = $6;
n->indexParams = $9; n->indexParams = $8;
n->withClause = NIL; n->withClause = NIL;
n->whereClause = NULL; n->whereClause = NULL;
$$ = (Node *)n; $$ = (Node *)n;
} }
; ;
access_method_clause: USING access_method { $$ = $2; }
| /* empty -- 'btree' is default access method */
{ $$ = "btree"; }
/***************************************************************************** /*****************************************************************************
* *
* QUERY: * QUERY:
......
...@@ -7,7 +7,7 @@ ...@@ -7,7 +7,7 @@
* *
* *
* IDENTIFICATION * IDENTIFICATION
* $Header: /cvsroot/pgsql/src/backend/utils/cache/syscache.c,v 1.1.1.1 1996/07/09 06:22:07 scrappy Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/cache/syscache.c,v 1.2 1996/08/15 07:42:52 scrappy Exp $
* *
* NOTES * NOTES
* These routines allow the parser/planner/executor to perform * These routines allow the parser/planner/executor to perform
...@@ -304,7 +304,16 @@ static struct cachedesc cacheinfo[] = { ...@@ -304,7 +304,16 @@ static struct cachedesc cacheinfo[] = {
0 }, 0 },
offsetof(FormData_pg_proc, prosrc), offsetof(FormData_pg_proc, prosrc),
ProcedureSrcIndex, ProcedureSrcIndex,
(ScanFunc) ProcedureSrcIndexScan } (ScanFunc) ProcedureSrcIndexScan },
{ OperatorClassRelationName, /* CLADEFTYPE */
1,
{ Anum_pg_opclass_opcdeftype,
0,
0,
0 },
sizeof(FormData_pg_opclass),
NULL,
(ScanFunc) NULL }
}; };
static struct catcache *SysCache[lengthof(cacheinfo)]; static struct catcache *SysCache[lengthof(cacheinfo)];
......
...@@ -6,7 +6,7 @@ ...@@ -6,7 +6,7 @@
* *
* Copyright (c) 1994, Regents of the University of California * Copyright (c) 1994, Regents of the University of California
* *
* $Id: syscache.h,v 1.1.1.1 1996/07/09 06:22:02 scrappy Exp $ * $Id: syscache.h,v 1.2 1996/08/15 07:42:45 scrappy Exp $
* *
*------------------------------------------------------------------------- *-------------------------------------------------------------------------
*/ */
...@@ -58,6 +58,7 @@ ...@@ -58,6 +58,7 @@
#define GROSYSID 24 #define GROSYSID 24
#define REWRITENAME 25 #define REWRITENAME 25
#define PROSRC 26 #define PROSRC 26
#define CLADEFTYPE 27
/* ---------------- /* ----------------
* struct cachedesc: information needed for a call to InitSysCache() * struct cachedesc: information needed for a call to InitSysCache()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment