sql >> Database teknologi >  >> RDS >> Mysql

Forberedt erklæring, der ikke lader mig kalde $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';
    }
}

Sådan bruges:

Instantiér første klasse, der har site_db()-metoden

$db = new Class();

Instantiér derefter anden klasse, der har exist()-metoden

$query = new Class();

Så bare

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


  1. Sådan konfigurerer du MySQL til at være case-sensitive

  2. Importer hex/binære data til mysql

  3. Hvordan binder man parametre til en rå DB-forespørgsel i Laravel, der bruges på en model?

  4. Er en Load DATA uden en fil (dvs. i hukommelsen) mulig for MySQL og Java?