Maison >développement back-end >tutoriel php >Classe de formatage du préfixe d'ID php
Les tables de base de données ont généralement une clé primaire à incrémentation automatique avec un champ de type int et nommé id.
Avantages : l'utilisation du type int peut s'auto-incrémenter et économiser de l'espace de stockage par rapport au type de caractère.
Inconvénients : id est un type numérique Lorsque vous souhaitez interroger les données correspondant à un identifiant, il est difficile de déterminer sur quelle table de données il est basé sur l'identifiant.
Par conséquent, nous devrions utiliser int lors du stockage et effectuer un traitement sur l'identifiant lors de l'affichage, afin qu'il soit facile de savoir à quelle table appartient cet identifiant.
Écrit la classe suivante pour ajouter des préfixes aux identifiants et restaurer les identifiants préfixés.
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 '';?>
Sortie :
1.id加前缀 U1001 O2016102743765214 M1092832.根据已加前缀id获取前缀类型 user order message3.还原为原始id10012016102743765214109283
Constante de préfixe personnalisée, qui peut être créée en fonction de vos besoins.
Adresse de téléchargement du code source : Cliquez pour voir
Les tables de base de données ont généralement un type de champ int et un incrément automatique nommé id Clé primaire.
Avantages : l'utilisation du type int peut s'auto-incrémenter et économiser de l'espace de stockage par rapport au type de caractère.
Inconvénients : L'ID est un type numérique Lorsque vous souhaitez interroger les données correspondant à un ID, il est difficile de déterminer sur quelle table de données il est basé sur l'ID.
Par conséquent, nous devrions utiliser int lors du stockage et effectuer un traitement sur l'identifiant lors de l'affichage, afin qu'il soit facile de savoir à quelle table appartient cet identifiant.
Écrit la classe suivante pour ajouter des préfixes aux identifiants et restaurer les identifiants préfixés.
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 '';?>
Sortie :
1.id加前缀 U1001 O2016102743765214 M1092832.根据已加前缀id获取前缀类型 user order message3.还原为原始id10012016102743765214109283
Constante de préfixe personnalisée, qui peut être créée en fonction de vos besoins.
Ce qui précède est le contenu de la classe de formatage du préfixe d'ID php. Pour plus de contenu connexe, veuillez faire attention au PHP. Site Web chinois (www.php.cn) !