2013-02-13 63 views
1

例如搜索PHP ASSOC陣列(散列映射)如MySQL的

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查詢獲取每種類型separatly例如:

$pt=db->query("select * from table where sysname like 'pt_%'")->result(); 
$visit=db->query("select * from table where sysname like 'visit_%'")->result(); 

我想在一個獲取所有和他們分裂PHP來減少數據庫負載。

那麼我該如何做到這一點?這是值得的或更好的保持我的querys分開。

+0

使用'foreach'和'strpos' – Pitchinnate 2013-02-13 14:37:30

回答

1

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文檔。
+0

這是否可以在課堂內使用? 致命錯誤:無法將類型爲stdClass的對象用作數組 – Zalaboza 2013-02-14 08:09:58

+0

您必須將$ array [$ key]更改爲$ array - > $ key – TML 2013-02-16 09:54:52

+0

您決定取消接受答案的任何特定原因?我的意思是,如果你接受了另一個答案,那將是一回事 - 但現在當我認爲你確實得到了一個有效的答案時,這個答案就是懸而未決的「未回答」? – TML 2013-03-05 16:00:20

1

做幾個查詢很好,你的數據庫可以很容易地處理。如果您爲幾十種類型(每種類型只有幾行)執行數十種查詢,那麼將該邏輯移至PHP可能值得研究。

我會推薦的是把systype放在一個單獨的列上,上面有an index。這會加快你的查詢速度,並加載你的數據庫。更好的是,你可以使該欄位爲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();