我有一些选项存储在 mysql 中。该表包含 4 列,如下所示:
option_id | option_name | option_default | option_user_value
------------------------------------------------------------
1 | timezone | Europe/Athens |
2 | mode | 1 |
3 | email | test@test.test |
到目前为止,我使用以下 php 代码从数据库中获取该信息:
$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()
如果你愿意,也请检查我的功能。我仍在学习(还不熟悉 OO)并提前感谢。祝你今天过得愉快。
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;
}