示例
public $inputs=array(
array( 'sysname'=>'pt_name','dbname' => 'users.name','label' => 'user (name/ID)','value' => '',
'type' => 'text','rules' => 'required','attr'=>'class="autocomplete"'),
array( 'sysname'=>'pt_dob','dbname' => 'users.dob','label' => 'Patient Dob','value' => '',
'type' => 'text','rules' => 'required','attr'=>'class="dob ac" Disabled'),
array( 'sysname'=>'pt_gender','dbname' => 'users.gender','label' => 'gender','value' => 'male,female',
'type' => 'dropdown','rules' => 'required','attr'=>'class="ac" Disabled'),
array( 'sysname'=>'visit_date','dbname' => 'visits.date','label' => 'Date','value' => '',
'type' => 'text','rules' => 'required','attr'=>'class="datepicker"'),
array( 'sysname'=>'visit_time','dbname' => 'visits.time_booked','label' => 'Time','value' => '',
'type' => 'text','rules' => 'required','attr'=>'class="timepicker"'),
array( 'sysname'=>'visit_type','dbname' => 'visits.type','label' => 'Visit type','value' => 'visit,schedule',
'type' => 'dropdown','rules' => 'required','attr'=>'')
);
例如,我如何在这个数组中只搜索系统名称中有pt_的数组?
这个想法是,我在同一个表中有许多类型的行,所以不用运行mysql查询来分别获取每种类型,例如:
$pt=db->query("select * from table where sysname like 'pt_%'")->result();
$visit=db->query("select * from table where sysname like 'visit_%'")->result();
我想一次获取所有内容,并将它们拆分到php中,以减少数据库负载。
那么我该怎么做呢?把我的查询分开值得吗。
array_filter和PHP风格的闭包*将是一个非常简单的解决方案:
function buildFilter($key, $needle) {
return function($array) use($key, $needle) {
return (strpos($array[$key], $needle) !== FALSE);
};
}
$matches = array_filter($inputs, buildFilter('sysname', 'pt_'));
var_dump($matches);
- 注意:PHP所称的"闭包"与大多数其他语言对同一术语的使用有很大不同,所以请务必阅读PHP文档
做几个查询很好,您的数据库可以轻松处理。如果您正在为数十种类型(每个类型只有几行)执行数十个查询,那么将该逻辑转移到PHP可能是值得研究的。
我建议把systype
放在一个单独的列中,上面有一个索引。这会大大加快查询速度,并占用数据库的负载。更好的是,您可以将该列设置为ENUM。
public $inputs=array(
array( 'systype'=>'pt', 'sysname'=>'pt_name','dbname' => 'users.name','label' => 'user (name/ID)','value' => '',
'type' => 'text','rules' => 'required','attr'=>'class="autocomplete"'),
...
$pt=db->query("select * from table where systype = 'pt'")->result();
$visit=db->query("select * from table where systype = 'visit'")->result();