Subversion Repositories eFlore/Applications.del

Rev

Rev 1308 | Rev 1376 | Go to most recent revision | Blame | Compare with Previous | Last modification | View Log | RSS feed

SET @OLD_UNIQUE_CHECKS=@@UNIQUE_CHECKS, UNIQUE_CHECKS=0;
SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0;
SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='TRADITIONAL';


-- -----------------------------------------------------
-- Table `del_utilisateur_infos`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_utilisateur_infos` ;

CREATE  TABLE IF NOT EXISTS `del_utilisateur_infos` (
  `id_utilisateur` INT(11) NOT NULL ,
  `admin` TINYINT(1) NULL ,
  `preferences` LONGTEXT NULL ,
  `date_premiere_utilisation` DATETIME NULL ,
  PRIMARY KEY (`id_utilisateur`) )
ENGINE = MyISAM;


-- -----------------------------------------------------
-- Table `del_utilisateur`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_utilisateur` ;

CREATE  TABLE IF NOT EXISTS `del_utilisateur` (
  `id_utilisateur` INT NOT NULL AUTO_INCREMENT COMMENT 'Type varchar pour éviter problème de jointure.' ,
  `prenom` VARCHAR(255) NOT NULL ,
  `nom` VARCHAR(255) NOT NULL ,
  `courriel` VARCHAR(255) NOT NULL ,
  `mot_de_passe` VARCHAR(45) NULL DEFAULT NULL ,
  PRIMARY KEY (`id_utilisateur`) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci;


-- -----------------------------------------------------
-- Table `del_image`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_image` ;

CREATE  TABLE IF NOT EXISTS `del_image` (
  `id_image` BIGINT NOT NULL AUTO_INCREMENT ,
  `ce_utilisateur` INT NOT NULL ,
  `hauteur` INT NULL ,
  `largeur` INT NULL ,
  `date_prise_de_vue` DATETIME NULL ,
  `mots_cles_texte` LONGTEXT NULL DEFAULT NULL ,
  `commentaire` LONGTEXT NULL DEFAULT NULL ,
  `nom_original` VARCHAR(255) NOT NULL ,
  `date_creation` DATETIME NOT NULL ,
  `date_modification` DATETIME NOT NULL ,
  `publiable_eflore` TINYINT(1) NOT NULL DEFAULT '1' ,
  PRIMARY KEY (`id_image`) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci;


-- -----------------------------------------------------
-- Table `del_observation`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_observation` ;

CREATE  TABLE IF NOT EXISTS `del_observation` (
  `id_observation` BIGINT NOT NULL AUTO_INCREMENT ,
  `ce_utilisateur` INT NOT NULL ,
  `nom_sel` VARCHAR(255) NULL DEFAULT NULL COMMENT 'Nom scientifique sélectionné par l\'utilisateur.' ,
  `nom_sel_nn` DECIMAL(9,0) NULL DEFAULT NULL COMMENT 'Identifiant du nom sélectionné.' ,
  `nom_ret` VARCHAR(255) NULL DEFAULT NULL COMMENT 'Nom scientifique retenu correspondant au nom sélectionné.' ,
  `nom_ret_nn` DECIMAL(9,0) NULL DEFAULT NULL COMMENT 'Identifiant du nom retenu.' ,
  `nt` DECIMAL(9,0) NULL DEFAULT NULL COMMENT 'Numéro taxonomique du taxon correspondant au nom sélectionné.' ,
  `famille` VARCHAR(255) NULL DEFAULT NULL COMMENT 'Nom de la famille du nom sélectionné.' ,
  `nom_referentiel` VARCHAR(255) NULL DEFAULT NULL ,
  `ce_zone_geo` VARCHAR(50) NULL DEFAULT NULL ,
  `zone_geo` VARCHAR(255) NULL DEFAULT NULL ,
  `lieudit` VARCHAR(255) NULL DEFAULT NULL ,
  `station` VARCHAR(255) NULL DEFAULT NULL ,
  `milieu` VARCHAR(255) NULL DEFAULT NULL ,
  `date_observation` DATETIME NULL ,
  `mots_cles_texte` LONGTEXT NULL DEFAULT NULL ,
  `commentaire` TEXT NULL DEFAULT NULL ,
  `date_creation` DATETIME NOT NULL ,
  `date_modification` DATETIME NOT NULL ,
  `date_transmission` DATETIME NOT NULL COMMENT 'Date à laquelle l\'observation a été rendu publique.' ,
  PRIMARY KEY (`id_observation`) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci
COMMENT = 'Observations publiques.';


-- -----------------------------------------------------
-- Table `del_image_protocole`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_image_protocole` ;

CREATE  TABLE IF NOT EXISTS `del_image_protocole` (
  `id_protocole` INT NOT NULL AUTO_INCREMENT ,
  `intitule` VARCHAR(255) NOT NULL ,
  `descriptif` TEXT NULL ,
  `tag` VARCHAR(255) NULL ,
  PRIMARY KEY (`id_protocole`) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci;


-- Insérer un protocole par défaut ---------------------
INSERT INTO `del_image_protocole` (`id_protocole`, `intitule`, `descriptif`, `tag`) VALUES
(1, 'Protocole par défaut', 'Protocole par défaut', 'defaut');

-- -----------------------------------------------------
-- Table `del_image_vote`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_image_vote` ;

CREATE  TABLE IF NOT EXISTS `del_image_vote` (
  `id_vote` BIGINT NOT NULL AUTO_INCREMENT ,
  `ce_image` BIGINT NOT NULL ,
  `ce_protocole` INT NOT NULL ,
  `ce_utilisateur` VARCHAR(32) NOT NULL COMMENT 'Identifiant de session ou id utilisateur.' ,
  `valeur` TINYINT(1) NOT NULL ,
  `date` DATETIME NOT NULL ,
  PRIMARY KEY (`id_vote`) ,
  UNIQUE INDEX `protocole_image_utilisateur` (`ce_image` ASC, `ce_protocole` ASC, `ce_utilisateur` ASC) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci;


-- -----------------------------------------------------
-- Table `del_image_tag`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_image_tag` ;

CREATE  TABLE IF NOT EXISTS `del_image_tag` (
  `id_tag` BIGINT NOT NULL AUTO_INCREMENT ,
  `ce_image` BIGINT NOT NULL ,
  `ce_utilisateur` VARCHAR(32) NOT NULL ,
  `tag` VARCHAR(255) NOT NULL DEFAULT 'Mot clé saisi par l\'utilisateur.' ,
  `tag_normalise` VARCHAR(255) NOT NULL DEFAULT 'Mot clé normalisé (sans espace ni accent).' ,
  `date` DATETIME NOT NULL COMMENT 'Date de création du tag.' ,
  `actif` INT(1) NULL ,
  `date_modification` DATETIME NULL ,
  PRIMARY KEY (`id_tag`) ,
  INDEX `tag` (`tag` ASC) ,
  INDEX `tag_normalise` (`tag_normalise` ASC) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci;


-- -----------------------------------------------------
-- Table `del_commentaire`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_commentaire` ;

CREATE  TABLE IF NOT EXISTS `del_commentaire` (
  `id_commentaire` BIGINT NOT NULL AUTO_INCREMENT ,
  `ce_observation` BIGINT NOT NULL ,
  `ce_proposition` INT NULL DEFAULT '0' ,
  `ce_commentaire_parent` BIGINT NULL DEFAULT '0' ,
  `texte` TEXT NULL DEFAULT NULL ,
  `ce_utilisateur` INT NULL DEFAULT '0' ,
  `utilisateur_prenom` VARCHAR(255) NOT NULL ,
  `utilisateur_nom` VARCHAR(255) NOT NULL ,
  `utilisateur_courriel` VARCHAR(255) NOT NULL ,
  `nom_sel` VARCHAR(255) NULL DEFAULT NULL ,
  `nom_sel_nn` DECIMAL(9,0) NULL DEFAULT NULL ,
  `nom_ret` VARCHAR(255) NULL DEFAULT NULL ,
  `nom_ret_nn` DECIMAL(9,0) NULL DEFAULT NULL ,
  `nt` DECIMAL(9,0) NULL DEFAULT NULL ,
  `famille` VARCHAR(255) NULL DEFAULT NULL ,
  `nom_referentiel` VARCHAR(255) NULL DEFAULT NULL ,
  `date` DATETIME NOT NULL COMMENT 'Date de création du commentaire.' ,
  `proposition_initiale` INT(1) NOT NULL DEFAULT '0' ,
  PRIMARY KEY (`id_commentaire`) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci;


-- -----------------------------------------------------
-- Table `del_commentaire_vote`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_commentaire_vote` ;

CREATE  TABLE IF NOT EXISTS `del_commentaire_vote` (
  `id_vote` BIGINT NOT NULL AUTO_INCREMENT ,
  `ce_proposition` BIGINT NOT NULL ,
  `ce_utilisateur` VARCHAR(32) NOT NULL DEFAULT '0' COMMENT 'Identifiant de session ou id de l\'utilisateur.' ,
  `valeur` TINYINT(1) NOT NULL ,
  `date` DATETIME NOT NULL ,
  PRIMARY KEY (`id_vote`) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci
COMMENT = 'Vote uniquement sur le commentaire de type \'proposition\'.';


-- -----------------------------------------------------
-- Table `del_obs_image`
-- -----------------------------------------------------
DROP TABLE IF EXISTS `del_obs_image` ;

CREATE  TABLE IF NOT EXISTS `del_obs_image` (
  `id_image` BIGINT NOT NULL ,
  `id_observation` BIGINT NOT NULL ,
  `date_liaison` DATETIME NOT NULL ,
  PRIMARY KEY (`id_image`, `id_observation`) )
ENGINE = MyISAM
DEFAULT CHARACTER SET = utf8
COLLATE = utf8_general_ci;


-- -----------------------------------------------------
-- View `del_utilisateur`
-- -----------------------------------------------------
DROP VIEW IF EXISTS `del_utilisateur` ;
DROP TABLE IF EXISTS `del_utilisateur`;
DELIMITER $$
CREATE  OR REPLACE VIEW del_utilisateur AS 
        SELECT 
    U_ID AS id_utilisateur, 
    CONVERT(U_SURNAME USING UTF8) AS prenom, 
    CONVERT(U_NAME USING UTF8) AS nom, 
    CONVERT(U_MAIL USING UTF8) AS courriel, 
    CONVERT(U_PASSWD USING UTF8) AS mot_de_passe 
        FROM tela_prod_v4.annuaire_tela;
$$
DELIMITER ;

;

-- -----------------------------------------------------
-- View `del_observation`
-- -----------------------------------------------------
DROP VIEW IF EXISTS `del_observation` ;
DROP TABLE IF EXISTS `del_observation`;
DELIMITER $$
CREATE  OR REPLACE VIEW del_observation AS 
    SELECT id_observation, if((char_length(o.ce_utilisateur) <> 32),cast(o.ce_utilisateur as unsigned),0) AS ce_utilisateur, prenom_utilisateur, nom_utilisateur, courriel_utilisateur, nom_sel, nom_sel_nn, nom_ret, nom_ret_nn, nt, famille, 
        ce_zone_geo, zone_geo, lieudit, station, milieu, 
        date_observation, mots_cles_texte, commentaire, 
        date_creation, date_modification, date_transmission 
    FROM tb_cel.cel_obs AS o
    WHERE transmission = '1' 
$$
DELIMITER ;

;

-- -----------------------------------------------------
-- View `del_image`
-- -----------------------------------------------------
DROP VIEW IF EXISTS `del_image` ;
DROP TABLE IF EXISTS `del_image`;
DELIMITER $$
CREATE  OR REPLACE VIEW del_image AS
    SELECT i.id_image, if((char_length(i.ce_utilisateur) <> 32),cast(i.ce_utilisateur as unsigned),0) AS ce_utilisateur, i.prenom_utilisateur, i.nom_utilisateur, i.courriel_utilisateur, i.hauteur, i.largeur, i.date_prise_de_vue, i.mots_cles_texte, 
        i.commentaire, i.nom_original, i.date_modification, i.date_creation, i.publiable_eflore 
    FROM tb_cel.cel_images AS i 
        INNER JOIN tb_cel.cel_obs_images AS oi ON (i.id_image = oi.id_image)  
        INNER JOIN tb_cel.cel_obs AS o ON (oi.id_observation = o.id_observation)
    WHERE o.transmission = '1' 
$$
DELIMITER ;

;

-- -----------------------------------------------------
-- View `del_obs_image`
-- -----------------------------------------------------
DROP VIEW IF EXISTS `del_obs_image` ;
DROP TABLE IF EXISTS `del_obs_image`;
DELIMITER $$
CREATE  OR REPLACE VIEW del_obs_image AS 
    SELECT oi.id_image, oi.id_observation, oi.date_liaison
    FROM tb_cel.cel_obs_images AS oi 
        INNER JOIN tb_cel.cel_obs AS o ON (oi.id_observation = o.id_observation)
    WHERE o.transmission = '1' 
$$
DELIMITER ;

;


SET SQL_MODE=@OLD_SQL_MODE;
SET FOREIGN_KEY_CHECKS=@OLD_FOREIGN_KEY_CHECKS;
SET UNIQUE_CHECKS=@OLD_UNIQUE_CHECKS;