php 鏈接mysql(查詢 增刪改)

一、鏈接數據庫方法:php

<?php
//方法1
$mysqli = new mysqli("localhost", "root", "root", "easyadmin");
if (!$mysqli) {
echo "database error";
} else {
echo "php env successful";
}
$mysqli->close();

//方法2
try {
$dbh = new PDO('mysql:host=localhost;dbname=easyadmin', 'root', 'root', array(PDO::ATTR_PERSISTENT => true)); //持久性鏈接
$dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);
$dbh->exec('SET CHARACTER SET utf8');
echo "鏈接成功";
echo "<br/>";
/* 1.斷開鏈接*/
//$dbh = null;
$name = 'kevin2%';
/* 2.查詢:sql語句中user與name不能是單引號‘’,是左上角的波浪線~,sql語句之外的能夠是單引號,不然查詢語句會報錯*/
$sql = "select * from `user` where `name` like :name";
$stmt = $dbh->prepare($sql);
$stmt->execute(array(':name' => $name));
while ($row = $stmt->fetch(PDO::FETCH_ASSOC)) {
print_r($row);
echo("<br/>");
}
// /*3.添加*/
// $sql = "INSERT INTO `user` (`name` ,`password`)VALUES (:name, :password)";
// $stmt = $dbh->prepare($sql);
// $stmt->execute(array(':name' => 'kevin2', ':password' => '123459'));
// echo $dbh->lastInsertId();

/*4.刪除*/
$name = "zj";
$sql = "delete from `user` where `name` like :name";
$stmt = $dbh->prepare($sql);
$stmt->execute(array(':name' => $name));
echo $stmt->rowCount();

/*5.修改*/
$id = 3;
$sql = "update `user` set `password`=:password where `id`=:id ";
$stmt = $dbh->prepare($sql);
$stmt->execute(array(':id' => $id, ':password' => 'testabc'));
echo "Update:" . $stmt->rowCount();


} catch (PDOException $ex) {
print"Error!:" . $ex->getMessage() . "<br/>";
die();
}


?>

2.參數綁定
舉例:
 $stmt = $dbh->prepare($sql);    
 $stmt->bindParam(':country', $country, PDO::PARAM_STR);    
 $stmt->execute();   

 

3.事務mysql

  try {  
    $dbh = new PDO('mysql:host=localhost;dbname=test', 'root', 'root');  
    $dbh->query('set names utf8;');  
    $dbh->setAttribute(PDO::ATTR_ERRMODE, PDO::ERRMODE_EXCEPTION);  
    $dbh->beginTransaction();  
    $dbh->exec("Insert INTO `test`.`table` (`name` ,`age`)VALUES ('mick', 22);");  
    $dbh->exec("Insert INTO `test`.`table` (`name` ,`age`)VALUES ('lily', 29);"); 
    $dbh->exec("Insert INTO `test`.`table` (`name` ,`age`)VALUES ('susan', 21);");  
    $dbh->commit(); 
 } catch (Exception $e) {  
    $dbh->rollBack();  
    echo "Failed: " . $e->getMessage();  
 } sql

 

4.foreach語句數據庫

<?php
$dbh->query($sql); 當$sql 中變量能夠用$dbh->quote($params); //轉義字符串的數據
$sql = 'Select * from city where CountryCode ='.$dbh->quote($country);  //引用
foreach ($dbh->query($sql) as $row)   {    
 print $row['Name'] . "/t";    
 print $row['CountryCode'] . "/t";    
 print $row['Population'] . "/n"; 

?>fetch

相關文章
相關標籤/搜索