Commit afe1c51c authored by Tom Lane's avatar Tom Lane

Add pgbench option to add foreign key constraints to the standard scenario.

The option --foreign-keys, used at initialization time, will create foreign
key constraints for the columns that represent references to other tables'
primary keys.  This can help in benchmarking FK performance.

Jeff Janes
parent 11b335ac
...@@ -119,6 +119,11 @@ int scale = 1; ...@@ -119,6 +119,11 @@ int scale = 1;
*/ */
int fillfactor = 100; int fillfactor = 100;
/*
* create foreign key constraints on the tables?
*/
int foreign_keys = 0;
/* /*
* use unlogged tables? * use unlogged tables?
*/ */
...@@ -343,6 +348,8 @@ usage(const char *progname) ...@@ -343,6 +348,8 @@ usage(const char *progname)
" -i invokes initialization mode\n" " -i invokes initialization mode\n"
" -F NUM fill factor\n" " -F NUM fill factor\n"
" -s NUM scaling factor\n" " -s NUM scaling factor\n"
" --foreign-keys\n"
" create foreign key constraints between tables\n"
" --index-tablespace=TABLESPACE\n" " --index-tablespace=TABLESPACE\n"
" create indexes in the specified tablespace\n" " create indexes in the specified tablespace\n"
" --tablespace=TABLESPACE\n" " --tablespace=TABLESPACE\n"
...@@ -1275,9 +1282,9 @@ init(void) ...@@ -1275,9 +1282,9 @@ init(void)
}; };
struct ddlinfo DDLs[] = { struct ddlinfo DDLs[] = {
{ {
"pgbench_branches", "pgbench_history",
"bid int not null,bbalance int,filler char(88)", "tid int,bid int,aid int,delta int,mtime timestamp,filler char(22)",
1 0
}, },
{ {
"pgbench_tellers", "pgbench_tellers",
...@@ -1290,9 +1297,9 @@ init(void) ...@@ -1290,9 +1297,9 @@ init(void)
1 1
}, },
{ {
"pgbench_history", "pgbench_branches",
"tid int,bid int,aid int,delta int,mtime timestamp,filler char(22)", "bid int not null,bbalance int,filler char(88)",
0 1
} }
}; };
static char *DDLAFTERs[] = { static char *DDLAFTERs[] = {
...@@ -1300,6 +1307,13 @@ init(void) ...@@ -1300,6 +1307,13 @@ init(void)
"alter table pgbench_tellers add primary key (tid)", "alter table pgbench_tellers add primary key (tid)",
"alter table pgbench_accounts add primary key (aid)" "alter table pgbench_accounts add primary key (aid)"
}; };
static char *DDLKEYs[] = {
"alter table pgbench_tellers add foreign key (bid) references pgbench_branches",
"alter table pgbench_accounts add foreign key (bid) references pgbench_branches",
"alter table pgbench_history add foreign key (bid) references pgbench_branches",
"alter table pgbench_history add foreign key (tid) references pgbench_tellers",
"alter table pgbench_history add foreign key (aid) references pgbench_accounts"
};
PGconn *con; PGconn *con;
PGresult *res; PGresult *res;
...@@ -1403,7 +1417,7 @@ init(void) ...@@ -1403,7 +1417,7 @@ init(void)
/* /*
* create indexes * create indexes
*/ */
fprintf(stderr, "set primary key...\n"); fprintf(stderr, "set primary keys...\n");
for (i = 0; i < lengthof(DDLAFTERs); i++) for (i = 0; i < lengthof(DDLAFTERs); i++)
{ {
char buffer[256]; char buffer[256];
...@@ -1424,6 +1438,18 @@ init(void) ...@@ -1424,6 +1438,18 @@ init(void)
executeStatement(con, buffer); executeStatement(con, buffer);
} }
/*
* create foreign keys
*/
if (foreign_keys)
{
fprintf(stderr, "set foreign keys...\n");
for (i = 0; i < lengthof(DDLKEYs); i++)
{
executeStatement(con, DDLKEYs[i]);
}
}
/* vacuum */ /* vacuum */
fprintf(stderr, "vacuum..."); fprintf(stderr, "vacuum...");
executeStatement(con, "vacuum analyze pgbench_branches"); executeStatement(con, "vacuum analyze pgbench_branches");
...@@ -1864,6 +1890,7 @@ main(int argc, char **argv) ...@@ -1864,6 +1890,7 @@ main(int argc, char **argv)
int i; int i;
static struct option long_options[] = { static struct option long_options[] = {
{"foreign-keys", no_argument, &foreign_keys, 1},
{"index-tablespace", required_argument, NULL, 3}, {"index-tablespace", required_argument, NULL, 3},
{"tablespace", required_argument, NULL, 2}, {"tablespace", required_argument, NULL, 2},
{"unlogged-tables", no_argument, &unlogged_tables, 1}, {"unlogged-tables", no_argument, &unlogged_tables, 1},
......
...@@ -180,6 +180,15 @@ pgbench <optional> <replaceable>options</> </optional> <replaceable>dbname</> ...@@ -180,6 +180,15 @@ pgbench <optional> <replaceable>options</> </optional> <replaceable>dbname</>
</listitem> </listitem>
</varlistentry> </varlistentry>
<varlistentry>
<term><option>--foreign-keys</option></term>
<listitem>
<para>
Create foreign key constraints between the standard tables.
</para>
</listitem>
</varlistentry>
<varlistentry> <varlistentry>
<term><option>--index-tablespace=<replaceable>index_tablespace</replaceable></option></term> <term><option>--index-tablespace=<replaceable>index_tablespace</replaceable></option></term>
<listitem> <listitem>
......
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