数据库表通常都会有一个字段类型为int,命名为id的自增主键。
Lht蓝海豚(大维)团购导航系统是一套开源程序,采用PHP+MySql平台开发,具有强大的多规则API采集功能、精确化引导消费功能,卓越的负载能力和访问速度,全面支持第三方整合(微博、短信等)前台功能团购名站:显示分类下的所有团购网站,点击团购站,可直接进行查看、推荐、收藏精品商城:为网民推荐展示非团购网站的网上商城今日团购:显示各团购网站正在进行的团购团购排行:今日团购商品可按价格、行业、折扣、
优点:使用int类型可自增,且比字符类型节省存储空间。
缺点:id是数值型,当要查询一个id对应的数据时,很难根据id判断是哪一个数据表。
因此我们在存储时,应使用int,而在显示时对id进行一些处理,使很容易分辨这个id属于哪一个表。
编写了下面这个类,实现对id增加前缀及对已加前缀的id还原。
Prefix.class.php
立即学习“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前缀格式化类的内容,更多相关内容请关注PHP中文网(www.php.cn)!










