gpt4 book ai didi

php - 在 php foreach 循环中从 mysql 获取数据的有效方法

转载 作者:行者123 更新时间:2023-11-29 00:33:18 24 4
gpt4 key购买 nike

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

最佳答案

每次您使用数据库连接调用该函数时,您将打开、查询和关闭与数据库的连接……这会导致 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
}

}

?>

关于php - 在 php foreach 循环中从 mysql 获取数据的有效方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15553107/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com