File: 1.1_to_2.0.pgsql.sql

package info (click to toggle)
nag2 2.1.2-1
  • links: PTS
  • area: main
  • in suites: etch, etch-m68k
  • size: 4,120 kB
  • ctags: 766
  • sloc: php: 3,066; xml: 304; sql: 132; makefile: 64; sh: 39
file content (58 lines) | stat: -rw-r--r-- 2,011 bytes parent folder | download | duplicates (3)
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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
-- Update script to update nag 1.1 data to 2.x data for pgsql
-- Converted from mysql version by Daniel E. Markle <lexicon@seul.org>
--
-- You can simply execute this file in your database.
--
-- Run as:
--
-- $ psql <db name> -f < 1.1_to_2.0.pgsql.sql

ALTER TABLE nag_tasks DROP COLUMN task_modified;

BEGIN;
ALTER TABLE nag_tasks ADD COLUMN task_category_new VARCHAR(80);
UPDATE nag_tasks SET task_category_new = task_category;
ALTER TABLE nag_tasks DROP task_category;
ALTER TABLE nag_tasks RENAME task_category_new TO task_category;
COMMIT;

BEGIN;
ALTER TABLE nag_tasks ADD COLUMN task_id_new VARCHAR(32);
UPDATE nag_tasks SET task_id_new = task_id;
ALTER TABLE nag_tasks DROP task_id;
ALTER TABLE nag_tasks RENAME task_id_new TO task_id;
ALTER TABLE nag_tasks ALTER COLUMN task_id SET NOT NULL;
COMMIT;

BEGIN;
ALTER TABLE nag_tasks ADD COLUMN task_private_new SMALLINT;
UPDATE nag_tasks SET task_private_new = task_private;
ALTER TABLE nag_tasks DROP task_private;
ALTER TABLE nag_tasks RENAME task_private_new TO task_private;
ALTER TABLE nag_tasks ALTER COLUMN task_private SET NOT NULL;
ALTER TABLE nag_tasks ALTER COLUMN task_private SET DEFAULT 0;
COMMIT;

BEGIN;
ALTER TABLE nag_tasks ADD COLUMN task_uid VARCHAR(255);
UPDATE nag_tasks SET task_uid = '';
ALTER TABLE nag_tasks ALTER COLUMN task_uid SET NOT NULL;
COMMIT;

BEGIN;
ALTER TABLE nag_tasks ADD COLUMN task_alarm INT;
UPDATE nag_tasks SET task_alarm = 0;
ALTER TABLE nag_tasks ALTER COLUMN task_alarm SET NOT NULL;
COMMIT;

ALTER TABLE nag_tasks ADD INDEX nag_tasklist_idx (task_owner);
ALTER TABLE nag_tasks ADD INDEX nag_uid_idx (task_uid);

UPDATE nag_tasks SET task_id = task_owner || task_id;
UPDATE nag_tasks SET task_uid = 'nag:' || task_id WHERE task_id NOT LIKE 'nag:%';

-- this assumes the default constraint name was used at table creation time
ALTER TABLE nag_tasks DROP CONSTRAINT nag_tasks_pkey;
ALTER TABLE nag_tasks ADD CONSTRAINT nag_tasks_pkey PRIMARY KEY (task_id);

CREATE INDEX nag_uid_idx ON nag_tasks (task_uid);