分不多,只有100,希望大家可以帮我
A表: 关键字段 id(字段id) attr_type(字段类别 只获取是1)
15 1
14 0
13 1
12 1 可能会有更多
B表: 关键字段 a_id(字段id) in_id(同A表ID 关联)shop_id(获取依据字段 id)
400 15 15
399 15 15
388 14 15-----
387 14 15-----这两组不做组合 以为A表中 type是0
386 13 15
385 13 15
384 12 15
383 12 15 可能会有更多是1的属性 也可能就一组
384 12 14
383 12 14
382 12 14
381 12 14
380 12 14 可能会有更多
C表:关键字段 id(字段id) shop_id(同B表shop_id 关联)attr_id(循环出来的数值) 以下是我想得到的结果
1 15 400|386|384
2 15 400|386|385
3 15 400|387|384 如果此组已存在,就跳过 如果不存在 往下自动循环出来写入
意图 我给予ID 15的指令 从AB表获取数据 生成到C表 如果原先已存在,就忽略不生成不存在的生成
比如我想循环shop_id 15的这个依据id 生成到C表 求代码
以下是我写的部分sql 后面不会了 求救
$sql = "SELECT b.a_id ". "FROM " .$GLOBALS['ecs']->table('B'). " AS b ". "LEFT JOIN " .$GLOBALS['ecs']->table('A'). " AS a ". "ON a.id IN(b.in_id) ". "WHERE b.shop_id = '15' AND a.attr_type = '1' " . "ORDER BY b.a_id DESC"; $row = $GLOBALS['db']->getAll($sql);
回复讨论(解决方案)
没看明白结果是怎么来的,猜测一下
create temporary table A (id int, attr_type int);insert into A values (15, 1),(14, 0),(13, 1),(12, 1); create temporary table B (a_id int, in_id int, shop_id int);insert into B values (400, 15, 15),(399, 15, 15),(388, 14, 15) ,(387, 14, 15),(386, 13, 15),(385, 13, 15),(384, 12, 15) ,(383, 12, 15),(384, 12, 14),(383, 12, 14) ,(382, 12, 14),(381, 12, 14),(380, 12, 14);select shop_id, group_concat(a_id) as attr_id from A, B where A.id=B.in_id and A.attr_type=1 group by shop_id, B.in_id
shop_id attr_id 14 384,383,382,381,380 15 384,383 15 386,385 15 400,399
结果就是 我浏览器给与 ....&shop_id=15 这个格局 php收到指令 从b表获取shop_id为15的数据 然后从b表隔离掉 attr_type 不是1的数据
获取到的应该是 以下几组
B表: 关键字段 a_id(字段id) in_id(同A表ID 关联)shop_id(获取依据字段 id)
400 15 15
399 15 15
386 13 15
385 13 15
384 12 15
383 12 15
然后归类 以 in_id 区分
400 15 15
399 15 15
*********************************************************************************************************************一个分组
386 13 15
385 13 15
*********************************************************************************************************************一个分组
384 12 15
383 12 15
*********************************************************************************************************************一个分组
然后把 前面的 a_id 字段数据做组合变化 写入到c表 形成 400|386|384 这种
C表:关键字段 id(字段id) shop_id(同B表shop_id 关联)attr_id(循环出来的数值) 以下是我想得到的结果
1 15 400|386|384
2 15 400|386|385
C表 id 为 auto属性 shop_id 为我给与的id attr_id 就是组合出来的变化结果
结果就是 我浏览器给与 ....&shop_id=15 这个格局 php收到指令 从b表获取shop_id为15的数据 然后从b表隔离
写错了 应该是从A表帅选
结果就是 我浏览器给与 ....&shop_id=15 这个格局 php收到指令 从b表获取shop_id为15的数据 然后从 A表隔离
select in_id, shop_id, group_concat(a_id) as attr_id from A, B where A.id=B.in_id and A.attr_type=1 and shop_id=15 group by B.in_id
in_id shop_id attr_id 12 15 384,383 13 15 386,385 15 15 400,399
select in_id, shop_id, group_concat(a_id) as attr_id from A, B where A.id=B.in_id and A.attr_type=1 and shop_id=15 group by B.in_id
in_id shop_id attr_id 12 15 384,383 13 15 386,385 15 15 400,399
版主,我已经自己写好了,谢谢你啊
大神,请您帮个忙,怎么把这个表里的数据按照我的要求隔离出来
img_id 标示为1的 goods_id 261 attr_id 区分组的依据
最终的要求就是 输出
a= '584,583,582,581,580,579'
b= '578,577,576,575,574,573'
572和495不输出 因为img_id 不等于一 谢谢了
select goods_id, attr_id, groub_concat(goods_attr_id) from tbl_name where img_id=1 group by attr_id
$a = array('571','570');$b = array('569','568','567','566','565','564');$c = array('563','562','561','560','559');foreach(combineDika($a,$b) as $v){ $r[] = join('|', $v);}$attr_all = join(',', $r);$attr_all = explode(',', $attr_all);foreach ($attr_all as $list){ $sql = "SELECT goods_attr " . "FROM " .$GLOBALS['ecs']->table('products') . "WHERE goods_attr = '".$list."' "; $check_attr = $GLOBALS['db']->getOne($sql); $value = 'ECS000261g_p'.rand(10000,99999); if (empty($check_attr)) { $sql = "INSERT INTO " . $GLOBALS['ecs']->table('products') . " (goods_id, goods_attr, product_sn, product_number) VALUES ('261', '".$list."', '$value', '10000')"; $GLOBALS['db']->query($sql); }}
这是我后面执行的代码
用个2B方法读取出来了
谢谢版主
我现在结贴

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

JWT是一种基于JSON的开放标准,用于在各方之间安全地传输信息,主要用于身份验证和信息交换。1.JWT由Header、Payload和Signature三部分组成。2.JWT的工作原理包括生成JWT、验证JWT和解析Payload三个步骤。3.在PHP中使用JWT进行身份验证时,可以生成和验证JWT,并在高级用法中包含用户角色和权限信息。4.常见错误包括签名验证失败、令牌过期和Payload过大,调试技巧包括使用调试工具和日志记录。5.性能优化和最佳实践包括使用合适的签名算法、合理设置有效期、

会话劫持可以通过以下步骤实现:1.获取会话ID,2.使用会话ID,3.保持会话活跃。在PHP中防范会话劫持的方法包括:1.使用session_regenerate_id()函数重新生成会话ID,2.通过数据库存储会话数据,3.确保所有会话数据通过HTTPS传输。

SOLID原则在PHP开发中的应用包括:1.单一职责原则(SRP):每个类只负责一个功能。2.开闭原则(OCP):通过扩展而非修改实现变化。3.里氏替换原则(LSP):子类可替换基类而不影响程序正确性。4.接口隔离原则(ISP):使用细粒度接口避免依赖不使用的方法。5.依赖倒置原则(DIP):高低层次模块都依赖于抽象,通过依赖注入实现。

在PHPStorm中如何进行CLI模式的调试?在使用PHPStorm进行开发时,有时我们需要在命令行界面(CLI)模式下调试PHP�...

如何在系统重启后自动设置unixsocket的权限每次系统重启后,我们都需要执行以下命令来修改unixsocket的权限:sudo...

静态绑定(static::)在PHP中实现晚期静态绑定(LSB),允许在静态上下文中引用调用类而非定义类。1)解析过程在运行时进行,2)在继承关系中向上查找调用类,3)可能带来性能开销。

使用PHP的cURL库发送JSON数据在PHP开发中,经常需要与外部API进行交互,其中一种常见的方式是使用cURL库发送POST�...
