设计数据库字段经常会使用1,2,3来代表数据记录的状态

1.如果在设计数据库字段经常会使用1,2,3来代表数据记录的状态,在程序中使用过的时候又不容易记住涵义,
 需要将数字转换成为相对应的状态名称。下面有两种方法可以解决这个问题:
 第一种方法:在相对应的model中定义一个函数(例如UserModel)

 private static $_items = array();
 public static function loadItems($type,$code=null)
{
    self::$_items = array(
        'status' => array(
            '1' => Yii::t('dh','开启'),
            '2' => Yii::t('dh','关闭'),
        ),
         'type' => array(
            '1' => Yii::t('dh','审核'),
            '2' => Yii::t('dh','结束'),
           '3' => Yii::t('dh','待审核'),
        ),
    );
    return $code ? self::$_items[$type][$code] : self::$_items[$type];
}

  



数据获取方法:
User::model()->loadItems('status',2);

第二中方法:定义静态变量

public static $status =  array(
            '1' => Yii::t('dh','开启'),
            '2' => Yii::t('dh','关闭'),
        );
public static $type = array(
            '1' => Yii::t('dh','审核'),
            '2' => Yii::t('dh','结束'),
            '3' => Yii::t('dh','待审核'),
        );


数据获取方法:

User::$status[2];

第三种方法:

视图

<input type="button" class="but_downs" id="shouluzt" 
value="<?php if(isset($_GET['type_id'])) echo $type[$_GET['type_id']]['name']; else echo '全部'; ?>" /> //通过id去取他的值
控制器
$arrType = ContentType::model()->getTypeById();
'type' => $arrType,

 


public function getTypeById(){ $cache_name=md5('model_ContentType_getTypeById'); $data=Yii::app()->memcache->get($cache_name); if(!$data){ $result=$this->findAll('status=:status',array(':status'=>1)); if(!empty($result)){ foreach($result as $val){ $data[$val->id]['code']=$val->code; $data[$val->id]['name']=$val->name; } } Yii::app()->memcache->set($cache_name,$data,3000); } return $data; }

  

 

 

转载于:https://www.cnblogs.com/fengzhiqiangcaisangzi/p/3361346.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值