Location: PHPKode > projects > Entier Studio > entierstudio/studio/classes/datas/data.RepositoryModelComponentSet.php
<?php
/**
 * Entier Studio
 *
 * LICENSE
 *
 *	Copyright 2006 Entier Studio team.
 *
 *	Licensed under the Apache License, Version 2.0 (the "License");
 *	you may not use this file except in compliance with the License.
 *	You may obtain a copy of the License at
 *
 *		http://www.apache.org/licenses/LICENSE-2.0
 *
 *	Unless required by applicable law or agreed to in writing, software
 *	distributed under the License is distributed on an "AS IS" BASIS,
 *	WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 *	See the License for the specific language governing permissions and
 *	limitations under the License.
 *
 * @package    entier.studio
 * @copyright  Copyright (c) 2006 Entier Studio team. All rights reserved.
 * @version	   $Id: data.RepositoryModelComponentSet.php 81 2008-01-17 23:08:21Z yannromefort $
 */
//-----------------------------------------------------------------------------
//	namespace
if (!defined("DefRepositoryModelComponentSet")) {
    //-------------------------------------------------------------------------
    //	Define
    define("DefRepositoryModelComponentSet", "1");
    //-------------------------------------------------------------------------
    //	Include
    @require_once (FRAMEWORK_DIR . DATASETOBJECT);
    //-------------------------------------------------------------------------
    //	Class
    class RepositoryModelComponentSet extends DataSet {
        //---------------------------------------------------------------------
        //	Constructor
        
        /**
         *
         * @param	integer	RepositoryModelComponent		reflect key $REPMCOMLINK
         * @param	integer	RepositoryModelComponentType	foreign key $REPMCOTPKID
         *
         */
        function RepositoryModelComponentSet($REPMCOMLINK = 0, $REPMCOTPKID = 0) {
            //
            $this->m_tableSet[PRIMARYKEY] = "tbl_repository_model_component";
            //
            $this->m_indexSet[PRIMARYKEY] = "REPMCOMPKID";
            $this->m_indexSet[FOREIGNKEY] = "LRepPkid";
            $this->m_indexSet[NATURALKEY] = "REPMCOMNAME";
            $this->m_indexSet[REFLECTKEY] = "REPMCOTPKID";
            //
            $this->m_querySet[REPMCOMLINK] = $REPMCOMLINK;
            $this->m_querySet[REPMCOTPKID] = $REPMCOTPKID;
        }
        //---------------------------------------------------------------------
        //	Methods
        /*
        *
        * @access	protected
        *
        * @param	integer	index type
        * @param	integer	order type
        * @param	string	order mode
        *
        */
        function getSelectQuery($indexType = FOREIGNKEY, $orderType = NATURALKEY, $orderMode = "") {
            //
            switch ($indexType) {
                case FOREIGNKEY:
                    /*
                    * List of all members of one type
                    * SELECT
                    *			tbl_repository_model_component
                    *		<-> tbl_repository_core_component
                    *		<-> tbl_repository_core_component_type
                    *		<-> tbl_repository_model_component_type
                    * ON
                    *			REPMCOTPKID && REPMCOMLINK
                    *
                    * @see class RepositoryModelComponentExplorer.renderView in view.RepositoryModelComponentExplorer.php line 159
                    *
                    */
                    //
                    $index1 = $this->m_querySet[REPMCOTPKID];
                    $index2 = $this->m_querySet[REPMCOMLINK];
                    if (($index1 != 0) && ($index2 != 0)) {
                        //
                        $selectSQL = "SELECT 
										t1.REPMCOMPKID, 
										t1.REPMCOTPKID, 
										t1.REPMCOMLINK, 
										t1.REPCCOMPKID, 
										t1.REPMCOMNAME, 
										t2.REPCCOTPKID, 
										t2.REPCCOMNAME, 
										t3.REPCCOTNAME, 
										t4.REPMCOTTYPE 
									FROM 
										tbl_repository_model_component as t1, 
										tbl_repository_core_component as t2, 
										tbl_repository_core_component_type as t3, 
										tbl_repository_model_component_type as t4 
									WHERE 
										t1.REPMCOTPKID=$index1 
									AND 
										t1.REPMCOMLINK=$index2 
									AND 
										t1.REPMCOMSTAT>0 
									AND 
										t1.REPCCOMPKID=t2.REPCCOMPKID 
									AND 
										t2.REPCCOMSTAT>0 
									AND 
										t2.REPCCOTPKID=t3.REPCCOTPKID 
									AND 
										t3.REPCCOTPKID=t4.REPCCOTPKID";
                        //
                        switch ($orderType) {
                            case PRIMARYKEY:
                                return ($selectSQL . " ORDER BY t1.REPMCOMPKID $orderMode");
                            case NATURALKEY:
                                return ($selectSQL . " ORDER BY t1.REPMCOMNAME $orderMode");
                            default:
                                return ($selectSQL . " ORDER BY t1.REPMCOTPKID, t1.REPMCOMNAME");
                        }
                    }
                    //
                    
                break;
                case REFLECTKEY:
                    //
                    /*
                    * List of all members ( any type )
                    * SELECT
                    *			tbl_repository_model_component
                    *		<-> tbl_repository_core_component
                    *		<-> tbl_repository_core_component_type
                    *		<-> tbl_repository_model_component_type
                    * ON
                    *		REPMCOMLINK
                    *
                    * @see class RepositoryModelComponentExplorer.renderView in view.RepositoryModelComponentExplorer.php
                    *
                    */
                    //
                    $index = $this->m_querySet[REPMCOMLINK]; {
                            //
                            $selectSQL = "SELECT 
											t1.REPMCOMPKID, 
											t1.REPMCOTPKID, 
											t1.REPMCOMLINK, 
											t1.REPCCOMPKID, 
											t1.REPMCOMNAME, 
											t2.REPCCOTPKID, 
											t2.REPCCOMNAME, 
											t3.REPCCOTNAME, 
											t4.REPMCOTTYPE 
										FROM 
											tbl_repository_model_component as t1, 
											tbl_repository_core_component as t2, 
											tbl_repository_core_component_type as t3, 
											tbl_repository_model_component_type as t4 
										WHERE 
											t1.REPMCOMLINK=$index 
										AND 
											t1.REPMCOMSTAT>0 
										AND 
											t1.REPCCOMPKID=t2.REPCCOMPKID 
										AND 
											t2.REPCCOMSTAT>0 
										AND 
											t2.REPCCOTPKID=t3.REPCCOTPKID 
										AND 
											t3.REPCCOTPKID=t4.REPCCOTPKID";
                            //
                            switch ($orderType) {
                                case PRIMARYKEY:
                                    return ($selectSQL . " ORDER BY t1.REPMCOTPKID, t1.REPMCOMPKID $orderMode");
                                case NATURALKEY:
                                    return ($selectSQL . " ORDER BY t1.REPMCOTPKID, t1.REPMCOMNAME $orderMode");
                                default:
                                    return ($selectSQL . " ORDER BY t1.REPMCOTPKID, t1.REPMCOMPKID");
                            }
                    }
                    //
                    break;
                }
                //
                return ("");
            }
        };
        //	Class
        //-------------------------------------------------------------------------
        
    }
    //	namespace
    //-----------------------------------------------------------------------------
    
?>
Return current item: Entier Studio