aboutsummaryrefslogtreecommitdiff
path: root/sql/migrations/2.sql
blob: c1d502f2244f39d79dd0cc6cdfc64bc77640ec61 (plain)
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
-- Add payment categories with accents from payment with accents

INSERT INTO
  payment_category (name, category, created_at)
SELECT
  DISTINCT lower(payment.name), payment_category.category, datetime('now')
FROM
  payment
INNER JOIN
  payment_category
ON
  replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(replace(lower(payment.name), 'é', 'e'), 'è', 'e'), 'à', 'a'), 'û', 'u'), 'â', 'a'), 'ê', 'e'), 'â', 'a'), 'î', 'i'), 'ï', 'i'), 'ô', 'o'), 'ë', 'e') = payment_category.name
WHERE
  payment.name
IN
  (SELECT DISTINCT payment.name FROM payment WHERE lower(payment.name) NOT IN (SELECT payment_category.name FROM payment_category) AND payment.deleted_at IS NULL);

-- Remove unused payment categories

DELETE FROM
  payment_category
WHERE
  name NOT IN (SELECT DISTINCT lower(name) FROM payment);

-- Add category id to payment table

PRAGMA foreign_keys = 0;

ALTER TABLE payment ADD COLUMN "category" INTEGER NOT NULL REFERENCES "category" DEFAULT -1;

PRAGMA foreign_keys = 1;

UPDATE
  payment
SET
  category = (SELECT category FROM payment_category WHERE payment_category.name = LOWER(payment.name))
WHERE
  EXISTS (SELECT category FROM payment_category WHERE payment_category.name = LOWER(payment.name));

DELETE FROM payment WHERE category = -1;

-- Remove

DROP TABLE payment_category;