s4

changeset 580:a9faeb10a33b

Add script for fixing tblaccesses table schema
author HIROSE Yuuji <yuuji@gentei.org>
date Wed, 19 Jun 2019 09:13:57 +0900
parents 6e727ab07c98
children 8a206c6342a8
files scripts/s4-fix-tblaclog.sh
diffstat 1 files changed, 24 insertions(+), 0 deletions(-) [+]
line diff
     1.1 --- /dev/null	Thu Jan 01 00:00:00 1970 +0000
     1.2 +++ b/scripts/s4-fix-tblaclog.sh	Wed Jun 19 09:13:57 2019 +0900
     1.3 @@ -0,0 +1,24 @@
     1.4 +#!/bin/sh
     1.5 +
     1.6 +cd `dirname $0`/..
     1.7 +if ! . ./s4-funcs.sh; then
     1.8 +  echo "Cannot find s4-funcs.sh, which should be located in $mydir/.."
     1.9 +  exit 1
    1.10 +fi
    1.11 +
    1.12 +cnt0=`query "SELECT count(sql) FROM sqlite_master WHERE name='tblaccesses';"`
    1.13 +cnt1=`query "SELECT count(sql) FROM sqlite_master WHERE name='tblaccesses' AND sql LIKE '%cascade%';"`
    1.14 +
    1.15 +if [ x"$cnt0" = x"1" -a x"$cnt1" = x"0" ]; then
    1.16 +  echo -n Start fixing accesslog table...
    1.17 +  query <<-EOF && echo ..Done
    1.18 +	BEGIN;
    1.19 +	CREATE TABLE "tblaccesses2" (user, tbl, tblrowid, time, primary key (user, tbl, tblrowid, time), FOREIGN KEY(user) REFERENCES user(name) ON DELETE CASCADE ON UPDATE CASCADE);
    1.20 +	INSERT INTO tblaccesses2 SELECT * FROM tblaccesses;
    1.21 +	DROP TABLE tblaccesses;
    1.22 +	ALTER TABLE tblaccesses2 RENAME TO tblaccesses;
    1.23 +	COMMIT;
    1.24 +	EOF
    1.25 +else
    1.26 +  echo No need to fix db.
    1.27 +fi