File: testscripts.xml

package info (click to toggle)
libgda5 5.2.10-8
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 76,168 kB
  • sloc: ansic: 495,319; xml: 10,486; yacc: 5,165; sh: 4,451; makefile: 4,095; php: 1,416; java: 1,300; javascript: 1,298; python: 896; sql: 879; perl: 116
file content (179 lines) | stat: -rw-r--r-- 30,323 bytes parent folder | download | duplicates (9)
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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
<testdata>
  <test id="0" file="mysql_employees.sql">
    <stmt>DROP DATABASE IF EXISTS employees</stmt>
    <stmt>CREATE DATABASE IF NOT EXISTS employees</stmt>
    <stmt>USE employees</stmt>
    <stmt>SELECT 'CREATING DATABASE STRUCTURE' AS 'INFO'</stmt>
    <stmt>DROP TABLE IF EXISTS dept_emp,                      dept_manager,                      titles,                      salaries,                       employees,                       departments</stmt>
    <stmt>set storage_engine = InnoDB</stmt>
    <stmt>select CONCAT('storage engine: ', @@storage_engine) as INFO</stmt>
    <stmt>CREATE TABLE employees (     emp_no      INT             NOT NULL,     birth_date  DATE            NOT NULL,     first_name  VARCHAR(14)     NOT NULL,     last_name   VARCHAR(16)     NOT NULL,     gender      ENUM ('M','F')  NOT NULL,         hire_date   DATE            NOT NULL,     PRIMARY KEY (emp_no) )</stmt>
    <stmt>CREATE TABLE departments (     dept_no     CHAR(4)         NOT NULL,     dept_name   VARCHAR(40)     NOT NULL,     PRIMARY KEY (dept_no),     UNIQUE  KEY (dept_name) )</stmt>
    <stmt>CREATE TABLE dept_manager (    dept_no      CHAR(4)         NOT NULL,    emp_no       INT             NOT NULL,    from_date    DATE            NOT NULL,    to_date      DATE            NOT NULL,    KEY         (emp_no),    KEY         (dept_no),    FOREIGN KEY (emp_no)  REFERENCES employees (emp_no)    ON DELETE CASCADE,    FOREIGN KEY (dept_no) REFERENCES departments (dept_no) ON DELETE CASCADE,    PRIMARY KEY (emp_no,dept_no) )</stmt>
    <stmt>CREATE TABLE dept_emp (     emp_no      INT             NOT NULL,     dept_no     CHAR(4)         NOT NULL,     from_date   DATE            NOT NULL,     to_date     DATE            NOT NULL,     KEY         (emp_no),     KEY         (dept_no),     FOREIGN KEY (emp_no)  REFERENCES employees   (emp_no)  ON DELETE CASCADE,     FOREIGN KEY (dept_no) REFERENCES departments (dept_no) ON DELETE CASCADE,     PRIMARY KEY (emp_no,dept_no) )</stmt>
    <stmt>CREATE TABLE titles (     emp_no      INT             NOT NULL,     title       VARCHAR(50)     NOT NULL,     from_date   DATE            NOT NULL,     to_date     DATE,     KEY         (emp_no),     FOREIGN KEY (emp_no) REFERENCES employees (emp_no) ON DELETE CASCADE,     PRIMARY KEY (emp_no,title, from_date) )</stmt>
    <stmt>CREATE TABLE salaries (     emp_no      INT             NOT NULL,     salary      INT             NOT NULL,     from_date   DATE            NOT NULL,     to_date     DATE            NOT NULL,     KEY         (emp_no),     FOREIGN KEY (emp_no) REFERENCES employees (emp_no) ON DELETE CASCADE,     PRIMARY KEY (emp_no, from_date) )</stmt>
    <stmt>SELECT 'LOADING departments' AS 'INFO'</stmt>
    <stmt>source load_departments.dump</stmt>
    <stmt>SELECT 'LOADING employees' AS 'INFO'</stmt>
    <stmt>source load_employees.dump</stmt>
    <stmt>SELECT 'LOADING dept_emp' AS 'INFO'</stmt>
    <stmt>source load_dept_emp.dump</stmt>
    <stmt>SELECT 'LOADING dept_manager' AS 'INFO'</stmt>
    <stmt>source load_dept_manager.dump</stmt>
    <stmt>SELECT 'LOADING titles' AS 'INFO'</stmt>
    <stmt>source load_titles.dump</stmt>
    <stmt>SELECT 'LOADING salaries' AS 'INFO'</stmt>
    <stmt>source load_salaries.dump</stmt>
  </test>

  <test id="1" file="mysql_employees_partitioned.sql" provider="MySQL">
    <stmt>DROP DATABASE IF EXISTS employees</stmt>
    <stmt>CREATE DATABASE IF NOT EXISTS employees</stmt>
    <stmt>USE employees</stmt>
    <stmt>SELECT 'CREATING DATABASE STRUCTURE' AS 'INFO'</stmt>
    <stmt>DROP TABLE IF EXISTS dept_emp,                      dept_manager,                      titles,                      salaries,                       employees,                       departments</stmt>
    <stmt>set storage_engine = MyISAM</stmt>
    <stmt>select CONCAT('storage engine: ', @@storage_engine) as INFO</stmt>
    <stmt>CREATE TABLE employees (     emp_no      INT             NOT NULL,     birth_date  DATE            NOT NULL,     first_name  VARCHAR(14)     NOT NULL,     last_name   VARCHAR(16)     NOT NULL,     gender      ENUM ('M','F')  NOT NULL,         hire_date   DATE            NOT NULL,     PRIMARY KEY (emp_no) )</stmt>
    <stmt>CREATE TABLE departments (     dept_no     CHAR(4)         NOT NULL,     dept_name   VARCHAR(40)     NOT NULL,     PRIMARY KEY (dept_no),     UNIQUE  KEY (dept_name) )</stmt>
    <stmt>CREATE TABLE dept_manager (    dept_no      CHAR(4)         NOT NULL,    emp_no       INT             NOT NULL,    from_date    DATE            NOT NULL,    to_date      DATE            NOT NULL,    KEY         (emp_no),    KEY         (dept_no),            PRIMARY KEY (emp_no,dept_no) )</stmt>
    <stmt>CREATE TABLE dept_emp (     emp_no      INT             NOT NULL,     dept_no     CHAR(4)         NOT NULL,     from_date   DATE            NOT NULL,     to_date     DATE            NOT NULL,     KEY         (emp_no),     KEY         (dept_no),               PRIMARY KEY (emp_no,dept_no) )</stmt>
    <stmt>CREATE TABLE titles (     emp_no      INT             NOT NULL,     title       VARCHAR(50)     NOT NULL,     from_date   DATE            NOT NULL,     to_date     DATE,     KEY         (emp_no),          PRIMARY KEY (emp_no,title, from_date) )</stmt>
    <stmt>ALTER TABLE titles  partition by range (year(from_date)) (     partition p01 values less than (1985),     partition p02 values less than (1986),     partition p03 values less than (1987),     partition p04 values less than (1988),     partition p05 values less than (1989),     partition p06 values less than (1990),     partition p07 values less than (1991),     partition p08 values less than (1992),     partition p09 values less than (1993),     partition p10 values less than (1994),     partition p11 values less than (1995),     partition p12 values less than (1996),     partition p13 values less than (1997),     partition p14 values less than (1998),     partition p15 values less than (1999),     partition p16 values less than (2000),     partition p17 values less than (2001),     partition p18 values less than (2002),     partition p19 values less than (MAXVALUE) )</stmt>
    <stmt>CREATE TABLE salaries (     emp_no      INT             NOT NULL,     salary      INT             NOT NULL,     from_date   DATE            NOT NULL,     to_date     DATE            NOT NULL,     KEY         (emp_no),          PRIMARY KEY (emp_no, from_date) )</stmt>
    <stmt>ALTER TABLE salaries partition by range (year(from_date)) (     partition p01 values less than (1985),     partition p02 values less than (1986),     partition p03 values less than (1987),     partition p04 values less than (1988),     partition p05 values less than (1989),     partition p06 values less than (1990),     partition p07 values less than (1991),     partition p08 values less than (1992),     partition p09 values less than (1993),     partition p10 values less than (1994),     partition p11 values less than (1995),     partition p12 values less than (1996),     partition p13 values less than (1997),     partition p14 values less than (1998),     partition p15 values less than (1999),     partition p16 values less than (2000),     partition p17 values less than (2001),     partition p18 values less than (2002),     partition p19 values less than (MAXVALUE) )</stmt>
    <stmt>SELECT 'LOADING departments' AS 'INFO'</stmt>
    <stmt>source load_departments.dump</stmt>
    <stmt>SELECT 'LOADING employees' AS 'INFO'</stmt>
    <stmt>source load_employees.dump</stmt>
    <stmt>SELECT 'LOADING dept_emp' AS 'INFO'</stmt>
    <stmt>source load_dept_emp.dump</stmt>
    <stmt>SELECT 'LOADING dept_manager' AS 'INFO'</stmt>
    <stmt>source load_dept_manager.dump</stmt>
    <stmt>SELECT 'LOADING titles' AS 'INFO'</stmt>
    <stmt>source load_titles.dump</stmt>
    <stmt>SELECT 'LOADING salaries' AS 'INFO'</stmt>
    <stmt>source load_salaries.dump</stmt>
  </test>

  <test id="2" file="e-venement.sql" provider="PostgreSQL">
    <stmt>SET client_encoding = 'UTF8'</stmt>
    <stmt>SET standard_conforming_strings = off</stmt>
    <stmt>SET check_function_bodies = false</stmt>
    <stmt>SET client_min_messages = warning</stmt>
    <stmt>SET escape_string_warning = off</stmt>
    <stmt>COMMENT ON SCHEMA public IS 'Standard public schema'</stmt>
    <stmt>SET search_path = public, pg_catalog</stmt>
    <stmt>CREATE LANGUAGE plpgsql</stmt>
    <stmt>CREATE TYPE resume_tickets AS (  "transaction" bigint,  manifid integer,  nb bigint,  tarif character varying,  reduc integer,  printed boolean,  canceled boolean,  prix numeric,  prixspec numeric )</stmt>
    <stmt>CREATE FUNCTION get_personneid(integer) RETURNS bigint     AS $_$SELECT personneid AS result FROM org_personne WHERE id = $1;$_$     LANGUAGE sql STABLE STRICT</stmt>
    <stmt>COMMENT ON FUNCTION get_personneid(integer) IS 'retourne l''id d''une personne investie de la fonction $1 $1: org_personne.id'</stmt>
    <stmt>CREATE FUNCTION zeroifnull(bigint) RETURNS bigint     AS $_$BEGIN IF $1 IS NULL THEN RETURN 0; ELSE RETURN $1; END IF; END;$_$     LANGUAGE plpgsql IMMUTABLE</stmt>
    <stmt>SET default_tablespace = ''</stmt>
    <stmt>SET default_with_oids = true</stmt>
    <stmt>CREATE TABLE entite (     id integer NOT NULL,     nom character varying(127) NOT NULL,     creation timestamp with time zone DEFAULT now() NOT NULL,     modification timestamp with time zone DEFAULT now() NOT NULL,     adresse text,     cp character varying(10),     ville character varying(255),     pays character varying(255) DEFAULT 'France'::character varying,     email character varying(255),     npai boolean DEFAULT false NOT NULL,     active boolean DEFAULT true NOT NULL )</stmt>
    <stmt>COMMENT ON TABLE entite IS 'entités liées à l''organisme (personnes ou organismes)'</stmt>
    <stmt>COMMENT ON COLUMN entite.cp IS 'code postal de l''adresse'</stmt>
    <stmt>COMMENT ON COLUMN entite.email IS 'adresse email'</stmt>
    <stmt>COMMENT ON COLUMN entite.active IS 'permet de "supprimer" une entité dans l''application tout en gardant sa trace...'</stmt>
    <stmt>CREATE SEQUENCE entite_id_seq     INCREMENT BY 1     NO MAXVALUE     NO MINVALUE     CACHE 1</stmt>
    <stmt>ALTER SEQUENCE entite_id_seq OWNED BY entite.id</stmt>
    <stmt>CREATE TABLE fonction (     id integer NOT NULL,     libelle character varying(127) NOT NULL )</stmt>
    <stmt>COMMENT ON TABLE fonction IS 'Fonction liant une personne à un organisme (avec son intitulé exact par exemple)'</stmt>
    <stmt>COMMENT ON COLUMN fonction.libelle IS 'intitulé type, servant dans les extractions par exemple'</stmt>
    <stmt>CREATE TABLE org_categorie (     id integer NOT NULL,     libelle character varying(255) NOT NULL )</stmt>
    <stmt>COMMENT ON TABLE org_categorie IS 'categories regroupant des sous catégories d''organismes'</stmt>
    <stmt>CREATE TABLE org_personne (     id integer NOT NULL,     personneid bigint NOT NULL,     organismeid bigint NOT NULL,     fonction character varying(255),     email character varying(255),     service character varying(255),     "type" integer,     telephone character varying(40),     description text )</stmt>
    <stmt>COMMENT ON TABLE org_personne IS 'liaison entre des personnes et des organismes, au titre d''une fonction dans ledit organisme'</stmt>
    <stmt>COMMENT ON COLUMN org_personne.personneid IS 'personne.id'</stmt>
    <stmt>COMMENT ON COLUMN org_personne.organismeid IS 'organisme.id'</stmt>
    <stmt>COMMENT ON COLUMN org_personne.fonction IS 'fonction au titre de laquelle une personne est liée à un organisme'</stmt>
    <stmt>COMMENT ON COLUMN org_personne.email IS 'email de la personne dans l''organisme'</stmt>
    <stmt>COMMENT ON COLUMN org_personne.service IS 'Service dans l''organisme où travaille la personne'</stmt>
    <stmt>COMMENT ON COLUMN org_personne."type" IS 'fonction.id : type de fonction'</stmt>
    <stmt>COMMENT ON COLUMN org_personne.telephone IS 'téléphone professionel d''une personne liée à un organisme'</stmt>
    <stmt>COMMENT ON COLUMN org_personne.description IS 'description du pro'</stmt>
    <stmt>CREATE TABLE organisme (     url character varying(255),     categorie integer,     description text ) INHERITS (entite)</stmt>
    <stmt>COMMENT ON TABLE organisme IS 'structures en contact avec l''organisme'</stmt>
    <stmt>COMMENT ON COLUMN organisme.description IS 'Description de l''organisme'</stmt>
    <stmt>CREATE VIEW organisme_categorie AS     SELECT organisme.id, organisme.nom, organisme.creation, organisme.modification, organisme.adresse, organisme.cp, organisme.ville, organisme.pays, organisme.email, organisme.npai, organisme.active, organisme.url, organisme.categorie, org_categorie.libelle AS catdesc, organisme.description FROM organisme, org_categorie WHERE (((organisme.categorie = org_categorie.id) AND (organisme.categorie IS NOT NULL)) AND (organisme.active = true)) UNION SELECT organisme.id, organisme.nom, organisme.creation, organisme.modification, organisme.adresse, organisme.cp, organisme.ville, organisme.pays, organisme.email, organisme.npai, organisme.active, organisme.url, NULL::"unknown" AS categorie, NULL::"unknown" AS catdesc, organisme.description FROM organisme WHERE ((organisme.categorie IS NULL) AND (organisme.active = true)) ORDER BY 14, 2</stmt>
    <stmt>COMMENT ON VIEW organisme_categorie IS 'Liste des organismes avec leur catégorie (qui est à NULL s''ils n''en ont pas)'</stmt>
    <stmt>CREATE TABLE personne (     prenom character varying(255),     titre character varying(24) ) INHERITS (entite)</stmt>
    <stmt>COMMENT ON TABLE personne IS 'contacts de l''organisme'</stmt>
    <stmt>CREATE VIEW personne_properso AS     (((SELECT DISTINCT personne.id, personne.nom, personne.creation, personne.modification, personne.adresse, personne.cp, personne.ville, personne.pays, personne.email, personne.npai, personne.active, personne.prenom, personne.titre, organisme.id AS orgid, organisme.nom AS orgnom, organisme.categorie AS orgcat, organisme.adresse AS orgadr, organisme.cp AS orgcp, organisme.ville AS orgville, organisme.pays AS orgpays, organisme.email AS orgemail, organisme.url AS orgurl, organisme.description AS orgdesc, org_personne.service, org_personne.id AS fctorgid, fonction.id AS fctid, fonction.libelle AS fcttype, org_personne.fonction AS fctdesc, org_personne.email AS proemail, org_personne.telephone AS protel, organisme.catdesc AS orgcatdesc, org_personne.description FROM organisme_categorie organisme, personne, org_personne, fonction WHERE ((((personne.id = org_personne.personneid) AND (organisme.id = org_personne.organismeid)) AND (fonction.id = org_personne."type")) AND (org_personne."type" IS NOT NULL)) ORDER BY personne.id, personne.nom, personne.creation, personne.modification, personne.adresse, personne.cp, personne.ville, personne.pays, personne.email, personne.npai, personne.active, personne.prenom, personne.titre, organisme.id, organisme.nom, organisme.categorie, organisme.adresse, organisme.cp, organisme.ville, organisme.pays, organisme.email, organisme.url, organisme.description, org_personne.service, org_personne.id, fonction.id, fonction.libelle, org_personne.fonction, org_personne.email, org_personne.telephone, organisme.catdesc, org_personne.description) UNION (SELECT DISTINCT personne.id, personne.nom, personne.creation, personne.modification, personne.adresse, personne.cp, personne.ville, personne.pays, personne.email, personne.npai, personne.active, personne.prenom, personne.titre, organisme.id AS orgid, organisme.nom AS orgnom, organisme.categorie AS orgcat, organisme.adresse AS orgadr, organisme.cp AS orgcp, organisme.ville AS orgville, organisme.pays AS orgpays, organisme.email AS orgemail, organisme.url AS orgurl, organisme.description AS orgdesc, org_personne.service, org_personne.id AS fctorgid, NULL::integer AS fctid, NULL::text AS fcttype, org_personne.fonction AS fctdesc, org_personne.email AS proemail, org_personne.telephone AS protel, organisme.catdesc AS orgcatdesc, org_personne.description FROM organisme_categorie organisme, personne, org_personne WHERE (((personne.id = org_personne.personneid) AND (organisme.id = org_personne.organismeid)) AND (org_personne."type" IS NULL)) ORDER BY personne.id, personne.nom, personne.creation, personne.modification, personne.adresse, personne.cp, personne.ville, personne.pays, personne.email, personne.npai, personne.active, personne.prenom, personne.titre, organisme.id, organisme.nom, organisme.categorie, organisme.adresse, organisme.cp, organisme.ville, organisme.pays, organisme.email, organisme.url, organisme.description, org_personne.service, org_personne.id, 26, 27, org_personne.fonction, org_personne.email, org_personne.telephone, organisme.catdesc, org_personne.description)) UNION SELECT personne.id, personne.nom, personne.creation, personne.modification, personne.adresse, personne.cp, personne.ville, personne.pays, personne.email, personne.npai, personne.active, personne.prenom, personne.titre, NULL::"unknown" AS orgid, NULL::"unknown" AS orgnom, NULL::"unknown" AS orgcat, NULL::"unknown" AS orgadr, NULL::"unknown" AS orgcp, NULL::"unknown" AS orgville, NULL::"unknown" AS orgpays, NULL::"unknown" AS orgemail, NULL::"unknown" AS orgurl, NULL::"unknown" AS orgdesc, NULL::"unknown" AS service, NULL::"unknown" AS fctorgid, NULL::"unknown" AS fctid, NULL::"unknown" AS fcttype, NULL::"unknown" AS fctdesc, NULL::"unknown" AS proemail, NULL::"unknown" AS protel, NULL::"unknown" AS orgcatdesc, NULL::"unknown" AS description FROM personne) UNION SELECT NULL::"unknown" AS id, NULL::"unknown" AS nom, NULL::"unknown" AS creation, NULL::"unknown" AS modification, NULL::"unknown" AS adresse, NULL::"unknown" AS cp, NULL::"unknown" AS ville, NULL::"unknown" AS pays, NULL::"unknown" AS email, NULL::"unknown" AS npai, NULL::"unknown" AS active, NULL::"unknown" AS prenom, NULL::"unknown" AS titre, NULL::"unknown" AS orgid, NULL::"unknown" AS orgnom, NULL::"unknown" AS orgcat, NULL::"unknown" AS orgadr, NULL::"unknown" AS orgcp, NULL::"unknown" AS orgville, NULL::"unknown" AS orgpays, NULL::"unknown" AS orgemail, NULL::"unknown" AS orgurl, NULL::"unknown" AS orgdesc, NULL::"unknown" AS service, NULL::"unknown" AS fctorgid, NULL::"unknown" AS fctid, NULL::"unknown" AS fcttype, NULL::"unknown" AS fctdesc, NULL::"unknown" AS proemail, NULL::"unknown" AS protel, NULL::"unknown" AS orgcatdesc, NULL::"unknown" AS description ORDER BY 2, 12, 15, 27, 28, 24</stmt>
    <stmt>COMMENT ON VIEW personne_properso IS 'permet d''accéder à toutes les personnes de l''annuaire qu''elles soient pro ou non, qu''elles aient des fonctions au sein d''un organisme ou non'</stmt>
    <stmt>CREATE TABLE "object" (     id bigint NOT NULL,     name character varying(128) NOT NULL,     description text )</stmt>
    <stmt>COMMENT ON TABLE "object" IS 'Base table for a unified scape for every objects'</stmt>
    <stmt>CREATE SEQUENCE object_id_seq     INCREMENT BY 1     NO MAXVALUE     NO MINVALUE     CACHE 1</stmt>
    <stmt>ALTER SEQUENCE object_id_seq OWNED BY "object".id</stmt>
    <stmt>CREATE TABLE account (     "login" character varying(32) NOT NULL,     "password" character varying(32) NOT NULL,     active boolean DEFAULT true NOT NULL,     expire date,     "level" integer DEFAULT 0 NOT NULL,     email character varying(255) ) INHERITS ("object")</stmt>
    <stmt>COMMENT ON COLUMN account."level" IS 'Niveau de droits octroyé... dépend de l''application. Ici &gt;= 10 : admin ; &gt;= 5 : possibilité de modifier des fiches ; &lt; 5 : consultation simple'</stmt>
    <stmt>COMMENT ON COLUMN account.email IS 'email de l''utilisateur'</stmt>
    <stmt>SET default_with_oids = false</stmt>
    <stmt>CREATE TABLE child (     id integer NOT NULL,     personneid integer NOT NULL,     birth integer NOT NULL,     name text )</stmt>
    <stmt>COMMENT ON TABLE child IS 'Permet de définir l''âge des enfants d''un contact'</stmt>
    <stmt>COMMENT ON COLUMN child.personneid IS 'personne.id'</stmt>
    <stmt>COMMENT ON COLUMN child.birth IS 'year of birth'</stmt>
    <stmt>COMMENT ON COLUMN child.name IS 'child''s name'</stmt>
    <stmt>CREATE SEQUENCE child_id_seq     INCREMENT BY 1     NO MAXVALUE     NO MINVALUE     CACHE 1</stmt>
    <stmt>ALTER SEQUENCE child_id_seq OWNED BY child.id</stmt>
    <stmt>CREATE SEQUENCE fonction_id_seq     INCREMENT BY 1     NO MAXVALUE     NO MINVALUE     CACHE 1</stmt>
    <stmt>ALTER SEQUENCE fonction_id_seq OWNED BY fonction.id</stmt>
    <stmt>CREATE TABLE groupe (     id integer NOT NULL,     nom character varying(255) NOT NULL,     createur bigint,     creation timestamp with time zone DEFAULT now() NOT NULL,     modification timestamp with time zone DEFAULT now() NOT NULL,     description text )</stmt>
    <stmt>COMMENT ON TABLE groupe IS 'groupes de personnes créés à partir du requêteur'</stmt>
    <stmt>COMMENT ON COLUMN groupe.id IS 'id du groupe permettant de reconsituer le nom système de la view représentant le groupe ("grp_`id`")'</stmt>
    <stmt>COMMENT ON COLUMN groupe.nom IS 'nom usuel du groupe'</stmt>
    <stmt>COMMENT ON COLUMN groupe.createur IS 'lien vers le createur du groupe (account.id)'</stmt>
    <stmt>CREATE TABLE groupe_andreq (     id integer NOT NULL,     fctid integer,     orgid integer,     orgcat integer,     cp character varying(10),     ville character varying(255),     npai boolean DEFAULT false,     email boolean DEFAULT false,     adresse boolean DEFAULT false,     infcreation date,     infmodification date,     supcreation date,     supmodification date,     groupid integer NOT NULL,     grpinc integer[],     childmax integer,     childmin integer )</stmt>
    <stmt>COMMENT ON TABLE groupe_andreq IS 'chaque ligne correspond à un groupe de ET logiques qui, regroupées en OU logiques, définissent un groupe...'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.fctid IS 'fonction.id'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.orgid IS 'organisme.id'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.orgcat IS 'org_categorie.id'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.cp IS 'personne.cp LIKE ''cp%'' OR organisme.cp LIKE ''cp%'''</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.ville IS 'personne.ville LIKE ''ville%'' OR organisme.ville LIKE ''ville%'''</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.npai IS 'personne.npai'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.email IS 'personne.email IS NULL => true (si une personne N''a PAS d''email)'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.adresse IS 'personne.adresse IS NULL => true (une personne N''a PAS d''adresse)'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.infcreation IS 'personne.creation &lt; infcreation'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.infmodification IS 'personne.modification &lt; infmodification'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.supcreation IS 'personne.creation &gt;= supcreation'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.supmodification IS 'personne.modification &gt;= supmodification'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.groupid IS 'groupe.id'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.grpinc IS 'inclusion de groupes dans la condition'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.childmax IS 'date("Y") - childmax &gt;= child.birth'</stmt>
    <stmt>COMMENT ON COLUMN groupe_andreq.childmin IS 'date("Y") - childmin &lt;= child.birth'</stmt>
    <stmt>CREATE SEQUENCE groupe_andreq_id_seq     INCREMENT BY 1     NO MAXVALUE     NO MINVALUE     CACHE 1</stmt>
    <stmt>ALTER SEQUENCE groupe_andreq_id_seq OWNED BY groupe_andreq.id</stmt>
    <stmt>CREATE TABLE groupe_fonctions (     groupid integer NOT NULL,     fonctionid integer NOT NULL,     included boolean DEFAULT false NOT NULL,     info text )</stmt>
    <stmt>COMMENT ON TABLE groupe_fonctions IS 'Liaison directe entre fonctions au sein d''un organisme et groupe... une fonction est liée à un groupe avec un booléen qui exprime si elle est exclue (false) ou inclue (true).'</stmt>
    <stmt>COMMENT ON COLUMN groupe_fonctions.groupid IS 'groupe.id'</stmt>
    <stmt>COMMENT ON COLUMN groupe_fonctions.fonctionid IS 'org_personne.id'</stmt>
    <stmt>COMMENT ON COLUMN groupe_fonctions.info IS 'Colonne permettant de stocker des informations subsidiaires'</stmt>
    <stmt>CREATE SEQUENCE groupe_id_seq     INCREMENT BY 1     NO MAXVALUE     NO MINVALUE     CACHE 1</stmt>
    <stmt>ALTER SEQUENCE groupe_id_seq OWNED BY groupe.id</stmt>
    <stmt>CREATE TABLE groupe_personnes (     groupid integer NOT NULL,     personneid integer NOT NULL,     included boolean DEFAULT false NOT NULL,     info text )</stmt>
    <stmt>COMMENT ON TABLE groupe_personnes IS 'Liaison directe entre personnes et groupe... une personne est liée à un groupe avec un booléen qui exprime si elle est exclue (false) ou inclue (true).'</stmt>
    <stmt>COMMENT ON COLUMN groupe_personnes.groupid IS 'groupe.id'</stmt>
    <stmt>COMMENT ON COLUMN groupe_personnes.included IS 'la personne est incluse dans le groupe ? (si non : elle est exclue)'</stmt>
    <stmt>CREATE FUNCTION addpreresa(bigint, bigint, integer, integer, boolean, character varying, integer) RETURNS boolean     AS $_$ DECLARE account ALIAS FOR $1; transac ALIAS FOR $2; manif ALIAS FOR $3; reduction ALIAS FOR $4; annulation ALIAS FOR $5; tarif ALIAS FOR $6; nbloops ALIAS FOR $7; nb integer; tarif_id integer;  BEGIN  nb := 0;  tarif_id := get_tarifid(manif,tarif);  WHILE nb &lt; ABS(nbloops) LOOP   nb := nb + 1;   INSERT INTO reservation_pre ("accountid","manifid","tarifid","reduc","transaction","annul")   VALUES ( account, manif,tarif_id,reduction,transac,annulation ); END LOOP;  RETURN nb &gt; 0; END;$_$     LANGUAGE plpgsql</stmt>
    <stmt>CREATE FUNCTION contingeanting(bigint, bigint, bigint, bigint) RETURNS boolean     AS $_$BEGIN PERFORM * FROM contingeant WHERE transaction = $1; IF ( FOUND ) THEN RETURN false; ELSE INSERT INTO contingeant (transaction,accountid,personneid,fctorgid) VALUES ($1,$2,$3,$4);      RETURN true; END IF; END;$_$     LANGUAGE plpgsql</stmt>
    <stmt>COMMENT ON FUNCTION contingeanting(bigint, bigint, bigint, bigint) IS 'fonction permettant d''ajouter _au_besoin_ une entrée dans la table contingeant. retourne true si aucun enregistrement n''existait avant l''appel à la fonction (qui en a alors rajouté un), retourne false sinon. $1: transaction $2: accountid $3: personneid $4: fctorgid'</stmt>
    <stmt>CREATE FUNCTION counttickets(bigint, boolean) RETURNS bigint     AS $_$SELECT count(*) AS RESULT FROM reservation_cur AS resa WHERE resa.canceled = false AND resa_preid = $1;$_$     LANGUAGE sql STABLE STRICT</stmt>
    <stmt>CREATE FUNCTION decontingeanting(bigint, integer, bigint, integer, integer, integer, integer) RETURNS boolean     AS $_$DECLARE trans ALIAS FOR $1; manif ALIAS FOR $2; account ALIAS FOR $3; oldtarif ALIAS FOR $4; newtarif ALIAS FOR $5; reduction ALIAS FOR $6; qty ALIAS FOR $7;  i INTEGER := 0; selled INTEGER := 0; mass RECORD; BEGIN   selled := (SELECT nb FROM masstickets WHERE tarifid = newtarif AND manifid = manif AND transaction = trans) - qty;   IF ( selled &lt;= 0 ) THEN RETURN true; END IF;   UPDATE masstickets SET nb = qty WHERE tarifid = newtarif AND manifid = manif AND transaction = trans; IF ( NOT FOUND ) THEN RETURN false; END IF;  LOOP  IF ( i &gt;= selled ) THEN RETURN true; END IF;   PERFORM * FROM reservation_pre AS resa WHERE transaction = trans AND manifid = manif AND tarifid = oldtarif; IF ( NOT FOUND ) THEN   INSERT INTO reservation_pre (transaction,accountid,manifid,tarifid,reduc) SELECT trans, account, manif, oldtarif, 0;   IF ( NOT FOUND )   THEN RETURN false;   END IF; END IF;   INSERT INTO reservation_cur (resa_preid,accountid) VALUES ((SELECT MIN(id) AS resa_preid          FROM reservation_pre AS resa          WHERE transaction = trans AND manifid = manif AND account != 0 AND tarifid = oldtarif), account); IF ( NOT FOUND ) THEN RETURN false; END IF;   UPDATE reservation_pre SET tarifid = newtarif, reduc = reduction WHERE id = (SELECT MIN(id) AS min FROM reservation_pre AS resa WHERE transaction = trans AND tarifid = oldtarif AND manifid = manif); IF ( NOT FOUND ) THEN RETURN false; END IF;  i := i+1;  END LOOP; RETURN true; END;$_$     LANGUAGE plpgsql STRICT</stmt>
    <stmt>CREATE FUNCTION getprice(integer, character varying) RETURNS numeric     AS $_$DECLARE     buf NUMERIC; BEGIN          buf := (    SELECT prix                 FROM manifestation_tarifs                 WHERE manifestationid = $1                   AND tarifid = get_tarifid($1,$2));     IF ( buf IS NOT NULL )     THEN RETURN buf;     END IF;          buf := (    SELECT prix                 FROM tarif                 WHERE id = get_tarifid($1,$2));     RETURN buf; END;$_$     LANGUAGE plpgsql STABLE STRICT</stmt>
  </test>


  <test id="3" file="piggydb.sql" provider="PostgreSQL">
    <stmt>CREATE TABLE global_setting (    setting_name VARCHAR(100) NOT NULL,    setting_value VARCHAR,      PRIMARY KEY(setting_name)  )</stmt>
    <stmt>INSERT INTO global_setting (setting_name, setting_value) VALUES ('database.version', '1')</stmt>
    <stmt>CREATE TABLE tag (    tag_id BIGINT NOT NULL,      tag_name VARCHAR(100) NOT NULL UNIQUE,      creation_datetime TIMESTAMP NOT NULL,    update_datetime TIMESTAMP NOT NULL,      PRIMARY KEY(tag_id)  )</stmt>
    <stmt>CREATE SEQUENCE seq_tag_id START WITH 1</stmt>
    <stmt>CREATE TABLE tagging (    tagging_id IDENTITY NOT NULL,      tag_id BIGINT NOT NULL,    target_id BIGINT NOT NULL,    target_type TINYINT NOT NULL,      PRIMARY KEY(tagging_id),    UNIQUE(tag_id, target_id, target_type)  )</stmt>
    <stmt>CREATE TABLE fragment (    fragment_id BIGINT NOT NULL,      title VARCHAR(200),    content VARCHAR,      creation_datetime TIMESTAMP NOT NULL,    update_datetime TIMESTAMP NOT NULL,      PRIMARY KEY(fragment_id)  )</stmt>
    <stmt>CREATE SEQUENCE seq_fragment_id START WITH 1</stmt>
    <stmt>CREATE TABLE filter (    filter_id BIGINT NOT NULL,      filter_name VARCHAR(100) NOT NULL UNIQUE,      creation_datetime TIMESTAMP NOT NULL,    update_datetime TIMESTAMP NOT NULL,      PRIMARY KEY(filter_id)  )</stmt>
    <stmt>CREATE SEQUENCE seq_filter_id START WITH 1</stmt>
  </test>
</testdata>