一种精妙的数据查询与存储方式
首页->学习资料->编程语言->php教程->php技巧 关键词: 发布时间:2017-03-10 09:29:33 浏览次数:1768

假如一种商品上有这样几个随机标签属性:【国外】【美国】【进口】【红色】【绿色】

假如这几个属性是固定的(属性个数不是很多),我们可以给他编个号:

1国外2美国4进口8红色16绿色

假如A的属性为国外,美国,绿色,则将其属性存为19(1+2+16)

假如B的属性为国外,美国,红色,则将其属性存为11(1+2+8)

如果要查同时具有国外,美国属性的商品,可以用(字段名&3)=字段名这种位运算方式,3(即1国外+2美国=3)


附两种解这种以和存储的方法:

 //将1,2,4. 。。。这种规律存储的材质,手寸的和还原为由哪些数据相加得出的;
function sumReduction($v){
    $size_all=(string)(decbin($v));//和
    $size_all=strrev($size_all);
    $l=strlen($size_all);
    $gs='';
    $arr=array();
    for($i=0;$i<$l;$i++){
        $d=(int)substr($size_all,$i,1);
        //echo $d.'<br/>';
        $m=pow(2,$i);
        $gs+=$d*$m;
        if($d>0){
            array_push($arr,$m);
        }
    }
    return $arr;
}


function extract_binary($input) {
    //数字转二进制字符串
    $string = decbin($input);
    //翻转字符串
        $string = strrev($string);
        //字符串拆成数组
    $values = str_split($string);
    //过滤掉数组中的0,只剩下1,元素索引不变
        $values = array_filter($values, function($value) {
            return $value;
        });
        //把剩下索引取出
        $keys = array_keys($values);

        //索引是几,就是2的几次方
        $segments = [];
        foreach ($keys as $k) {
            $segments[] = pow(2, $k);
        }
        return $segments;
    }



以上的方式属合属性不多,且固定的情况;


另外可以用:

mysql中FIND_IN_SET的使用方法

FIND_IN_SET(str,strlist)函数

str 要查询的字符串

strlist 字段名 参数以”,”分隔 如 (1,2,6,8)//存储的数据格式,前后不要用逗号,是一种集合的方式查询,非常方便,适合属性很多的情况

查询字段(strlist)中包含(str)的结果,返回结果为null或记录

下面举例说明

test表中有如下字段及值

下面我想查询area中包含”1″这个参数的记录

SELECT * from test where FIND_IN_SET('1',area)



还有一种笨办法就是以(,1,2,4,8,)这种前后有逗号的方式存,查的时候用like '%,1,%'这种方式

赞:(0)
踩:(0)
相关文章
phpexcel设置行高及列宽,背景颜色,
单点登录sso原理及php实现方式及de
在php中用curl请求java接口无法获
免费ip地址查询接口
php,java,android, aes加解密-加密
地图上计算两点间的距离
关于百度地图的一些技巧
php中empty,is_null,isset的区别
windows及linux下composer安装教程
微信扫码登录
热门文章
win7中将文件拷贝到虚拟机linux下
phpexcel设置行高及列宽,背景颜色,
rabbitmq无法启动
intellij idea不显示git push按钮
php7中使用mongodb的aggregate进行
centos7.4 64位下swoole安装及配置
laravel页面静态化的方法
navicate连接mycat报1184错误
单点登录sso原理及php实现方式及de
devops-jenkins容器为pending状态
好评文章
phpexcel设置行高及列宽,背景颜色,
php7中使用mongodb的aggregate进行
intellij idea打开文件所在文件夹
windows下使用MongoDB Compass Com
win7中将文件拷贝到虚拟机linux下
laravel 中悲观锁 & 乐观锁的使用
单点登录sso原理及php实现方式及de
navicate连接mycat报1184错误
rabbitmq无法启动
laravel整合dingo/api方法步骤:jwt
标签
rabbitmq mysql备份 elasticsearch golang swoole
我的项目
【github】www.github.com/hurong241
【码云】gitee.com/hu_rong/projects
【docker hub】hub.docker.com/repositories/hurong241
【packagist】packagist.org/users/hurong241/packages
站点信息
建站时间:2011年
文章数:607篇
浏览数:943478
粤ICP备18028092号-1  微信:hurong241