• 技术文章 >后端开发 >php教程

    如何通过php 进行ID前缀格式化类

    jacklovejacklove2018-06-20 18:01:20原创1186
    数据库表通常都会有一个字段类型为int,命名为id的自增主键。

    优点:使用int类型可自增,且比字符类型节省存储空间。
    缺点:id是数值型,当要查询一个id对应的数据时,很难根据id判断是哪一个数据表。

    因此我们在存储时,应使用int,而在显示时对id进行一些处理,使很容易分辨这个id属于哪一个表。

    编写了下面这个类,实现对id增加前缀及对已加前缀的id还原。

    Prefix.class.php

    <?php/**
     * ID前缀格式化类
     * Date:    2016-10-27
     * Author:  fdipzone
     * Ver:     1.0
     *
     * Func
     * public getPrefixId    生成已加前缀的id
     * public getId          还原为id
     * public getPrefixType  根据已加前缀id获取前缀类型
     */class Prefix{ // class start
    
        // 定义前缀常量
        const USER_TYPE = 'user';       // 用户
        const ORDER_TYPE = 'order';     // 订单
        const MESSAGE_TYPE = 'message'; // 消息
    
        // 前缀设定
        private static $prefix = array(        self::USER_TYPE => 'U',        self::ORDER_TYPE => 'O',        self::MESSAGE_TYPE => 'M'
        );    /**
         * 创建带前缀的id
         * @param  Int     $id          id
         * @param  Int     $prefix_type 类型
         * @return String
         */
        public static function getPrefixId($id, $prefix_type=''){
            // 有自定义前缀类型
            if(isset(self::$prefix[$prefix_type])){            return self::$prefix[$prefix_type].$id;
            }        // 没有自定义前缀类型
            return $id;
        }    /**
         * 还原为id
         * @param  String $prefix_id 已加前缀id 
         * @return Int
         */
        public static function getId($prefix_id){
            preg_match('/\d+/', $prefix_id, $arr);        if(isset($arr[0])){            return $arr[0];
            }        return 0;
        }    /**
         * 根据已加前缀id获取前缀类型
         * @param  String $prefix_id 已加前缀id 
         * @return Int
         */
        public static function getPrefixType($prefix_id){
    
            // 获取id前缀
            preg_match('/[A-Za-z]+/', $prefix_id, $arr);        if(isset($arr[0])){            $prefix = $arr[0];            // 获取前缀
                $prefixs = array_flip(self::$prefix);            if(isset($prefixs[$prefix])){                return $prefixs[$prefix];
                }
            }        return '';
        }
    
    } // class end?>

    demo.php

    <?phprequire 'Prefix.class.php';// 原始id$user_id = 1001;$order_id = 2016102743765214;$message_id = 109283;echo '<pre>';// 已加前缀idecho '1.id加前缀'.PHP_EOL;$prefix_user_id = Prefix::getPrefixId($user_id, Prefix::USER_TYPE);$prefix_order_id = Prefix::getPrefixId($order_id, Prefix::ORDER_TYPE);$prefix_message_id = Prefix::getPRefixId($message_id, Prefix::MESSAGE_TYPE);echo $prefix_user_id.PHP_EOL;echo $prefix_order_id.PHP_EOL;echo $prefix_message_id.PHP_EOL.PHP_EOL;// 前缀类型echo '2.根据已加前缀id获取前缀类型'.PHP_EOL;echo Prefix::getPrefixType($prefix_user_id).PHP_EOL;echo Prefix::getPrefixType($prefix_order_id).PHP_EOL;echo Prefix::getPrefixType($prefix_message_id).PHP_EOL.PHP_EOL;// 还原为原始idecho '3.还原为原始id'.PHP_EOL;echo Prefix::getId($prefix_user_id).PHP_EOL;echo Prefix::getId($prefix_order_id).PHP_EOL;echo Prefix::getId($prefix_message_id).PHP_EOL.PHP_EOL;echo '</pre>';?>

    输出:

    1.id加前缀
    U1001
    O2016102743765214
    M1092832.根据已加前缀id获取前缀类型
    user
    order
    message3.还原为原始id10012016102743765214109283

    自定义的前缀常量,可以根据需求自行创建。

    本文讲解了如何通过php 进行ID前缀格式化类,更多相关内容请关注php中文网。

    相关推荐:

    如何通过php 将print_r处理后的数据还原为原始数组的方法

    通过php中的PDO判断连接是否可用的方法

    通过php 判断页面或图片是否经过gzip压缩

    php入门到就业线上直播课:查看学习

    以上就是如何通过php 进行ID前缀格式化类的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    快捷开发Web应用及小程序:点击使用

    支持亿级表,高并发,自动生成可视化后台。

    专题推荐:php 数据库
    上一篇:如何通过php 将print_r处理后的数据还原为原始数组的方法 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• 浅析PHP8.0特性:Named Parameter(命名参数)• 手把手教你用PHP快速连接SqlServer• 不用数据库的多用户文件自由上传投票系统(2)_PHP教程• 一个分页的论坛_php基础• PHP的Yii框架的基本使用示例_PHP
    1/1

    PHP中文网