初识通用数据库操作类――前端easyui-datagrid,form(php)


Posted in PHP onJuly 31, 2015

初识通用数据库操作类——前端easyui-datagrid,form(php),实现代码比较简单,具体实现步骤请看下文。

实现功能:

    左端datagrid显示简略信息,右侧显示选中行详细信息,数据库增删改

(1)点击选中行,右侧显示详细信息,其中【新增】、【修改】、【删除】按钮可用,【保存】按钮禁用

(2)点击【新增】按钮,【修改】,【删除】按钮禁用,【保存】按钮启用

(3)点击【修改】按钮,【新增】,【删除】按钮禁用

难点:通用数据库操作类中insert方法跟update方法

最终效果图:

前端功能不是很完善,按钮之间逻辑还是有点问题,最后补充前端代码

其中Formain.php对前端传值判断,并调用actSQL.class.php获得结果

代码比较简单

如下:

<?php
  require('include/mysql_connect/actSQL.class.php');
  $key=$_REQUEST['key'];
  $a=new actSQL('localhost','root','1234','tpss');
  //获取信息
  if($key=='1')
  {
   $a->getAllData('t_prekeychart');
  }
  if($key=='2')
  { 
   $objectstr=$_REQUEST['object'];   
   if($a->insertData($objectstr,'t_prekeychart'))
   {
    echo json_encode("true");
   }else{
    echo json_encode("false");
   }
   //test
   //$test='{"keychartid":"2","keyid":"2","keychartname":"2","level":"2","showtype":"2","helptips":"2","keylevel":"2","ishmap":"2"}';
   //$a->insertData($test,'t_prekeychart');
  }
  if($key=='3')
  { 
   $prekey=$_REQUEST['keychartid'];
   $prekeyname='keychartname';
   if($a->delData($prekey,$prekeyname,'t_prekeychart'))
   {
    echo json_encode("true");
   }else{
    echo json_encode("false");
   }
  }
  if($key=='4')
  {
   $objectstr=$_REQUEST['object'];
   $prekeyname='keychartid';
   if($a->updData($objectstr,$prekeyname,'t_prekeychart'))
   {
    echo json_encode("true");
   }else{
    echo json_encode("false");
   }
  }
?>

看Formain.php中出现的类的各个方法,简单思考一下

其中

getAllData($tablename)获取表格的所有信息,这个方法比较简单,一个简单的sql语句就可以搞定,最后将结果json格式返回即可

delData($prekey,$prekeyname,$tablename)删除指定信息,这个更简单,就不说了

insertData( $objectstr,$tablename ) ,其中$objectstr是json格式的字符串,$tablename表名,

难点是将拼凑成 insert into $tablename (......) values(.....) 这种语句

解决办法:

(1)根据$tablename获取所有的列名,并将列名数组转换为字符串,为最后sql语句的拼凑做准备,除此获取列名还有个目的,往下看

(2)将json格式的字符串$objectstr转换为关联数组,调用json_decode() 方法

补充json_decode()方法

mixed json_decode ( string $json [, bool $assoc = false [, int $depth = 512 [, int $options = 0 ]]] )
接受一个 JSON 格式的字符串并且把它转换为 PHP 变量,其中assoc,当该参数为  TRUE   时,将返回 关联数组    。

(3)按 照查询到的列名顺序查询数据,数据为空时,赋值为NULL , 将结果存到数组,防止数据库插入数值错位(获取列名的另个原因)

(4)将(3)的结果转化为字符串,调用implode()方法

补充implode()方法:

string implode(string glue, array pieces);
本函数将数组的内容组合成一个字符串,参数 glue 是字之间的分隔符号

(5)拼凑sql语句字符串,然后向数据库插入

updData($objstr,$prekeyname,$tablename)方法难点也是在于sql语句的字符串拼凑,拼凑格式应该如下

update $tablename set ..... where $prekeyname=$data[$prekeyname]

前两步同insertData()

(3)遍历列名字符数组,获取非主键名的列名值,按照  “列名=列名值”  的字符串格式存入数组 ,这里就是set 后面部分的不完全字符串

(4)将(3)结果转换为字符串,将数组元素以   ','   分隔开,这个就是set后面最后的字符串 格式为“xx=xx,xx=xx”

(5)拼凑sql字符串,然后更新数据库

insertData()以及updData()函数如下

/*
   * 添加信息
   * @param:$objstr:json风格的数据库插入信息字符串
   *   $tablename:表名
   */
  function insertData($objstr,$tablename)
  {
    $dbc=$this->conData();
    if($dbc)
    { 
     $columnname=array();
     $columnname=$this->getColumns($tablename);
     //echo $columnname[0];
     $clos=implode(',',$columnname); //将列名数组转换为字符串
     //echo $clos;
     $data=json_decode($objstr,true); //将json格式的字符串转换为关联数组
     //echo $value['keychartname'];
     $values=array();
     foreach($columnname as $value)
     {
       //按照查询到的列名查询数据,数据为空的,赋值为NULL,防止数据库插入数值错位
       //echo $data[$value]."<br>";
       if(isset($data[$value]))
       {
         array_push($values,$data[$value]);
       }else{
        $data[$value]=NULL;
        array_push($value,$data[$value]);
       }
     }
     $strvalue=implode(',',$values);
     //echo $strvalue;
     /*
     * SQL: insert into $tablename($clos) values(...)
     */
     $sql=<<<SQL
     insert into $tablename($clos) values($strvalue);
SQL;
     //echo $sql;
     $res=mysqli_query($dbc,$sql);
     if($res)
     {
      return true;
     }else{
       return false;
     }
    }else{
      echo "连接错误!";
    } 
  }
/*
   *更新信息 
   *@param: $objstr:json风格的数据库更新信息字符串
   *   $tablename:表名
   *   $prekeyname:主键名  
   * */
  function updData($objstr,$prekeyname,$tablename)
  {
    $dbc=$this->conData();
    if($dbc)
    {
     $columnname=array();
     $columnname=$this->getColumns($tablename); 
     //$clos=implode(',',$columnname); //将列名数组转换为字符串
     $data=json_decode($objstr,true); //将json格式的字符串转换为关联数组
     $sets=array();
     foreach($columnname as $value)
     { 
      //列名不等于主键名获取值
      if($prekeyname!=$value)
      {
        //set $value=$data[$value];
        array_push($sets,"$value=$data[$value]");//接好的set语句部分
      }
     }
     //$sets数组转化为字符串
     $stringsets=implode(',',$sets);
     //echo $stringsets;
     /*
     * SQL:update $tablename set ..... where $prekeyname=$data[$prekeyname]; 
     * */
     $sql=<<<SQL
      update $tablename set $stringsets where $prekeyname=$data[$prekeyname];
SQL;
     $res=mysqli_query($dbc,$sql);
     if($res)
     {
      return true;
     }else{
      return false;
     }
    }else{
      echo "连接错误";
    }
  }
/*
   *获取表的所有列名
   *@param:$tablename:表名
   */
  function getColumns($tablename)
  { 
   $dbc=@mysqli_connect('localhost','root','1234','information_schema');
   if(!$dbc)
   {
    echo "Connect Error".mysqli_connect_error($dbc);
   }else
   {
    //连接成功,从表COLUMNS获取表的所有列名
    $sql="select COLUMN_NAME from columns where TABLE_NAME='$tablename'";
    $res=@mysqli_query($dbc,$sql);
    $items=array();
    if($res)
    {
     while($row=mysqli_fetch_array($res,MYSQLI_ASSOC))
     {
      $columnname=$row['COLUMN_NAME'];
      array_push($items,$columnname);
     }
    return $items;
    mysqli_close($dbc);
    }
    else{
     echo "查询失败,请检查SQL语句!";
     }
   }
  }

以上就是本文全部内容,希望大家喜欢。

PHP 相关文章推荐
PHP版国家代码、缩写查询函数代码
Aug 14 PHP
PHP中替换换行符的几种方法小结
Oct 15 PHP
对象失去焦点时自己动提交数据的实现代码
Nov 06 PHP
php字符编码转换之gb2312转为utf8
Oct 28 PHP
小谈php正则提取图片地址
Mar 27 PHP
PHP图片裁剪函数(保持图像不变形)
May 04 PHP
CI框架中libraries,helpers,hooks文件夹详细说明
Jun 10 PHP
yii2.0之GridView自定义按钮和链接用法
Dec 15 PHP
smarty模板判断数组为空的方法
Jun 10 PHP
php实现遍历多维数组的方法
Nov 25 PHP
完美解决phpexcel导出到xls文件出现乱码的问题
Oct 29 PHP
PHP实现的只保留字符串首尾字符功能示例【隐藏部分字符串】
Mar 11 PHP
使用Appcan客户端自动更新PHP版本号(全)
Jul 31 #PHP
php使用Imagick生成图片的方法
Jul 31 #PHP
如何使用Gitblog和Markdown建自己的博客
Jul 31 #PHP
php自定义类fsocket模拟post或get请求的方法
Jul 31 #PHP
详解Grunt插件之LiveReload实现页面自动刷新(两种方案)
Jul 31 #PHP
PHP中filter函数校验数据的方法详解
Jul 31 #PHP
PHP代码实现爬虫记录――超管用
Jul 31 #PHP
You might like
fleaphp常用方法分页之Pager使用方法
2011/04/23 PHP
shopex中集成的站长统计功能的代码简单分析
2011/08/11 PHP
php setcookie(name, value, expires, path, domain, secure) 参数详解
2013/06/28 PHP
PHP 类与构造函数解析
2017/02/06 PHP
js资料prototype 属性
2007/03/13 Javascript
jquery 打开窗口返回值实现代码
2010/03/04 Javascript
date.parse在IE和FF中的区别
2010/07/29 Javascript
firefox下frameset取不到值的解决方法
2010/09/06 Javascript
jQuery :nth-child前有无空格的区别分析
2011/07/11 Javascript
可选择和输入的下拉列表框示例
2013/11/05 Javascript
浅谈jquery.fn.extend与jquery.extend区别
2015/07/13 Javascript
JavaScript制作淘宝星级评分效果的思路
2020/06/23 Javascript
js删除数组元素、清空数组的简单方法(必看)
2016/07/27 Javascript
Vue.js中数组变动的检测详解
2016/10/12 Javascript
AngularJS基于http请求实现下载php生成的excel文件功能示例
2018/01/23 Javascript
详解从买域名到使用pm2部署node.js项目全过程
2018/03/07 Javascript
深入浅析vue全局环境变量和模式
2020/04/28 Javascript
[06:20]2015国际邀请赛第三日top10
2015/08/08 DOTA
Python找出list中最常出现元素的方法
2016/06/14 Python
Python多进程multiprocessing用法实例分析
2017/08/18 Python
基于anaconda下强大的conda命令介绍
2018/06/11 Python
python对于requests的封装方法详解
2019/01/03 Python
详解如何设置Python环境变量?
2019/05/13 Python
使用Python在Windows下获取USB PID&amp;VID的方法
2019/07/02 Python
Python3读写ini配置文件的示例
2020/11/06 Python
北京泡泡网网络有限公司.net面试题
2012/07/17 面试题
银行会计职员个人的自我评价
2013/09/29 职场文书
师范生实习的个人自我鉴定
2013/10/20 职场文书
师范生自我鉴定
2014/03/20 职场文书
小学生放飞梦想演讲稿
2014/08/26 职场文书
安全生产月宣传标语
2014/10/06 职场文书
法人身份证明书
2014/10/08 职场文书
2014年科技工作总结
2014/11/26 职场文书
授权协议书范本(3篇)
2019/10/15 职场文书
Python批量将csv文件转化成xml文件的实例
2021/05/10 Python
聊聊基于pytorch实现Resnet对本地数据集的训练问题
2022/03/25 Python