aboutsummaryrefslogtreecommitdiff
path: root/contrib/findoidjoins/make_oidjoins_check
blob: a17052f73014874eb12dda1e881f1455d64e1da7 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
:
# You first run findoidjoins on the template1 database, and send that
# output into this file to generate a list of SQL statements.
trap "rm -f /tmp/$$ /tmp/$$a /tmp/$$b" 0 1 2 3 15

cat "$@" >/tmp/$$
cat /tmp/$$ | cut -d' ' -f2 | sort | uniq -d >/tmp/$$a
cat /tmp/$$ | while read LINE
do
	set -- $LINE
	grep "$2" /tmp/$$a >/dev/null 2>&1 || echo $LINE
done >/tmp/$$b
cat /tmp/$$b |
awk -F'[ \.]' '\
	BEGIN \
	{
		printf "\
--\n\
-- This is created by pgsql/contrib/findoidjoins/make_oidjoin_check\n\
--\n";
	}
	{
		printf "\
SELECT	oid, %s.%s \n\
FROM	%s \n\
WHERE	%s%s.%s%s NOT IN (SELECT oid FROM %s) AND \n\
	%s%s.%s%s != 0;\n", 	$2, $3, $2,
				($5 == "pg_proc") ? "RegprocToOid(" : "",
				$2, $3,
				($5 == "pg_proc") ? ")" : "",
				$5,
				($5 == "pg_proc") ? "RegprocToOid(" : "",
				$2, $3,
				($5 == "pg_proc") ? ")" : "";
	}'