upgrade_5.1_to_6.0.sh.in 1.41 KB
Newer Older
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22
#!/bin/sh

prefix=@prefix@
# Include utilities. Use installed version if available and
# use build version if it isn't.
if [ -e @datarootdir@/@PACKAGE_NAME@/scripts/admin-utils.sh ]; then
    . @datarootdir@/@PACKAGE_NAME@/scripts/admin-utils.sh
else
    . @abs_top_builddir@/src/bin/admin/admin-utils.sh
fi

VERSION=`pgsql_version "$@"`

if [ "$VERSION" != "5.1" ]; then
    printf "This script upgrades 5.1 to 6.0. Reported version is $VERSION. Skipping upgrade.\n"
    exit 0
fi

psql "$@" >/dev/null <<EOF

START TRANSACTION;

23
-- Create a lower case hostname index for hosts.
24 25 26
CREATE INDEX hosts_by_hostname ON hosts (lower(hostname))
WHERE hostname IS NOT NULL;

27
-- Create a hostname index for lease4.
28
CREATE INDEX lease4_by_hostname ON lease4 (lower(hostname))
29 30 31
WHERE hostname IS NOT NULL;

-- Create a hostname index for lease6.
32
CREATE INDEX lease6_by_hostname ON lease6 (lower(hostname))
33 34 35
WHERE hostname IS NOT NULL;

-- Move to lower case hostnames in lease4 table.
36 37 38
-- Not required so in comment
-- UPDATE lease4 SET hostname = lower(hostname)
-- WHERE lower(hostname) != hostname;
39 40

-- Move to lower case hostnames in lease6 table.
41 42 43
-- Not required so in comment
-- UPDATE lease6 SET hostname = lower(hostname)
-- WHERE lower(hostname) != hostname;
44

45 46 47 48 49 50 51 52 53 54 55 56 57
-- Set 6.0 schema version.
UPDATE schema_version
    SET version = '6', minor = '0';

-- Schema 5.1a specification ends here.

-- Commit the script transaction
COMMIT;

EOF

exit $RESULT