sql >> Databasteknik >  >> RDS >> Mysql

Förberedt uttalande som inte låter mig ringa $mysqli->stmt_init()

public function site_db()
{
    // Connect to MySQL 
    $mysqli = mysqli_connect(SITE_HOST, SITE_ID, SITE_PW, SITE_DB); 

    // Check for Errors 
    if(mysqli_connect_errno()) 
    { 
        //echo mysqli_connect_error(); //shouldnt show client specific error information. 
        die('Error connecting to mysql database please report.'); 
    }

     return $mysqli;
}


public function exists (Mysqli $mysqli, $what, $who)
{

    $query = "SELECT * FROM users WHERE ? = ?";

    // Get instance of statement 
    $stmt = $mysqli->stmt_init();

    // Prepare query 
    if($stmt->prepare($query)) 
    { 
        // Bind Parameters 
        $stmt->bind_param("ss", $what, $who); 

        // Execute statement 
        $stmt->execute(); 

        // Bind result variables 
        $stmt->bind_result($result); 

        // Fetch Value 
        $stmt->fetch(); 

        // catch num_rows result as variable
        $username_result = $result->num_rows;

        // Close Statement 
        $stmt->close();
    }

    if ($username_result != 0)
    {
        return true;
        echo 'true';
    }
    else
    {
        return false;
        echo 'false';
    }
}

Hur man använder:

Instantiera första klass som har metoden site_db()

$db = new Class();

Instantiera sedan andra klass som har exist()-metoden

$query = new Class();

Sedan helt enkelt

$query->exist($db->site_db(), $what, $who );


  1. Hur man krypterar en vy i SQL Server

  2. Hur förhindrar man att max_user_connections överskrids vid omladdning/uppdatering av sidan flera gånger?

  3. VÄLJ Från MySQL-vy med HAVING-sats Returnerar tom resultatuppsättning

  4. Hur fyller man i databasen bara en gång före @Test-metoder i vårtestet?