데이터베이스 테이블에는 일반적으로 필드 유형이 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 class="brush:php;toolbar:false">'; // 已加前缀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 '';?>
출력:
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 class="brush:php;toolbar:false">'; // 已加前缀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 '';?>
출력:
1.id加前缀 U1001 O2016102743765214 M1092832.根据已加前缀id获取前缀类型 user order message3.还原为原始id10012016102743765214109283
필요에 따라 생성할 수 있는 사용자 정의된 접두사 상수입니다.
위 내용은 PHP ID 접두어 서식 클래스 내용입니다. 중국사이트(www.php.cn)!