数据库表通常都会有一个字段类型为int,命名为id的自增主键。
优点:使用int类型可自增,且比字符类型节省存储空间。
缺点:id是数值型,当要查询一个id对应的数据时,很难根据id判断是哪一个数据表。
因此我们在存储时,应使用int,而在显示时对id进行一些处理,使很容易分辨这个id属于哪一个表。
编写了下面这个类,实现对id增加前缀及对已加前缀的id还原。
Prefix.class.php
<?php
class Prefix{
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'
);
public static function getPrefixId($id, $prefix_type=''){
if(isset(self::$prefix[$prefix_type])){
return self::$prefix[$prefix_type].$id;
}
return $id;
}
public static function getId($prefix_id){
preg_match('/\d+/', $prefix_id, $arr);
if(isset($arr[0])){
return $arr[0];
}
return 0;
}
public static function getPrefixType($prefix_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 '';
}
}
?>
demo.php
<?php
require 'Prefix.class.php';
$user_id = 1001;
$order_id = 2016102743765214;
$message_id = 109283;
echo '<pre>';
echo '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;
echo '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 '</pre>';
?>
输出:
1.id加前缀
U1001
O2016102743765214
M109283
2.根据已加前缀id获取前缀类型
user
order
message
3.还原为原始id
1001
2016102743765214
109283
自定义的前缀常量,可以根据需求自行创建。
源码下载地址:点击查看
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)