13

我制作了一个 PHP 页面,该页面应该从数据库中选择两个名称并显示它们。

它只是说:

警告:mysqli_query() 至少需要 2 个参数,1 个在 /home/tdoylex1/public_html/dorkhub/index.php 第 4 行给出

警告:mysqli_query() 需要至少 2 个参数,1 个在 /home/tdoylex1/public_html/dorkhub/index.php 第 8 行给出

我的代码是:

<?php mysqli_connect(localhost,tdoylex1_dork,dorkk,tdoylex1_dork);
$name1 = mysqli_query("SELECT name1 FROM users
ORDER BY RAND()
LIMIT 1");

$name2 = mysqli_query("SELECT name FROM users
ORDER BY RAND()
LIMIT 1");

?>

<title>DorkHub. The online name-rating website.</title>
<link rel="stylesheet" type="text/css" href="style.css">
<body bgcolor='EAEAEA'>
<center>
<div id='TITLE'>
    <h2>DorkHub. The online name-rating website.</h2>
</div>
    <p>
    <br>
    <h3><?php echo $name1; ?></h3><h4> against </h4><h3><?php echo $name1; ?></h3>
    <br><br>
    <h2 style='font-family:Arial, Helvetica, sans-serif;'>Who's sounds the dorkiest?</h2>
    <br><br>
    <div id='vote'>
    <h3 id='done' style='margin-right: 10px'>VOTE FOR FIRST</h3><h3 id='done'>VOTE FOR LAST</h3>
4

2 回答 2

31

问题是您没有保存 mysqli 连接。将您的连接更改为:

$aVar = mysqli_connect('localhost','tdoylex1_dork','dorkk','tdoylex1_dork');

然后将其包含在您的查询中:

$query1 = mysqli_query($aVar, "SELECT name1 FROM users
    ORDER BY RAND()
    LIMIT 1");
$aName1 = mysqli_fetch_assoc($query1);
$name1 = $aName1['name1'];

也不要忘记将您的连接变量包含为字符串,就像我上面所说的那样。这是导致错误的原因,但您使用的函数错误,mysqli_query 返回一个查询对象,但要从中获取数据,您需要使用类似 mysqli_fetch_assoc http://php.net/manual/en/mysqli-result .fetch-assoc.php将数据实际获取到变量中,就像我上面所说的那样。

于 2013-10-02T23:38:57.027 回答
5

mysqli_query除了 2 个参数,第一个变量是等效mysqli_connect变量,第二个是您提供的查询

$name1 = mysqli_connect(localhost,tdoylex1_dork,dorkk,tdoylex1_dork);

$name2 = mysqli_query($name1,"SELECT name FROM users ORDER BY RAND() LIMIT 1");
于 2018-06-10T11:23:26.413 回答