左连接去重(objec)
需求场景:
1、前端使用的object-table(angularJs)
2、自定义模糊查询
可以模糊查询主表,主表没有数据的时候,可通过字表的(name或者hostname)字段来查询(主-子:一对多的关系)。两个表通过p_id和t_name关联
eg:主表A
| id | name | pid | t_name |
| 1 | aa | 1 | test1 |
| 2 | bb | 2 | test1 |
| 3 | ccc | 1 | test2 |
| 4 | ddd | 3 | test3 |
字表B
| id | pid | t_name | b_name | isTrue |
| 1 | 1 | test1 | ee | y |
| 2 | 1 | test2 | aa | y |
| 3 | 2 | test1 | ff | y |
| 4 | 3 | test4 | ww | n |
原本是查询A表,然后展示(可模糊查询),只展示A表的数据。但是后需求变为模糊查询的时候,如果A表查不到数据,即根据B表的b_name找出A表的数据
这里有个使用技巧,当后台使用拼接sql的时候,where 1=2 或者 where 1=1可以少写很多代码,因为你不确定where 后面是否有条件
select a.*,b.b_name from A a left join B b on(a.pid=b.pid and a.t_name=b.t_name) where 1=2 or a.name like '%aa%' or b.b_name like '%aa%';
这样得到的结果是
| id | name | pid | t_name | b_name |
| 1 | aa | 1 | test1 | ee |
| 1 | aa | 1 | test1 | aa |
因为我只展示A表,所以其实我是不用select b.b_name的。在页面的时候就隐藏了b_name这列。
| id | name | pid | t_name | |
| 1 | aa | 1 | test1 | |
| 1 | aa | 1 | test1 |
这样导致了数据重复了,导致数据不对。
select a.*,b.b_name from A a left join B b on(a.pid=b.pid and a.t_name=b.t_name) where 1=2 or a.name like '%aa%' or b.b_name like '%aa%';
如果我去重复只显示一条,数据也是不对的,因为明明是两条数据,数据库查出来去重也是两条,只是那个字段没显示而已。
重复数据不是客户要的结果。
那么就不要显示b.b_name然后去重
select distinct a.* from A a left join B b on(a.pid=b.pid and a.t_name=b.t_name) where 1=2 or a.name like '%aa%' or b.b_name like '%aa%';
这样就会得到一条数据,这就是我们想要的结果了
But!!!!
虽然我们得到了想要的结果。但是因为没有select b表的b_name导致前端表格是没有这个字段展示的。
如果A中没有查询到内容,就会用B表的b_name字段去查询。使用object-table模糊查询的时候,它不会有数据显示
假如使用B表中的“ff”去查询数据,实际上是有一条数据的,但是前端就是不显示(后台已返回该数据)
select distinct a.* from A a left join B b on(a.pid=b.pid and a.t_name=b.t_name) where 1=2 or a.name like '%ff%' or b.b_name like '%ff%';
应该得到的数据
| id | name | pid | t_name | b_name |
| 2 | bb | 2 | test1 | ff |
实际展示的数据
| id | name | pid | t_name | |
| 2 | bb | 2 | test1 |
得到这样的数据之后,再去模糊查询“ff”,后台会返回这条数据,但是前端就不不显示,想了好久才知道,原来是object-table自带的过滤导致的,虽然数据已经到前端了(本应该正常显示),但是因为前端列表中没有‘ff’字符串,然后搜索框中又有‘ff’字符串。
解决方法:1、因为用的是后端的模糊查询,可以关掉object-table自带的过滤(因为对object-table不熟,所以也不知道怎么关闭,这是自己想的理想状态。。。)
2、吧b_name这里在前端显示出来,但是也不要让前面的数据重复。这就是重点了,动态拼接前端模糊查询的字段(‘aa’就是模糊查询的字符串),这里需要好生理解,或者建两个简单的表测试一下
select distinct a.* ,‘aa’ as b_name from A a left join B b on(a.pid=b.pid and a.t_name=b.t_name) where 1=2 or a.name like '%aa%' or b.b_name like '%aa%';
| id | name | pid | t_name | b_name |
| 1 | aa | 1 | test1 | ee |
| 1 | aa | 1 | test1 | aa |
结果由最上面的变成
| id | name | pid | t_name | b_name |
| 1 | aa | 1 | test1 | aa |
这样数据就不会重复,然后前端又能过滤(通过子表来查询到主表的内容)
左连接去重(objec)的更多相关文章
- SQL左连接查询 left join ... on
左连接查询 保留左边主表的所有行(即使在右表没有匹配的行),右表输出满足 on 条件的行,不满足的输出null 示例:组合两个表 - 力扣 表1: Person +--------------+- ...
- mysql之左连接、右连接、内连接、全连接、等值连接、交叉连接等
mysql中的各种jion的记录,以备用时查 1.等值连接和内连接, a.内连接与等值连接效果是相同的,执行效率也相同,只是书写方式不一样,内连接是由SQL 1999规则定的书写方式 比如: sele ...
- 最常用SQL joins:内连接(交集)、左外连接、右外连接、左连接、右连接、全连接(并集),全外连接
1.内连接.两个表的公共部分用Inner join,Inner join是交集的部分. Select * from TableA A inner join TableB B on A.key=B.ke ...
- mysql 内连接、左连接、右连接
记录备忘下,初始数据如下: DROP TABLE IF EXISTS t_demo_product; CREATE TABLE IF NOT EXISTS t_demo_product( proid ...
- 《Entity Framework 6 Recipes》中文翻译系列 (16) -----第三章 查询之左连接和在TPH中通过派生类排序
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 3-10应用左连接 问题 你想使用左外连接来合并两个实体的属性. 解决方案 假设你有 ...
- 数据库中的左连接(left join)和右连接(right join)区别
Left Join / Right Join /inner join相关 关于左连接和右连接总结性的一句话: 左连接where只影向右表,右连接where只影响左表. Left Join select ...
- MySQL的左连接、右连接和全连接的实现
表student:+----+-----------+------+| id | name | age |+----+-----------+------+| 1 | Jim | 18 || 2 | ...
- Oracle 左连接、右连接、全外连接、(+)号作用
分类: Oracle Oracle 外连接 (1)左外连接 (左边的表不加限制) (2)右外连接(右边的表不加限制) (3)全外连接(左右两表都不加限制) 外连接(Outer ...
- Linq连接查询之左连接、右连接、内连接、全连接、交叉连接、Union合并、Concat连接、Intersect相交、Except与非查询
内连接查询 内连接与SqL中inner join一样,即找出两个序列的交集 Model1Container model = new Model1Container(); //内连接 var query ...
随机推荐
- 逆向随笔 - switch 语句深入分析
switch case 语句在c语言里还是比較简单的.可是被编译出来之后,优化结果往往让人非常疑惑.全然看不懂,以下我们一次次的尝试,看看编译器究竟把switch语句变成什么样了. ① 先上个最简 ...
- asp.net web网站权限系统的简单设计
权限设计总结一句话就是:拥有权限的主体来管控系统的各种资源资源,及在资源上体现的各种操作. 概括来说就是,权限离不开三要素: 1:权限的主体 2:管控的资源 3:各种操作 现对三要素分别做简单的阐述 ...
- Java多线程面试大全
什么是线程? 线程是操作系统能够进行运算调度的最小单位,它被包含在进程之中,是进程中的实际运作单位,可以使用多线程对进行运算提速. 比如,如果一个线程完成一个任务要100毫秒,那么用十个线程完成改任务 ...
- Linux写时拷贝技术(copy-on-write)
1.传统的fork()函数创建一个子进程,子进程和父进程共享正文段,复制数据段,堆,栈到子进程示意图如下: 2.Linux的fork()函数-写时复制(copy-on-write)创建一个子进程,内核 ...
- 每日英语:Mooncake Austerity Hits China's Mid-Autumn Festival
First baijiu, then red carpets, and now mooncakes. For Chinese government officials, the list of tab ...
- npm 的指令介绍
npm install <name>安装nodejs的依赖包 例如npm install express 就会默认安装express的最新版本,也可以通过在后面加版本号的方式安装指定版本, ...
- spring boot设定mysql
mysql创建表,制定自增,utf-8编码 create table person(id int auto_increment primary key, name varchar(100), age ...
- loadrunner11 测试restful
loadrunner不知道为啥会有这么大的体积. 一开始用的是c脚本,可是恶心的是又不是完全的c,读文件的fseek居然没有. 后来又折腾java脚本,发现loadrunner11 java要用jdk ...
- 【iOS】TableView的footerView不随cell滚动而停留在tableView底部的问题
苹果官方给我提供TableView的FooterView和HeaderView停留在顶部的非常不错效果,有时候我们不须要这些FooterView和HeaderView停留在底部或者上部,如今就以Foo ...
- 阿里云ECS,WampServer无法访问外网
情况: 使用阿里云ECS服务器.服务端打开WampServer后,在服务端能通过127.0.0.1和localhost访问到WampServer的首页. 阿里云已经给了外网IP,不需要路由器再做端口映 ...