php中实现用数组妩媚地生成要执行的sql语句

 更新时间:2015年07月10日 09:57:40   投稿:junjie  
这篇文章主要介绍了php中实现用数组妩媚地生成要执行的sql语句,本文直接给出代码示例,需要的朋友可以参考下

 会不会碰到这样一种情况呢?每次获取数据将数据和历史版本都有一定的差别,然而用ThinkPHP的addAll()函数,却会将已有的数据删掉再重新写入。这明显不是我们想要的。但自己写sql每次几十个字段也是醉了。如何优雅而又轻松地实现sql的自动生成呢?于是有了下面这个方法。

/**
   * [array_to_sql 根据数组key和value拼接成需要的sql]
   * @param [type] $array  [key, value结构数组]
   * @param string $type  [sql类型insert,update]
   * @param array $exclude [排除的字段]
   * @return [string]     [返回拼接好的sql]
   */
  function array_to_sql($array, $type='insert', $exclude = array()){
    
    $sql = '';
    if(count($array) > 0){
      foreach ($exclude as $exkey) {
        unset($array[$exkey]);//剔除不要的key
      }

      if('insert' == $type){
        $keys = array_keys($array);
        $values = array_values($array);
        $col = implode("`, `", $keys);
        $val = implode("', '", $values);
        $sql = "(`$col`) values('$val')";
      }else if('update' == $type){
        $tempsql = '';
        $temparr = array();
        foreach ($array as $key => $value) {
          $tempsql = "'$key' = '$value'";
          $temparr[] = $tempsql;
        }

        $sql = implode(",", $temparr);
      }
    }
    return $sql;
  }

当然,这个方法还有很多可以斟酌的地方。能用,但不是最好的。园子的猿猿们你们有更好的方法吗?请告诉我吧!

相关文章

  • PHP编写RESTful接口

    PHP编写RESTful接口

    本文给大家分享的是使用PHP编写的RESTful接口的方法和简单示例,有需要的小伙伴可以参考下。
    2016-02-02
  • PHP输入输出流学习笔记

    PHP输入输出流学习笔记

    这篇文章主要介绍了PHP输入输出流学习笔记,PHP输入和输出流是通过php://来访问的,它允许访问 PHP 的输入输出流、标准输入输出和错误描述符,内存中、磁盘备份的临时文件流以及可以操作其他读取写入文件资源的过滤器,需要的朋友可以参考下
    2015-05-05
  • 三个思路解决laravel上传文件报错:413 Request Entity Too Large问题

    三个思路解决laravel上传文件报错:413 Request Entity Too Large问题

    上传图片的时候,是用laravel自带的上传图片的方法,一下气上传了20张,结果就无情报错:413 Request Entity Too Large,后面查一下,这个报错信息是nginx报的错误,不是php报的错误。也就是说在上传图片的时候被nginx拦截了
    2017-11-11
  • laravel框架实现为 Blade 模板引擎添加新文件扩展名操作示例

    laravel框架实现为 Blade 模板引擎添加新文件扩展名操作示例

    这篇文章主要介绍了laravel框架实现为 Blade 模板引擎添加新文件扩展名操作,结合实例形式详细分析了laravel框架Blade 模板引擎添加新文件扩展名具体操作步骤与相关实现技巧,需要的朋友可以参考下
    2020-01-01
  • php curl请求信息和返回信息设置代码实例

    php curl请求信息和返回信息设置代码实例

    这篇文章主要介绍了php curl请求信息和返回信息设置代码实例,本文直接给出代码实例,需要的朋友可以参考下
    2015-04-04
  • 百万级别知乎用户数据抓取与分析之PHP开发

    百万级别知乎用户数据抓取与分析之PHP开发

    这篇文章主要介绍了百万级别知乎用户数据抓取与分析之PHP开发的相关资料,需要的朋友可以参考下
    2015-09-09
  • 分享一段php获取linux服务器状态的代码

    分享一段php获取linux服务器状态的代码

    正在做的项目中,需要使用php获取Linux服务器状态,度娘了一下,发现绝大部分都是基于WIN系统的,好吧,自力更生,分享给大家一段Linux的代码
    2014-05-05
  • Laravel 解决419错误 -ajax请求错误的问题(CSRF验证)

    Laravel 解决419错误 -ajax请求错误的问题(CSRF验证)

    今天小编就为大家分享一篇Laravel 解决419错误 -ajax请求错误的问题(CSRF验证),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-10-10
  • Laravel Swagger 使用超详细教程

    Laravel Swagger 使用超详细教程

    Swagger 是一个基于 Open Api 规范的 API 管理工具,通过项目注解的形式自动构建 API 文档,拥有在线调试的功能,这篇文章主要介绍了Laravel Swagger 使用完整教程,需要的朋友可以参考下
    2023-09-09
  • php获取新浪微博数据API实例

    php获取新浪微博数据API实例

    要获取新浪微博的数据,可以通过他们提供的API,地址:http://open.weibo.com/wiki/API文档_V2,获取数据的方法如下:
    2013-11-11

最新评论