ホームページ >バックエンド開発 >PHPチュートリアル >PHPを介してIDプレフィックスフォーマットクラスを実行する方法

PHPを介してIDプレフィックスフォーマットクラスを実行する方法

jacklove
jackloveオリジナル
2018-06-20 18:01:201958ブラウズ

データベース テーブルには通常、フィールド タイプが 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 プレフィックスの書式設定を実行する方法について説明します。その他の関連コンテンツについては、php の中国語 Web サイトを参照してください。

##関連する推奨事項:

php メソッドを使用して print_r を実行する方法処理されたデータを元の配列に復元するには


##php で PDO を介した接続を決定する 利用可能なメソッド


#ページまたは画像が php

# を通じて gzip 圧縮されているかどうかを確認します。 ##

以上がPHPを介してIDプレフィックスフォーマットクラスを実行する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。