批改状态:合格
老师批语:
今天学习了Mysqli和PDO操作数据库的知识
代码:
<?php
require 'demo1.php';
$sql="select staff_id,name,salary from staff where salary>?";
$stmt=$mysqli->stmt_init();
if($stmt->prepare($sql)){
$stmt->bind_param('i',$salary);
$salary=5000;
if($stmt->execute()) {
$stmt->store_result();
$stmt->bind_result($id, $name, $salary);
if ($stmt->num_rows > 0) {
while ($stmt->fetch()) {
echo '<p>id:' . $id . '---姓名:' . $name . '---工资:' . $salary . '</p>';
}
} else {
exit('<p>当前表中没有数据</p>');
}
$stmt->free_result();
}else {
exit($stmt->errno. ': ' . $stmt->error);
}
} else {
exit($stmt->errno. ': ' . $stmt->error);
}
$stmt->close();
$mysqli->close();点击 "运行实例" 按钮查看在线实例
PDO 的优势
有了PDO,您不必再使用mysql_*函数,oci_*函数或者mssql_*函数,也不必再为它们封闭数据库操作类,只需要使用PDO接口中的方法就可以对数据库进行操作,在选择不同的数据库时,只修改PDO的DSN即可. PDO比以往的数据库自带函数库比,安全系数更高,有效的可以防止SQL注入!
代码:
<?php
$dsn="mysql:host=127.0.0.1;dbname=php";
$user='root';
$pwd='root';
try{
$pdo=new PDO($dsn,$user,$pwd);
}catch (PDOException $e){
die('Connnect ERROR!:'.$e->getMessage());
}点击 "运行实例" 按钮查看在线实例
<?php
$pdo = new PDO('mysql:host=127.0.0.1;dbname=php','root','root');
$sql="insert into user set user_name=:name,email=:email,password=sha1(:password)";
$stmt=$pdo->prepare($sql);
$data=['name'=>'杨过','email'=>'yg@php.cn','password'=>'123'];
$stmt->bindParam(':name',$data['name'],PDO::PARAM_STR);
$stmt->bindParam(':email',$data['email'],PDO::PARAM_STR);
$stmt->bindParam(':password',$data['password'],PDO::PARAM_STR);
if($stmt->execute()){
echo '成功添加了'.$stmt->rowCount().'条记录';
}else{
echo '添加失败';
print_r($stmt->errorInfo());
exit();
}
$stmt = null;
$pdo = null;点击 "运行实例" 按钮查看在线实例
<?php
$pdo=new PDO('mysql:host=127.0.0.1;dbname=php','root','root');
$sql="update user set email=:email where user_id=:id";
$stmt=$pdo->prepare($sql);
$stmt->execute(['email'=>'yzf@qq.com','id'=>'3']);
echo '<h3>成功更新了'.$stmt->rowCount().'条记录</h3>';
$stmt=null;
$pdo=null;点击 "运行实例" 按钮查看在线实例
<?php
$pdo=new PDO('mysql:host=127.0.0.1;dbname=php','root','root');
$sql="delete from user where user_id=:id";
$stmt=$pdo->prepare($sql);
if($stmt->execute(['id'=>'3'])){
echo '<h3>成功删除了'.$stmt->rowCount().'条记录</h3>';
}else{
echo '<h3>无删除</h3>';
print_r($stmt->errorInfo());
exit();
}
$stmt=null;
$pdo=null;点击 "运行实例" 按钮查看在线实例
<?php
$pdo=new PDO('mysql:host=127.0.0.1;dbname=php','root','root');
$sql="select user_name,email from user where user_id<:id";
$stmt=$pdo->prepare($sql);
$stmt->execute(['id'=>'4']);
while($row=$stmt->fetch(PDO::FETCH_ASSOC)){
echo var_export($row),'<br>';
}点击 "运行实例" 按钮查看在线实例
获取结果集记录数量的正确方式是什么
用count()函数来获取结果集记录数量
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号