Location: PHPKode > projects > Entier Studio > entierstudio/studio/classes/datas/data.RepositoryCoreElementPropertyRuleSet.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.RepositoryCoreElementPropertyRuleSet.php 81 2008-01-17 23:08:21Z yannromefort $
 */
//-----------------------------------------------------------------------------
//	namespace
if (!defined("DefRepositoryCoreElementPropertyRuleSet")) {
    //-------------------------------------------------------------------------
    //	Define
    define("DefRepositoryCoreElementPropertyRuleSet", "1");
    //-------------------------------------------------------------------------
    //	Include
    @require_once (FRAMEWORK_DIR . DATASETOBJECT);
    //-------------------------------------------------------------------------
    //	Class
    class RepositoryCoreElementPropertyRuleSet extends DataSet {
        /*
        *
        * @see DictionaryCoreElementProperty-list.php
        *
        */
        //---------------------------------------------------------------------
        //	Constructor
        
        /**
         *
         * @param	integer	 DictionaryProperty		DICPROPPKID //	foreign key
         *
         */
        function RepositoryCoreElementPropertyRuleSet($DICPROPPKID = 0) {
            //
            $this->m_tableSet[PRIMARYKEY] = "tbl_dictionary_property_rule";
            $this->m_indexSet[PRIMARYKEY] = "DICPRULPKID";
            $this->m_indexSet[FOREIGNKEY] = "DICPVALPKID";
            $this->m_indexSet[NATURALKEY] = "DICPROPNAME";
            //
            $this->m_querySet["DICPROPPKID"] = $DICPROPPKID;
        }
        //-------------------------------------------------------------------------
        //	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:
                    /*
                    *
                    * SELECT tbl_dictionary_property_value <-> tbl_dictionary_property_rule <-> tbl_dictionary_property
                    * ON index = DICPRUTPKID + DICPVALPKID
                    */
                    //
                    $index = $this->m_querySet["DICPROPPKID"];
                    if ($index != 0) {
                        //
                        $selectSQL = "SELECT 
										t2.DICPRULNAME, 
										t2.DICPRULCODE, 
										t3.DICPROPPKID, 
										t3.DICPROPNAME,
										t3.DICPROPCODE 
									FROM 
										tbl_dictionary_property_value as t1, 
										tbl_dictionary_property_rule as t2, 
										tbl_dictionary_property as t3 
									WHERE 
										t1.DICPROPPKID=$index 
									AND 
										t1.DICPVALPKID=t2.DICPVALPKID 
									AND 
										t2.DICPRULSTAT>0 
									AND 
										t2.DICPROPPKID=t3.DICPROPPKID 
									AND 
										t3.DICPROPSTAT>0"GROUPBYt3 . DICPROPPKID";
						//
						switch($orderType)
						{
							case PRIMARYKEY :
								return( $selectSQL . "ORDERBYt3 . DICPROPPKID $orderMode" );
							case NATURALKEY :
								return( $selectSQL . "ORDERBYt3 . DICPROPNAME $orderMode" );
							default			:
								return( $selectSQL . "ORDERBYt3 . DICPROPNAME" );
							}
						}
					//
					break;
				}
			//
			return("");
			}
		};
	//	Class
	//-------------------------------------------------------------------------
	}
//	namespace
//-----------------------------------------------------------------------------
?>
Return current item: Entier Studio