mirror of
				https://github.com/postgres/postgres.git
				synced 2025-10-29 22:49:41 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			53 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
			
		
		
	
	
			53 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			Bash
		
	
	
		
			Executable File
		
	
	
	
	
| #! /bin/sh
 | |
| 
 | |
| # You first run findoidjoins on the template1 database, and send that
 | |
| # output into this script to generate a list of SQL statements.
 | |
| 
 | |
| # NOTE: any field that findoidjoins thinks joins to more than one table
 | |
| # will NOT be checked by the output of this script.  You should be
 | |
| # suspicious of multiple entries in findoidjoins' output.
 | |
| 
 | |
| # Caution: you may need to use GNU awk.
 | |
| AWK=${AWK:-awk}
 | |
| 
 | |
| trap "rm -f /tmp/$$ /tmp/$$a /tmp/$$b" 0 1 2 3 15
 | |
| 
 | |
| # Read input
 | |
| cat "$@" >/tmp/$$
 | |
| 
 | |
| # Look for fields with multiple references.
 | |
| cat /tmp/$$ | cut -d' ' -f2 | sort | uniq -d >/tmp/$$a
 | |
| if [ -s /tmp/$$a ] ; then
 | |
| 	echo "Ignoring these fields that link to multiple tables:" 1>&2
 | |
| 	cat /tmp/$$a 1>&2
 | |
| fi
 | |
| 
 | |
| # Get the non-multiply-referenced fields.
 | |
| cat /tmp/$$ | while read LINE
 | |
| do
 | |
| 	set -- $LINE
 | |
| 	grep "^$2\$" /tmp/$$a >/dev/null 2>&1 || echo $LINE
 | |
| done >/tmp/$$b
 | |
| 
 | |
| # Generate the output.
 | |
| cat /tmp/$$b |
 | |
| $AWK -F'[ \.]' '\
 | |
| 	BEGIN \
 | |
| 	{
 | |
| 		printf "\
 | |
| --\n\
 | |
| -- This is created by pgsql/contrib/findoidjoins/make_oidjoin_check\n\
 | |
| --\n";
 | |
| 	}
 | |
| 	{
 | |
| 		printf "\
 | |
| SELECT	ctid, %s \n\
 | |
| FROM	%s.%s fk \n\
 | |
| WHERE	%s != 0 AND \n\
 | |
| 	NOT EXISTS(SELECT 1 FROM %s.%s pk WHERE pk.oid = fk.%s);\n",
 | |
| 	$4, $2, $3, $4,
 | |
| 	$6, $7, $4;
 | |
| 	}'
 | |
| 
 | |
| exit 0
 |