Skip to content
Snippets Groups Projects
Select Git revision
  • 20f4fb313fb2e1798dbac7a0cf5c1b8863883797
  • main default protected
  • dev protected
  • f-fix-accent-sensitivity
  • f-filesystem-import
  • f-update-acl
  • f-filesystem-link
  • f-filesystem-directory
  • f-filesystem-core
  • f-filesystem-cleanup
  • f-string-ids
  • f-filesystem-main
  • f-multipart-encoding
  • f-trigger-advanced-user-tools
  • f-real-rename-test-pylibsolo2
  • f-real-rename-test-pylibsolo
  • f-real-rename-test
  • f-linkahead-rename
  • f-reference-record
  • f-xml-serialization
  • f-xfail-server-181
  • linkahead-pylib-v0.18.0
  • linkahead-control-v0.16.0
  • linkahead-pylib-v0.17.0
  • linkahead-mariadbbackend-v8.0.0
  • linkahead-server-v0.13.0
  • caosdb-pylib-v0.15.0
  • caosdb-pylib-v0.14.0
  • caosdb-pylib-v0.13.2
  • caosdb-server-v0.12.1
  • caosdb-pylib-v0.13.1
  • caosdb-pylib-v0.12.0
  • caosdb-server-v0.10.0
  • caosdb-pylib-v0.11.1
  • caosdb-pylib-v0.11.0
  • caosdb-server-v0.9.0
  • caosdb-pylib-v0.10.0
  • caosdb-server-v0.8.1
  • caosdb-pylib-v0.8.0
  • caosdb-server-v0.8.0
  • caosdb-pylib-v0.7.2
41 results

.add_dir_to_git

Blame
  • Code owners
    Assign users and groups as approvers for specific file changes. Learn more.
    initEntity.sql 4.88 KiB
    /*
     * ** header v3.0
     * This file is a part of the CaosDB Project.
     *
     * Copyright (C) 2018 Research Group Biomedical Physics,
     * Max-Planck-Institute for Dynamics and Self-Organization Göttingen
     *
     * This program is free software: you can redistribute it and/or modify
     * it under the terms of the GNU Affero General Public License as
     * published by the Free Software Foundation, either version 3 of the
     * License, or (at your option) any later version.
     *
     * This program is distributed in the hope that it will be useful,
     * but WITHOUT ANY WARRANTY; without even the implied warranty of
     * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
     * GNU Affero General Public License for more details.
     *
     * You should have received a copy of the GNU Affero General Public License
     * along with this program. If not, see <https://www.gnu.org/licenses/>.
     *
     * ** end header
     */
    
    DROP PROCEDURE IF EXISTS db_5_0.initEntity;
    DELIMITER //
    
    /**
     * Insert the specified (by `ename`, `enameLike`, `enameRegexp` or `eid`) Entities into `resultset`.
     *
     * If `versioned` is `TRUE`, also add archived entities (for example if the name was changed in the
     * past).
     */
    CREATE PROCEDURE db_5_0.initEntity(in eid VARCHAR(255), in ename VARCHAR(255),
                                       in enameLike VARCHAR(255), in enameRegexp VARCHAR(255),
                                       in resultset VARCHAR(255), in versioned BOOLEAN)
    initEntityLabel: BEGIN
        DECLARE select_columns VARCHAR(255) DEFAULT '` (id) SELECT entity_id FROM name_data ';
        SET @initEntityStmtStr = NULL;
    
        -- Prepare a statement which resolves the name or pattern to ids. The ids
        -- are collected in a temporary table (resultset).
        IF versioned IS TRUE THEN
            SET select_columns = '` (id, _iversion) SELECT entity_id, _get_head_iversion(entity_id) FROM name_data ';
        END IF;
        IF ename IS NOT NULL THEN
            SET @initEntityStmtStr = CONCAT(
                'INSERT IGNORE INTO `',
                resultset,
                select_columns,
                'WHERE value=?; ');
            SET @query_param = ename;
        ELSEIF enameLike IS NOT NULL THEN
            SET @initEntityStmtStr = CONCAT(
                'INSERT IGNORE INTO `',
                resultset,
                select_columns,
                'WHERE value LIKE ?;');
            SET @query_param = enameLike;
        ELSEIF enameRegexp IS NOT NULL THEN 
            SET @initEntityStmtStr = CONCAT(
                'INSERT IGNORE INTO `',
                resultset,
                select_columns,
                'WHERE value REGEXP ?;');
            SET @query_param = enameRegexp;
        END IF;
    
        -- execute the statement
        IF @initEntityStmtStr IS NOT NULL THEN
            PREPARE initEntityStmt FROM @initEntityStmtStr;
            EXECUTE initEntityStmt USING @query_param;
            DEALLOCATE PREPARE initEntityStmt;
        END IF;
    
        IF eid IS NOT NULL THEN
            -- add an explicitely given id to the resultset (if it exists)
            SET @initEntityStmtStr = CONCAT(
                'INSERT IGNORE INTO `',
                resultset,
                IF(versioned,
                    '` (id, _iversion) SELECT eids.internal_id, _get_head_iversion(eids.internal_id) ',
                    '` (id) SELECT eids.internal_id '),
                'FROM entity_ids AS eids WHERE eids.id=?;');
            SET @query_param = eid;
            PREPARE initEntityStmt FROM @initEntityStmtStr;
            EXECUTE initEntityStmt USING @query_param;
            DEALLOCATE PREPARE initEntityStmt;
        END IF;
    
    
        -- ################# VERSIONING #####################
        -- Same as above, but from `archive_name_data` instead of `name_data`.
        IF versioned IS TRUE THEN
            SET select_columns = '` (id, _iversion) SELECT entity_id, _iversion FROM archive_name_data ';
            IF ename IS NOT NULL THEN
                SET @initEntityStmtStr = CONCAT(
                    'INSERT IGNORE INTO `',
                    resultset,
                    select_columns,
                    'WHERE value=?; ');
                SET @query_param = ename;
            ELSEIF enameLike IS NOT NULL THEN
                SET @initEntityStmtStr = CONCAT(
                    'INSERT IGNORE INTO `',
                    resultset,
                    select_columns,
                    'WHERE value LIKE ?;');
                SET @query_param = enameLike;
            ELSEIF enameRegexp IS NOT NULL THEN
                SET @initEntityStmtStr = CONCAT(
                    'INSERT IGNORE INTO `',
                    resultset,
                    'WHERE value REGEXP ?;');
                SET @query_param = enameRegexp;
            END IF;
    
            -- execute the statement
            IF @initEntityStmtStr IS NOT NULL THEN
                PREPARE initEntityStmt FROM @initEntityStmtStr;
                EXECUTE initEntityStmt USING @query_param;
                DEALLOCATE PREPARE initEntityStmt;
            END IF;
        END IF;
        -- ##################################################
    
    
        IF @initEntityStmtStr IS NOT NULL THEN
            call getChildren(resultset, versioned);
        END IF;
    
    END;
    //
    DELIMITER ;
    
    
    
    
    DROP PROCEDURE IF EXISTS db_5_0.applyRole;