数据库表通常都会有一个字段类型为int,命名为id的自增主键。
HMCSS是由河马工作室全新开发的通用的企业网站系统,是PHP+MYSQL的架构,采用DIV+CSS的方式进行网页布局,网站的功能包括有:企业简介,图片展示幻灯,产品图片滚动,企业荣誉,实力展示,产品分类及展示,网上招聘,在线留言,联系我们,在线地图等内容,另外还带有完整的管理后台,如网站SEO优化关键词等都可以自由设定。 HMCSS目前发布的是1.0版本,就是上述的这些内容。后面我们还要加上产品
优点:使用int类型可自增,且比字符类型节省存储空间。
缺点:id是数值型,当要查询一个id对应的数据时,很难根据id判断是哪一个数据表。
因此我们在存储时,应使用int,而在显示时对id进行一些处理,使很容易分辨这个id属于哪一个表。
编写了下面这个类,实现对id增加前缀及对已加前缀的id还原。
Prefix.class.php
'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
';// 已加前缀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中文网。
相关推荐:










