sql >> Databáze >  >> RDS >> Mysql

Připravené prohlášení, které mi nedovoluje zavolat $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';
    }
}

Jak používat:

Vytvořte instanci první třídy, která má metodu site_db()

$db = new Class();

Poté vytvořte instanci druhé třídy, která má metodu exist()

$query = new Class();

Pak jednoduše

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


  1. Aktualizujte sloupec v databázi, kde je maximální hodnota php mysql

  2. Optimalizujte dotaz mysql pro použití indexu na klauzuli Bitwise where

  3. Výukový program připojení SQL

  4. Hostování MySQL v Azure, plně spravovaná cloudová databázová služba se spouští na ScaleGrid