gpt4 book ai didi

php - 搜索 php assoc array (hash map) 作为 mysql

转载 作者:行者123 更新时间:2023-11-29 06:51:53 25 4
gpt4 key购买 nike

例子

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 风格的 closure * 将是一个非常简单的解决方案:

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 - 搜索 php assoc array (hash map) 作为 mysql,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14855826/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com