博主信息
博文 24
粉丝 0
评论 0
访问量 20636
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
MySQLi与PDO操作数据库-2018年8月30日
鱼越龙门的博客
原创
828人浏览过

今天学习了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()函数来获取结果集记录数量

批改状态:合格

老师批语:
本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系admin@php.cn举报处理!
全部评论 文明上网理性发言,请遵守新闻评论服务协议
0条评论
作者最新博文
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号

  • 登录PHP中文网,和优秀的人一起学习!
    全站2000+教程免费学