> 백엔드 개발 > PHP 튜토리얼 > PHP ID 접두사 형식 지정 클래스

PHP ID 접두사 형식 지정 클래스

黄舟
풀어 주다: 2023-03-05 19:20:01
원래의
1567명이 탐색했습니다.


데이터베이스 테이블에는 일반적으로 필드 유형이 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 = &#39;user&#39;;       // 用户
    const ORDER_TYPE = &#39;order&#39;;     // 订单
    const MESSAGE_TYPE = &#39;message&#39;; // 消息

    // 前缀设定
    private static $prefix = array(        
    self::USER_TYPE => &#39;U&#39;,        
    self::ORDER_TYPE => &#39;O&#39;,        
    self::MESSAGE_TYPE => &#39;M&#39;
    );    
    /**
     * 创建带前缀的id
     * @param  Int     $id          id
     * @param  Int     $prefix_type 类型
     * @return String
     */
    public static function getPrefixId($id, $prefix_type=&#39;&#39;){
        // 有自定义前缀类型
        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(&#39;/\d+/&#39;, $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(&#39;/[A-Za-z]+/&#39;, $prefix_id, $arr);        
        if(isset($arr[0])){            
        $prefix = $arr[0];            
        // 获取前缀
            $prefixs = array_flip(self::$prefix);            
            if(isset($prefixs[$prefix])){                
            return $prefixs[$prefix];
            }
        }        
        return &#39;&#39;;
    }

} // class end?>
로그인 후 복사
로그인 후 복사

demo.php

<?phprequire &#39;Prefix.class.php&#39;;
// 原始id$user_id = 1001;
$order_id = 2016102743765214;
$message_id = 109283;echo &#39;<pre class="brush:php;toolbar:false">&#39;;
// 已加前缀idecho &#39;1.id加前缀&#39;.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 &#39;2.根据已加前缀id获取前缀类型&#39;.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 &#39;3.还原为原始id&#39;.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 &#39;
';?>
로그인 후 복사

출력:

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 = &#39;user&#39;;       // 用户
    const ORDER_TYPE = &#39;order&#39;;     // 订单
    const MESSAGE_TYPE = &#39;message&#39;; // 消息

    // 前缀设定
    private static $prefix = array(        
    self::USER_TYPE => &#39;U&#39;,        
    self::ORDER_TYPE => &#39;O&#39;,        
    self::MESSAGE_TYPE => &#39;M&#39;
    );    
    /**
     * 创建带前缀的id
     * @param  Int     $id          id
     * @param  Int     $prefix_type 类型
     * @return String
     */
    public static function getPrefixId($id, $prefix_type=&#39;&#39;){
        // 有自定义前缀类型
        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(&#39;/\d+/&#39;, $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(&#39;/[A-Za-z]+/&#39;, $prefix_id, $arr);        
        if(isset($arr[0])){            
        $prefix = $arr[0];            
        // 获取前缀
            $prefixs = array_flip(self::$prefix);            
            if(isset($prefixs[$prefix])){                
            return $prefixs[$prefix];
            }
        }        
        return &#39;&#39;;
    }

} // class end?>
로그인 후 복사
로그인 후 복사

demo.php

<?phprequire &#39;Prefix.class.php&#39;;
// 原始id$user_id = 1001;
$order_id = 2016102743765214;
$message_id = 109283;
echo &#39;<pre class="brush:php;toolbar:false">&#39;;
// 已加前缀idecho &#39;1.id加前缀&#39;.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 &#39;2.根据已加前缀id获取前缀类型&#39;.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 &#39;3.还原为原始id&#39;.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 &#39;
';?>
로그인 후 복사

출력:

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

필요에 따라 생성할 수 있는 사용자 정의된 접두사 상수입니다.


위 내용은 PHP ID 접두어 서식 클래스 내용입니다. 중국사이트(www.php.cn)!


원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿