mysql多表查询
问题描述
问题解答
回答1:最好存储的时候根据name有个路由规则到这十个表中,如果是多维度查询推荐使用es
回答2:比较蠢的方法是这样:
SELECT ’table_0’, id FROM table_0 WHERE name = ?UNIONSELECT ’table_1’, id FROM table_1 WHERE name = ?UNION...SELECT ’table_9’, id FROM table_9 WHERE name = ?
然而不蠢的方法我还没想到
回答3:我想到的查询语句是这样的:select * from (select id,name,’table0’ as t from table_0 union all select id,name,’table1’ as t from table_1 union all select id,name,’table2’ as t from table_2 ......) as t where t.name = ?
回答4:从功能设计来讲,拆表后一般不需要考虑数据是从哪一张表获取的,因为在哪一张表完全是系统内部的事情,对业务来讲没有意义。
depress说的查询方法是可行的,或者是在表内部一个标识字段能说明是哪一张表。
比较理想的办法是表拆分和ID和一定的规律,拿到ID后可以直接判断属于哪一张表,也省去了做UNION查询的麻烦。如按照ID大小,每一百万是一张表,这样拿到ID可以直接判断出属于哪一张表。
相关文章:
1. Navicat for mysql 中以json格式储存的数据存在大量反斜杠,如何去除?2. mysql建表报错,查手册看不懂,求解?3. mysql - 查询数据库某个字段不重复的值,按时间排序,如何写呢?4. mysql - 在PHPMyadmin上乱捣鼓后出现 了 - #2002 - — 服务器没有响应(或本地服务器的套接字没有正确设置)。5. 数组排序,并把排序后的值存入到新数组中6. mysql - 数据库多表联合查询插入其他库7. php多任务倒计时求助8. javascript - 用了koa mysql2 一直出现一个error9. vue打包和PHP后台怎样同域名部署配置10. phpStudy怎么把mysql升级到7.x
