0

我在我的网站上写了很多 SELECT * FROM... 类型的查询。我想编写一个函数来为我处理这个问题,这样我就可以更快地调用它,而无需使用 PDO 和 OOP 等更高级的技术。我只是对如何调用从数据库中检索到的数据感到困惑,尤其是在遍历数组结果时。

我喜欢这样的东西:

function selectAll($tableName, $limitAmount) {
    global $dbConnection;
    $query = mysql_query("SELECT * FROM $tableName ORDER BY id LIMIT $limitAmount");
    $row_result = mysql_fetch_assoc($query);
    return $row_result;
}

说这是一堆新闻帖子。我想以一种典型的方式遍历结果:

// CALL THE FUNCTION
selectAll('news_table', '10');

// SOMEHOW LOOP THROUGH RESULTS??
do {
    echo "<h2>".$row_result['title']."</h2>";
} while ($row_result = mysql_fetch_assoc($query));

显然,这不是我遍历函数的定制结果的方式。我什至不确定我的功能是否正确。

任何帮助是极大的赞赏。

编辑:忘记在函数内返回结果并调用实际函数。我的错。现在更新了。

4

1 回答 1

1

像你这样调用这样的函数是没有意义的。

就这样吧

function fetchAll($query) {
  $res = mysql_query($query) or trigger_error("db: ".mysql_error()." in ".$query);
  $a   = array();
  if ($res) {
    while($row = mysql_fetch_assoc($res)) $a[]=$row;
  }
  return $a;
}

并将其与任何查询一起使用:

$data = fetchAll("SELECT * FROM news_table ORDER BY id LIMIT 10");
foreach ($data as $row) {
    echo $row['title'];
}

SQL 查询本身就是一个强大的程序。不要将它的力量降低到愚蠢的选择上。
使用 SQL 表示数据处理逻辑和此辅助函数以避免重复。

于 2012-05-07T11:03:03.197 回答