本文整理匯總了PHP中Core\Helper\Utility\Validator::requireArray方法的典型用法代碼示例。如果您正苦於以下問題:PHP Validator::requireArray方法的具體用法?PHP Validator::requireArray怎麽用?PHP Validator::requireArray使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在類Core\Helper\Utility\Validator
的用法示例。
在下文中一共展示了Validator::requireArray方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。
示例1: countOrderSettleArray
/**
*
* 取得一組記錄的數目,用於分頁
*
* @return int 查詢條數
*
* @param array $condArray 查詢條件數組,例如:
* array(
* array('supplier_id = ?', $supplier_id)
* array('is_on_sale = ?', 1)
* array('create_time > ? or create_time < ?', $timeMin, $timeMax)
* )
*
* @param int $ttl 緩存多少時間
*
*/
public function countOrderSettleArray(array $condArray, $ttl = 0)
{
// 參數驗證
$validator = new Validator(array('condArray' => $condArray), '');
$condArray = $validator->requireArray(true)->validate('condArray');
$this->validate($validator);
return $this->_countArray('order_settle', $condArray, null, $ttl);
}
示例2: _countArray
/**
*
* 取得一組記錄的數目,用於分頁
*
* @return int 查詢條數
*
* @param mixed $table 需要查詢的數據表,可以是單個表,例如:'user',
* 也可以是多個表的數組,例如:array('user' ,'order_info' => 'oi')
*
* @param array $condArray 查詢條件數組,例如:
* array(
* array('supplier_id = ?', $supplier_id)
* array('is_on_sale = ?', 1)
* array('supplier_price > ? or supplier_price < ?', $priceMin, $priceMax)
* )
* 這些查詢條件最終會用 and 拚接起來
* @param array $optionArray 目前不支持 Having 查詢,留待以後擴展
* @param int $ttl 緩存多少時間
*
*/
public function _countArray($table, array $condArray = null, array $optionArray = null, $ttl = 0)
{
// 構造參數驗證數組
$validatorArray = array();
$validatorArray['table'] = $table;
$validatorArray['ttl'] = $ttl;
if (null != $condArray) {
$validatorArray['condArray'] = $condArray;
}
if (null != $optionArray) {
$validatorArray['optionArray'] = $optionArray;
}
// 參數驗證
$validator = new Validator($validatorArray, '');
$table = $validator->required()->validate('table');
$ttl = $validator->digits()->min(0)->validate('ttl');
if (null != $condArray) {
$condArray = $validator->requireArray(false)->validate('condArray');
}
if (null != $optionArray) {
$optionArray = $validator->requireArray(false)->validate('optionArray');
}
$this->validate($validator);
// 構造查詢條件
$filter = null;
if (!empty($condArray)) {
$filter = QueryBuilder::buildAndFilter($condArray);
}
// 創建 DataMapper
$dataMapper = new DataMapper($table);
if (is_string($table)) {
//簡單的單表查詢
$table = array($table);
}
if (is_array($table)) {
// 複雜的多表查詢
return $dataMapper->selectCount($table, $filter, $optionArray, $ttl);
}
throw new \InvalidArgumentException('table should be string or array');
}
示例3: fetchOrderInfoOrderGoodsArray
/**
*
* 對 order_info , order_goods 做 inner_join 查詢
*
* @param array $condArray
* @param int $offset
* @param int $limit
* @param int $ttl
*
* @return array
*/
public function fetchOrderInfoOrderGoodsArray(array $condArray, $offset = 0, $limit = 10, $ttl = 0)
{
// 參數驗證
$validator = new Validator(array('condArray' => $condArray), '');
$condArray = $validator->requireArray(true)->validate('condArray');
$this->validate($validator);
$tableInnerJoinStr = DataMapper::tableName('order_goods') . ' as og INNER JOIN ' . DataMapper::tableName('order_info') . ' as oi ON og.order_id = oi.order_id';
return $this->_fetchArray($tableInnerJoinStr, 'og.*, oi.user_id, oi.pay_time, oi.add_time, oi.order_sn, ' . 'oi.consignee, oi.address, oi.mobile', $condArray, array('order' => 'og.order_id desc, og.rec_id desc'), $offset, $limit, $ttl);
}