0

私はphpを初めて使用し、すべての記事用の独自のページを作成するのに数時間苦労しています。何をしてもうまくいきません。

mysql を mysqli に変換する必要があることはわかっていますが、最初はこれを機能させたいだけです。

url/video.php?id=3 に移動すると、空白のページが表示されるだけで、記事の表から「名前」が出力されません

助言がありますか?

video.php

<?php 

include "connect.php"; 


$id = mysql_real_escape_string($_GET['id']);
$query = "SELECT `name` FROM `article` WHERE `id` = '.$id.'";
$result = mysql_query($query);
$row = mysql_fetch_array($result);

// Echo page content
echo $row['name'];
?>

次のようにindex.phpからリンクしています

 <a href="/video.php?id=<? echo $row[id]; ?> 

動作します。

4

4 に答える 4

0

$row 変数の値をテストしましたか? 値を確認するために使用var_dump($row)します。

ところで、ID を確認する必要があります。

if (isset($_GET['id']))
{
  $id = $_GET['id'];
  echo $id;
}
于 2013-10-30T21:14:17.283 に答える
0

私が見る別のことですが、あなたがした場合:

  • MySQL サーバーに接続できましたか?
  • 使用するデータベースを選択しましたか?
  • PHPのmysql_result関数を知っていますか? と
  • MySQLのLIMITを知っていますか?

試す:

MySQL:

/**
* Connect and define your connection var
*/
$connection = mysql_connect("localhost","root","");
/**
*   Select your database
*/
mysql_select_db("mydatabase",$connection);

/**
* Check if exists "id" in $_GET
*/
if( array_key_exists( "id" , $_GET ) )
{
    $id = mysql_real_escape_string( $_GET [ "id" ],$connection );
    /**
    *   Remember use LIMIT
    */
    $source = mysql_query("SELECT `name` FROM `article` WHERE `id` = '$id' LIMIT 1",$connection);

    /**
    * if you need print only name
    */
    if( mysql_num_rows( $source ) )
    {
        // print only name
        echo mysql_result( $source );
    }
    /**
    * but if you need retrive array
    */
    $row = mysql_fetch_assoc( $source );
    echo $row["name"];
}

MySQL:

/**
* Connect and define your connection var
*/
$connection = mysqli_connect("localhost","root","");
/**
* Check if is connected[ http://us2.php.net/manual/en/mysqli.connect-errno.php ]
*/
if( mysqli_connect_errno() == 0 )
{
    /**
    *   Select your database
    */
    mysqli_select_db( $connection , "mydatabase" );

    /**
    * Check if exists "id" in $_GET
    */
    if( array_key_exists( "id" , $_GET ) )
    {
        $id = mysqli_real_escape_string($connection,$_GET [ "id" ]);
        /**
        *   Remember use LIMIT
        */
        $source = mysqli_query($connection,"SELECT `name` FROM `article` WHERE `id` = '$id' LIMIT 1");

        /**
        * if you need print only name
        */
        if( mysqli_num_rows( $source ) )
        {
            // print only name
            $row = mysqli_fetch_array( $source );
            echo $row[0];
        }
        /**
        * but if you need retrive array
        */
        $row = mysqli_fetch_assoc( $source );
        echo $row["name"];
    }

}

そして、 MySQLのLIMITについて読んでください。

幸運を!

于 2013-10-30T21:38:57.800 に答える
-1

あなたの質問が示唆しているように、idが数値フィールドの場合、それは

$id = (int)$_GET['id'];
$query = "SELECT `name` FROM `article` WHERE `id` = $id";

ID が数値フィールドの場合。

クエリ文字列内のドットも削除したことに注意してください。これによりid、数値フィールドであるかどうかにかかわらず、クエリが無効になります。

于 2013-10-30T21:05:24.653 に答える