博主信息
博文 13
粉丝 1
评论 0
访问量 10818
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
20190321-php基础之PDO封装增删改查函数
蛋炒饭的博客
原创
971人浏览过

实例

用刚学到的PDO知识封装增删改查函数,可以传入参数

<?php
/**
 * @Author: Marte
 * @Date:   2019-03-22 11:42:48
 * @Last Modified by:   Marte
 * @Last Modified time: 2019-03-22 22:49:53
 */
function con(){
    $sql = 'mysql';
    $host = '127.0.0.1';
    $dbName = 'test';
    $user = 'sunliang';
    $psw = '123456';

    try{
        $pdo = new PDO("$sql:host=$host;dbname=$dbName",$user,$psw);
    }catch(PDOException $e){
        echo 'connect error: '.$e->getMessage();
    }
    return $pdo;
}

/**
 *数据查找函数 selectAll()
 *$table str 要查找的表名
 *$field str 要查找的字段,默认全部查找
 *$where str 要查找的条件
 *$order str 排序
 *$limit str 需要查找的条数
 */

function selectAll($table,$field='*',$where="",$order="",$limit=''){
    //链接数据库
    $pdo = con();
    //组合sql语句
    //$sql  = 'select * from user where age > 20 order by id desc limit 1';
    $sql = 'select ';

    //如果字段不为空,执行
    if(!empty($field)){
        $sql .= trim($field);
    }
    //如果数据表不为空
    if(!empty($table)){
       $sql .= ' from ';
       $sql .= $table;
    }
    //如果条件不为空
    if(!empty($where)){
      $sql .= ' where ';
      $sql .= $where;
    }
    //如果排序不为空
    if(!empty($order)){
        $sql .= ' order by ';
        $sql .= $order;
    }
    //如果limit不为空
    if(!empty($limit)){
        $sql .= ' limit ';
        $sql .= $limit;
    }
    //echo $sql.'<br/>';

    $stmt = $pdo->prepare($sql);

    if($stmt->execute()){
        if($stmt->rowCount()){
            $res = $stmt->fetchAll(PDO::FETCH_ASSOC);
            return $res;
        }else{
            return '没有查找到数据啊';
        }

    }else{
        return 'sql语句执行失败';
    }

}

//print_r(selectAll('user','id,name,age,address','age>20','id desc','3'));

/**
 *数据添加函数 adddata()
*$table str 要添加的表名
 *$field str 要添加的字段
 *$values str 要添加的字段值
 *return true或false
 */

function adddata($table,$field,$values){
    $pdo = con();
    $sql = "insert into ";

    //检查表名是否为空
    if(!empty($table)){
        $sql .= $table;
    }else{
        return '没有表名添加不了';
    }

    //检查字段名是否为空
    if(!empty($field)){
        $sql .= " ($field)";
    }else{
        return '字段名不能为空';
    }

    $sql .= " values ";

    //检查值是否为空
    if(!empty($values)){
        $sql .= " ($values) ";
    }else{
        return '值不能为空';
    }

    //echo $sql;exit;

    $stmt = $pdo->prepare($sql);
    if($stmt->execute()){
        if($stmt->rowCount()){
            return true;
        }else{
            return false;
        }
    }
}
//adddata('user','`name`,`password`,`age`,`email`,`birthday`,`salary`,`height`,`weight`,`address`,`hobby`,`job`',"'黎明','827ccb0eea8a706c4c34a16891f84e7b','48','234234@qq.com','474938751','50000','180','75','中国***','演戏','演员'");

/**
 *删除数据函数 adddata()
*$table str 要添加的表名
 *$field str 要添加的字段
 *$values str 要添加的字段值
 *return true或false
 */

function del($table,$where){
    $pdo = con();
    if(empty($table) or empty($where)){
        echo '表名和删除条件都不能为空';
        exit;
    }
    //$sql = 'delete from user where id = 1';
    $sql = "delete from ";
    $sql .= $table;
    $sql .=" where ";
    $sql .= $where;

    $stmt = $pdo->prepare($sql);
    if($stmt->execute()){
        if($stmt->rowCount()){
            return true;
        }else{
            return false;
        }
    }
}
//del('user','age>20');

/**
 *删除数据函数 adddata()
*$table str 要添加的表名
 *$field str 要添加的字段
 *$values str 要添加的字段值
 *return true或false
 */

function update($table,$data,$where){
    $pdo = con();
    if(empty($table) or empty($where)){
        echo '表名和删除条件都不能为空';
        exit;
    }
    //$sql = 'update user set name="刘德华",age="30",address="中国***" where id=1';
    $sql = "update ";
    $sql .= $table;
    $sql .=" set ";
    foreach($data as $k=>$v){
        $sql .= $k.'='.'"'.$v.'"'.',';
    }
    $sql = rtrim($sql,',');
    $sql .= " where ";
    $sql .= $where;
    //echo $sql;exit;

    $stmt = $pdo->prepare($sql);
    if($stmt->execute()){
        if($stmt->rowCount()){
            return true;
        }else{
            return false;
        }
    }
}

//update('user',['name'=>'刘德华1','age'=>45,'address'=>'中国***'],'id=1');

运行实例 »

点击 "运行实例" 按钮查看在线实例


批改状态:未批改

老师批语:
本博文版权归博主所有,转载请注明地址!如有侵权、违法,请联系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+教程免费学