PHP自动验证MySql数据表字段

PHP自动验证MySql 数据表字段

变量自行替换,$this-> 自行删除

   

/**
     * 数据对比
     * @param type $param   数据
     * @param type $table   表名
     * @return boolean      false|需要数据
     */
    function data_contrast($param, $table) {
        //获取数据
        $columns = $this->mysql_columns($table);
        $data = array();
        foreach ($param as $key => $val) {
            foreach ($columns as $k => $v) {
                if ($v['column_name'] == $key) {
                    //是否允许为空
                    $strlen = strlen($val);
                    if ($v['null_able'] == 'NO' && $strlen == 0) {
                        return false;
                    }
                    //判断数据类型
                    switch ($v['data_type']) {
                        case 'int':
                            if ($val + 1 - 1 != $val)
                                return false;
                            break;
                        case 'tinyint':
                            if ($strlen > $v['num_length'])
                                return false;
                        default:break;
                    }

                    $columns[$k] = null;
                    unset($columns[$k]);
                    $data[$key] = $val;
                    $param[$key] = null;
                    unset($param[$key]);
                }
            }
        }
        foreach ($columns as $key => $val) {
            if ($val['null_able'] == 'NO' && $val['column_name'] != 'id') {
                return false;
            }
            if ($val['column_name'] == 'id') {
                $data['addtime'] = time();
                $data['uptime'] = time();
            }
        }
        if (!empty($data['id']))
            $data['uptime'] = time();

        return $data;
    }

    /**
     * 获取数据库某个结构
     * @param type $table       表名
     * @param type $database    数据库名称
     * @param type $prefix      表前缀
     * @return type             表结构
     */
    function mysql_columns($table, $database = '', $prefix = '') {
        empty($database) and $database = config('database.database');
        empty($prefix) and $prefix = config('database.prefix');
        if (empty($table))
            return [];
        $sql = "SELECT TABLE_NAME AS 'table_name',COLUMN_NAME AS 'column_name',"
                . "COLUMN_COMMENT AS 'column_comment',IS_NULLABLE AS 'null_able',"
                . "DATA_TYPE AS 'data_type',CHARACTER_MAXIMUM_LENGTH AS 'str_length',"
                . "NUMERIC_PRECISION AS 'num_length',NUMERIC_SCALE AS 'num_bit' "
                . "FROM information_schema.`COLUMNS` " . "WHERE TABLE_SCHEMA = '" . $database
                . "'AND TABLE_NAME = '" . $prefix . $table . "' "
                . "  ORDER BY      TABLE_NAME,  ORDINAL_POSITION;";
        $columns = Db::query($sql);
        return $columns;
    }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值