php ID前缀格式化类

企鹅博客
企鹅博客
企鹅博客
29008
文章
0
评论
2020年9月13日06:24:47 评论 5 views 4512字阅读15分2秒

数据库表通常都会有一个字段类型为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

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

源码下载地址:点击查看

数据库表通常都会有一个字段类型为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中文网(www.php.cn)!

继续阅读
weinxin
欢迎加入中国站长博客之家
本站的所有资源都会上传分享到博客之家,希望大家互相学习交流进步。
关于php header()函数的10篇文章推荐 php教程

关于php header()函数的10篇文章推荐

这篇文章主要介绍了PHP获取当前日期及本周一是几月几号的方法,涉及php时间戳、日期转换与运算相关操作技巧,需要的朋友可以参考下本文实例讲述了PHP获取当前日期及本周一是几月几号的方法。分享给大家供大...
总结关于表单input注意点 html教程

总结关于表单input注意点

本文了解HTML中让表单input等文本框为只读不可编辑的方法介绍有时候,我们希望表单中的文本框是只读的,让用户不能修改其中的信息,如使input text的内容,中国两个字不可以修改 有时候,我们希...
匿名

发表评论

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: