Heim Backend-Entwicklung PHP-Tutorial mysql_query() 实施结果一直为false

mysql_query() 实施结果一直为false

Jun 13, 2016 pm 01:10 PM
connection protected quot this

mysql_query() 执行结果一直为false
1)现有一个数据库名为test,里面只有一个表student。
属性名称:ID, Name, Email.
2)尝试着将数据库连接与操作封装成一个类DatabaseManager,并扩展了一个类StudentDetailsDataManager来获取学生信息。
3)问题:能够连接到test数据库,sql语句在数据库中测试过没有问题,但mysql_query()执行sql语句结果一直为false。不知什么问题?

代码如下:
数据库操作基类:DatabaseManager

PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
//DatabaseManager.php
<?php class DatabaseManager{
        
        protected $host;
        protected $name;
        protected $user;
        protected $psw;
        
        protected $connection;
        protected $close_flag;
        
        public function __construct($connection,$close_flag){
            $this->connection = $connection;
            $this-&gt;connection = $close_flag;
        }
        
        protected function db_open(){
            if(empty($this-&gt;connection)){
                $this-&gt;connection = mysql_connect($this-&gt;host,$this-&gt;user,$this-&gt;psw);
                if (!$this-&gt;connection) {
                    $this-&gt;db_handle_error_connetion();
                    return false;
                }
                if (!mysql_select_db($this-&gt;name,$this-&gt;connection)) {
                    $this-&gt;da_handle_select();
                    return false;
                }
            }
        }
        
        
        public function db_close(){
            if($this-&gt;connection)
                mysql_close($this-&gt;connection);
        }
        
        protected function db_handle_error_connetion(){
            echo 'Failed connetion';
        }
        protected function db_handle_select(){
            echo 'Failed access database!';
        }
    }

?&gt;

Nach dem Login kopieren


------
派生类:StudentDetailsDataManager
PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
//StudentDetailsDataManager.php
<?php require 'DatabaseManager.php';
    
    class StudentDetailsDataManager extends DatabaseManager{
        public function __construct($connection="",$close_flag=true){
            parent::__construct($connection, $close_flag);
            $this->host = "localhost";
            $this-&gt;user = "root";
            $this-&gt;psw = "root";
            $this-&gt;name = "test";
            $this-&gt;db_open();    
        }
        
        public function getStudentInfo($ID,&amp;$data){
            //$query = "SELECT * FROM student WHERE ID ='$ID'";
            $query = "select * from student where ID = '$ID'";
            $result = mysql_query($query);
            //print_r($result);
            if (!$result) {
                echo "result is empty!!";
                return false;
            }
            
            $data = mysql_fetch_array($result,MYSQL_ASSOC);
            mysql_free_result($result);
        }
    }

?&gt;

Nach dem Login kopieren


----
使用StudentDetailsDataManager实例获取学生信息
PHP code
<!--

Code highlighting produced by Actipro CodeHighlighter (freeware)
http://www.CodeHighlighter.com/

-->
<?php require_once 'StudentDetailsDataManager.php';
    $stuDataManager = new StudentDetailsDataManager();
    $ID = "DA123456"; $data=NULL;
    $stuDataManager->getStudentInfo($ID, $data);
    $stuDataManager-&gt;db_close();
    echo $data["ID"];
?&gt;

Nach dem Login kopieren


------解决方案--------------------
mysql_error看一下就知道了
------解决方案--------------------
public function __construct($connection,$close_flag){
$this->connection = $connection;
$this->connection = $close_flag;
}
这么严重的错误都看不出来?

另外
if (!mysql_select_db($this->name,$this->connection)) {
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
2 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Repo: Wie man Teamkollegen wiederbelebt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island Abenteuer: Wie man riesige Samen bekommt
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So beheben Sie einen Verbindungsfehler So beheben Sie einen Verbindungsfehler Nov 07, 2023 am 10:44 AM

So beheben Sie einen Verbindungsfehler

Was bedeutet CONNECTION_REFUSED? Was bedeutet CONNECTION_REFUSED? Jul 31, 2023 pm 02:48 PM

Was bedeutet CONNECTION_REFUSED?

PHP-Warnung: mysqli_connect(): (HY000/2002): Lösung für Verbindung abgelehnt PHP-Warnung: mysqli_connect(): (HY000/2002): Lösung für Verbindung abgelehnt Jun 23, 2023 am 08:54 AM

PHP-Warnung: mysqli_connect(): (HY000/2002): Lösung für Verbindung abgelehnt

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决 Jun 13, 2016 am 10:23 AM

php提交表单通过后,弹出的对话框怎样在当前页弹出,该如何解决

Können wir in Java eine Klasse der obersten Ebene als geschützt oder privat deklarieren? Können wir in Java eine Klasse der obersten Ebene als geschützt oder privat deklarieren? Sep 12, 2023 pm 07:21 PM

Können wir in Java eine Klasse der obersten Ebene als geschützt oder privat deklarieren?

Ein Artikel, der diesen Punkt versteht und 70 % der Front-End-Leute erreicht Ein Artikel, der diesen Punkt versteht und 70 % der Front-End-Leute erreicht Sep 06, 2022 pm 05:03 PM

Ein Artikel, der diesen Punkt versteht und 70 % der Front-End-Leute erreicht

So verwenden Sie diese Methode in Java So verwenden Sie diese Methode in Java Apr 18, 2023 pm 01:58 PM

So verwenden Sie diese Methode in Java

Java-Programme weisen unterschiedliche Zugriffsebenen auf Java-Programme weisen unterschiedliche Zugriffsebenen auf Aug 19, 2023 pm 10:09 PM

Java-Programme weisen unterschiedliche Zugriffsebenen auf

See all articles