1

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'=>'')
    );

たとえば、sysnameに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で分割して、dbの負荷を減らしたいと思っています。

どうすればこれを行うことができますか?クエリを分離しておくことは、それ以上の価値があります。

4

2 に答える 2

1

いくつかのクエリを実行することは問題ありません。DBはそれを簡単に処理できます。数十のタイプ(それぞれ数行しかない)に対して数十のクエリを実行している場合は、そのロジックをPHPに移行することを検討する価値があるかもしれません。

私がお勧めするのは、インデックスsystypeが付いた別の列にを配置することです。これにより、クエリの速度が大幅に向上し、DBの負荷がかかります。さらに良いのは、その列を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();
于 2013-02-13T14:47:48.150 に答える
1

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 のドキュメントを必ずお読みください。
于 2013-02-13T14:52:03.037 に答える