我有一些選項存儲在mysql中。 表包含4列看起來像這樣:在PHP foreach循環中從mysql中獲取數據的有效方法
option_id | option_name | option_default | option_user_value
------------------------------------------------------------
1 | timezone | Europe/Athens |
2 | mode | 1 |
3 | email | [email protected] |
到目前爲止,我使用類似下面的PHP代碼從DB獲得這些信息:
$table = 'options';
$values = '
option_name,
option_default,
option_user_value
';
$where = null;
$options = get_db_entries($table, $values, $where);
if ($options)
{
foreach ($options as $db_entry)
{
if ($db_entry['option_name'] == 'timezone')
{ $_timezone = $db_entry['option_default']; }
if ($db_entry['option_name'] == 'mode')
{ $_mode = $db_entry['option_default']; }
if ($db_entry['option_name'] == 'email')
{ $_email = $db_entry['option_default']; }
}
}
有沒有更有效的方法,以避免循環中的那些'if'語句? 我的意思是有沒有辦法將這些信息從那些列直接插入到沒有IF的每個變量?
只是出於好奇,請檢查我的get_db_entries()
功能,如果你想。 我還在學習(不熟悉面向對象),並提前致謝。 祝您有愉快的一天。
function get_db_entries($table, $values, $where)
{
$db_host = '........';
$db_name = '........';
$db_user = '........';
$db_pass = '........';
// -----------------------------------------------------
$dbh = new PDO(
'mysql:host='.$db_host.'; dbname='.$db_name,
$db_user,
$db_pass,
array(PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES utf8")
);
// -----------------------------------------------------
if ($where) { $where = ' WHERE '.$where; }
$sql = 'SELECT '.$values.' FROM '.$table.$where;
$results = $dbh->query($sql);
// -----------------------------------------------------
$results_array = array();
foreach ($results as $db_entry)
{ array_push($results_array, $db_entry); }
return $results_array;
}
每次進行數據庫查詢時都不要重新創建數據庫句柄。而不是「如果 - 然後」你的循環死亡,爲什麼不把表結果放入數組? – Crontab 2013-03-21 16:35:36
你是什麼意思「重新創建你的數據庫句柄」?如果你能解釋一下,我該怎麼做這個錯誤?另外,如果你檢查函數,它已經返回一個數組(檢查結束時檢查)。 – durduvakis 2013-03-21 16:40:40
有關我的意思,請參閱cpattersonv1的答案。 – Crontab 2013-03-21 18:08:44