s4
annotate scripts/s4-fix-tblaclog.sh @ 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 | |
children |
rev | line source |
---|---|
yuuji@580 | 1 #!/bin/sh |
yuuji@580 | 2 |
yuuji@580 | 3 cd `dirname $0`/.. |
yuuji@580 | 4 if ! . ./s4-funcs.sh; then |
yuuji@580 | 5 echo "Cannot find s4-funcs.sh, which should be located in $mydir/.." |
yuuji@580 | 6 exit 1 |
yuuji@580 | 7 fi |
yuuji@580 | 8 |
yuuji@580 | 9 cnt0=`query "SELECT count(sql) FROM sqlite_master WHERE name='tblaccesses';"` |
yuuji@580 | 10 cnt1=`query "SELECT count(sql) FROM sqlite_master WHERE name='tblaccesses' AND sql LIKE '%cascade%';"` |
yuuji@580 | 11 |
yuuji@580 | 12 if [ x"$cnt0" = x"1" -a x"$cnt1" = x"0" ]; then |
yuuji@580 | 13 echo -n Start fixing accesslog table... |
yuuji@580 | 14 query <<-EOF && echo ..Done |
yuuji@580 | 15 BEGIN; |
yuuji@580 | 16 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); |
yuuji@580 | 17 INSERT INTO tblaccesses2 SELECT * FROM tblaccesses; |
yuuji@580 | 18 DROP TABLE tblaccesses; |
yuuji@580 | 19 ALTER TABLE tblaccesses2 RENAME TO tblaccesses; |
yuuji@580 | 20 COMMIT; |
yuuji@580 | 21 EOF |
yuuji@580 | 22 else |
yuuji@580 | 23 echo No need to fix db. |
yuuji@580 | 24 fi |