2012-06-18 54 views
5

मेरे पास दो टेबल table1 और table2 हैं जिनमें प्रत्येक को अन्य कॉलम के साथ email नामक कॉलम है। मैं जो चाहता हूं वो एक वैधकर्ता है जो कॉलम दोनों के email फ़ील्ड में विशिष्टता की तलाश करता है। मुझे extension मिला जो के कई कॉलम की जांच करता है तालिका। मैं इसे कैसे बढ़ा सकता हूं ताकि यह एकाधिक कॉलम के लिए काम करे?वाईआई विभिन्न तालिकाओं के दो स्तंभों पर अद्वितीय सत्यापन यानी। समग्र अद्वितीय सत्यापन

उत्तर

7

आप अन्य वर्गों के लिए निर्दिष्ट करने के लिए className संपत्ति का उपयोग कर सकते ..

प्रलेखन: the ActiveRecord class name that should be used to look for the attribute value being validated. Defaults to null, meaning using the class of the object currently being validated. You may use path alias to reference a class name here.

चलें दो मॉडल में एक विशेषता common_attr कहा जाता है:

class Model1 extends CActiveRecord{ 
    public function rules(){ 
     array('common_attr', 'unique', 'className'=> 'Model1'), 
     array('common_attr', 'unique', 'className'=> 'Model2'), 
    } 
} 

class Model2 extends CActiveRecord{ 
    public function rules(){ 
     array('common_attr', 'unique', 'className'=> 'Model1'), 
     array('common_attr', 'unique', 'className'=> 'Model2'), 
    } 
} 

और combined key जाँच करने के लिए एकाधिक तालिकाओं से सत्यापन आप CUniqueValidator की मानदंड संपत्ति का उपयोग कर सकते हैं ..किसी भी विस्तार के लिए कोई ज़रूरत नहीं

प्रलेखन: criteria property public array $criteria; additional query criteria. This will be combined with the condition that checks if the attribute value exists in the corresponding table column. This array will be used to instantiate a CDbCriteria object.

class Model1 extends CActiveRecord{ 

    public function rules(){ 
     array('common_attr', 'unique', 'caseSensitive'=>false, 
        'criteria'=>array(
      'join'=>'LEFT JOIN model2 ON model2.common_attr=model1.common_attr', 
          'condition'=>'model2.common_attr=model1.common_attr', 
     )), 
    } 
} 
+0

पहली विधि एक आकर्षण की तरह काम करता है। धन्यवाद :) – dInGd0nG