-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpdo_prepare.php
35 lines (32 loc) · 1.07 KB
/
pdo_prepare.php
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<?php
include("./pdo_connect.php");
$sql = "SELECT * FROM `a` WHERE id = :id";
$pdo->setAttribute(PDO::ATTR_EMULATE_PREPARES,true); //开启在本地模拟prepare
$pdoStatement = $pdo->prepare($sql);
$data = 1;
$pdoStatement->bindValue(":id", $data, paramType($data));
$pdoStatement->execute();
var_dump($pdoStatement->fetchAll(PDO::FETCH_ASSOC));
$pdoStatement = $pdo->prepare($sql);
$pdoStatement->bindParam(":id", $data, paramType($data));
$data = 2;
$pdoStatement->execute();
var_dump($pdoStatement->fetchAll(PDO::FETCH_ASSOC));
$name = mt_rand(0,10);
$pdoStatement = $pdo->prepare("UPDATE a SET name= '{$name}' WHERE id=:id");
$pdoStatement->bindParam(":id", $id,1);
$id = 1;
$pdoStatement->execute();
var_dump($pdoStatement->rowCount());
function paramType($data){
$typeMap = [
// php type => PDO type
'boolean' => \PDO::PARAM_BOOL,
'integer' => \PDO::PARAM_INT,
'string' => \PDO::PARAM_STR,
'resource' => \PDO::PARAM_LOB,
'NULL' => \PDO::PARAM_NULL,
];
$type = gettype($data);
return isset($typeMap[$type]) ? $typeMap[$type] : \PDO::PARAM_STR;
}