mirror of
https://github.com/yiisoft/yii2.git
synced 2026-03-06 23:39:02 +01:00
* Add github action for testing oci8 Oracle. * Fix CommandTest::testQueryCache. * Fix tests CommandTest::testBindParamsNonWhere. * Fix test CommandTest::testInsert. * Fix test CommanTest::testInsertExpression. * Fix test CommandTest::testInsertSelectAlias. * Fix test CommandTest::testBindParamValue. * Fix tests CommandTest::testBatchInsertDataTypesLocale. * Fix test CommandTest::testNoTablenameReplacement. * Fix test CommandTest::testCreateTable. * Fix test CommandTest::testsInsertQueryAsColumnValue. * Fix tests CommandTest::testAlterTable. * Fix test CommandTest::testCreateView. * Fix test CommandTest::testTransaction. * Fix test ConnectionTest::testTransactionShortcutCorrect. * Fix test ConnectionTest::testTransactionShortcutCustom. * Fix test ConnectionTest::testEnableQueryLog. * Fix test QueryBuilder::testAddDropDefaultValue. * Fix test QueryTest::testUnion. * Fix test QueryTest::testExpressionInFrom. * Fix test SchemaTest::testFindUniqueIndexes. * Fix test QueryBuilderTest::testGetColumnType. * Fix test ActiveRecordTest::testFind. * Fix test ExistValidatorTest::testExpresionInAttributeColumnName. * Fix test UniqueValidatorTest::testExpressionInAttributeColumnName. * Fix ActiveRecordTest testCastValues(), testDefaultValues. * Fix test UniqueValidatorTest::testValidateAttributeDefault. * Fix test UniqueValidatorTest::testValidateEmptyAttributeInStringField. * Fix test UniqueValidatorTest::testValidateEmptyAttributeInIntField. * Fix test ActiveRecordTest::testBit. * Fix test ActiveRecordTest::testBooleanAttribute. * Fix test ActiveRecordTest::testJoinWithAlias. * Fix test SchemaTest::testColumnSchema. * Fix test CommandTest:: testBatchInsertSQL. * Skip CommandTest::testColumnCase. * Fix test ConnectionTest::testQuoteValue. * Should be fixed tests conditionsProvider in QueryBuilderTest. * Fix ActiveRecordTest.php * Fix test UniqueValidatorTest. * Fix test QueryBuilderTest::testUpsert. * Skip SchemaTest::testCompositeFK.
106 lines
2.7 KiB
PHP
106 lines
2.7 KiB
PHP
<?php
|
|
/**
|
|
* @link http://www.yiiframework.com/
|
|
* @copyright Copyright (c) 2008 Yii Software LLC
|
|
* @license http://www.yiiframework.com/license/
|
|
*/
|
|
|
|
namespace yiiunit\data\ar;
|
|
|
|
use yii\db\ActiveQuery;
|
|
use yiiunit\framework\db\ActiveRecordTest;
|
|
|
|
/**
|
|
* Class Customer.
|
|
*
|
|
* @property int $id
|
|
* @property string $name
|
|
* @property string $email
|
|
* @property string $address
|
|
* @property int $status
|
|
*
|
|
* @method CustomerQuery findBySql($sql, $params = []) static
|
|
*/
|
|
class Customer extends ActiveRecord
|
|
{
|
|
const STATUS_ACTIVE = 1;
|
|
const STATUS_INACTIVE = 2;
|
|
|
|
public $status2;
|
|
|
|
public $sumTotal;
|
|
|
|
public static function tableName()
|
|
{
|
|
return 'customer';
|
|
}
|
|
|
|
public function getProfile()
|
|
{
|
|
return $this->hasOne(Profile::className(), ['id' => 'profile_id']);
|
|
}
|
|
|
|
public function getOrdersPlain()
|
|
{
|
|
return $this->hasMany(Order::className(), ['customer_id' => 'id']);
|
|
}
|
|
|
|
public function getOrders()
|
|
{
|
|
return $this->hasMany(Order::className(), ['customer_id' => 'id'])->orderBy('[[id]]');
|
|
}
|
|
|
|
public function getExpensiveOrders()
|
|
{
|
|
return $this->hasMany(Order::className(), ['customer_id' => 'id'])->andWhere('[[total]] > 50')->orderBy('id');
|
|
}
|
|
|
|
public function getOrdersWithItems()
|
|
{
|
|
return $this->hasMany(Order::className(), ['customer_id' => 'id'])->with('orderItems');
|
|
}
|
|
|
|
public function getExpensiveOrdersWithNullFK()
|
|
{
|
|
return $this->hasMany(OrderWithNullFK::className(), ['customer_id' => 'id'])->andWhere('[[total]] > 50')->orderBy('id');
|
|
}
|
|
|
|
public function getOrdersWithNullFK()
|
|
{
|
|
return $this->hasMany(OrderWithNullFK::className(), ['customer_id' => 'id'])->orderBy('id');
|
|
}
|
|
|
|
public function getOrders2()
|
|
{
|
|
return $this->hasMany(Order::className(), ['customer_id' => 'id'])->inverseOf('customer2')->orderBy('id');
|
|
}
|
|
|
|
// deeply nested table relation
|
|
public function getOrderItems()
|
|
{
|
|
/* @var $rel ActiveQuery */
|
|
$rel = $this->hasMany(Item::className(), ['id' => 'item_id']);
|
|
|
|
return $rel->viaTable('order_item', ['order_id' => 'id'], function ($q) {
|
|
/* @var $q ActiveQuery */
|
|
$q->viaTable('order', ['customer_id' => 'id']);
|
|
})->orderBy('id');
|
|
}
|
|
|
|
public function afterSave($insert, $changedAttributes)
|
|
{
|
|
ActiveRecordTest::$afterSaveInsert = $insert;
|
|
ActiveRecordTest::$afterSaveNewRecord = $this->isNewRecord;
|
|
parent::afterSave($insert, $changedAttributes);
|
|
}
|
|
|
|
/**
|
|
* {@inheritdoc}
|
|
* @return CustomerQuery
|
|
*/
|
|
public static function find()
|
|
{
|
|
return new CustomerQuery(\get_called_class());
|
|
}
|
|
}
|