1

我有一些选项存储在 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;
}
4

2 回答 2

1

每次使用数据库连接调用该函数时,您都在打开、查询和关闭与数据库的连接......这会导致 SQL 服务器和 PHP/MySQL 连接器的大量开销。如果有很多查询,您可以在资源不足的情况下运行服务器。将其拉入一个数组,这样您就只使用一个数据库连接和一个查询,如下所示:

<?php
$sql = "select * from database.table;";
$result = mysql_query($sql);
while ($db_entry = mysql_fetch_array($result)){

    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']; }

}
?>

PDO 示例(未测试):

<?php
try {
$DBH = new PDO("mssql:host=$host;dbname=$dbname, $user, $pass");    
}
catch(PDOException $e) {  
   echo $e->getMessage();  
}  

$STH = $DBH->query('select * from database.table');

$STH->setFetchMode(PDO::FETCH_OBJ); 

while($row = $STH->fetch()) {

    switch($row->option_name){
    case 'mode':
    $_mode = $row->option_default;
    break;
    case 'email':
    $_email = $row->option_default;
    break;
    case 'timezone':
    //timezone
    $_timezone = $row->option_default;
    default:
    //do something else
    }

}

?>
于 2013-03-21T16:40:43.297 回答
0

使用一个数组,$option_defaults例如,而不是您的单个变量($_timezone,$_mode$_email),并使用作为关联值$db_entry['option_name']的键向其中添加条目。$db_entry['option_default']

于 2013-03-21T16:48:33.660 回答