5

別のクラス内の別のクラスから関数を呼び出すにはどうすればよいですか?

これが私の現在のコードです:

    <?php

    class database
    {
        private $host = "localhost";
        private $user = "root";
        private $password = "";
        private $db = "9dot";

        //connect to database
        public function connect()
        {
            $connect =  mysql_connect($this->host,$this->user,$this->password);
            $database = mysql_select_db($this->db,$connect);

        }



        //Get exam headers
        public function GetExam()
        {
            $this->connect();
            $select = "SELECT e.ExamHeaderID, CONCAT(e.Firstname,' ',e.Lastname) AS Fullname e.Age, e.Position, e.Date FROM examheader e";
            $result = mysql_query($select);
            $table = "";
            $table .= "<th>ExamID</th>";
            $table .= "<th>Name</th>";
            $table .= "<th>Age</th>";
            $table .= "<th>Position</th>";
            $table .= "<th>Date</th>";

            $exam_id = "";
            $fullname = "";
            $age = "";
            $position = "";
            $date = "";
            while($row = mysql_fetch_array($select))
            {
                $exam_id = mysql_real_escape_string($row['ExamHeaderID']);
                $fullname = mysql_real_escape_string($row['Fullname']);
                $age = mysql_real_escape_string($row['Age']);
                $position = mysql_real_escape_string($row['Position']);
                $date = mysql_real_escape_string($row['Date']);
            }

        }

        public function GetExamDetails($ExamID)
        {
            $this->connect();
            //$select = "SELECT ed.ExamDetailsID, ed.";
        }


        //Save Exam header
        public function SaveExam($firstname,$lastname, $age, $position)
        {
            $this->connect();
            $date = date("m/d/Y");
            mysql_real_escape_string($firstname);
            mysql_real_escape_string($lastname);
            mysql_real_escape_string($age);
            mysql_real_escape_string($position);
            $insert = "INSERT INTO examheader (Firstname,Lastname, Age, Position, Date) VALUES ('$firstname','$lastname','$age','$position')";
            $result = mysql_query($insert);
            $exam_id = mysql_insert_id();
            //return exam id for insertion of exam details
            return $exam_id;

        }

        public function SaveExamAnswer()
        {


        }



    }

?>





<?php

include 'database.php';
$database = new $database();

class department
{
    $database->//property or function
}



?>

データベース クラスから関数を呼び出す方法

4

6 に答える 6

8

以下のように、部門クラスでデータベースのインスタンスを宣言できます。

class department
{
    public function __construct() 
    {
        $database = new database();
        $database->someFunction();
    }
}

部門クラスに直接入れたくない場合はglobal、次のように、必要なファイルが含まれていると仮定して、システムを使用して宣言できます。

include 'database.php'

$database = new database();

class department
{
    public function __construct() 
    {
        global $database;
        $database->someFunction();
    }
}

PHP: 変数のスコープを参照してください。

于 2012-06-27T16:07:37.890 に答える
3

それらを拡張できます。

class department extends database {
    function test() {
        $this->getdbfunction();
    }
}

または、コンストラクターでそれらを渡します。

class department {
    private $db;

    public function __construct(Database db) {
        $this->db = $db
    }
}

$department = new department($database);
于 2012-06-27T16:03:38.987 に答える
2

最初のクラスのインスタンスである属性を定義し、2 番目のクラスの例で定義された属性にメソッドを適用できます。

class A {
function a () {
}
...
}

class B {
$attClassA;
function __construct(A objA) {
$this->attClassA = objA;
}
// you can use the attClassA in any class you want and then apply the chosen method
...
}
于 2012-06-27T16:05:35.577 に答える
1

タイプ「データベース」のオブジェクトを作成し、それを使用してメソッドを呼び出します。

$database = new database();
$connection = $database->connect();
于 2012-06-27T16:03:47.060 に答える
1

このようなことを試してください(大まかな例):

<?php

include 'database.php';


class department
{

    public function doSomething() {
       $database = new $database();
       $val = $database->GetExam();
       //do something
    }
}

?>
于 2012-06-27T16:01:53.317 に答える