一个判断是否是权限商品,之后进行不同筛选的SQL语句

xiaoyang7545 2015-09-16 10:02:35
假设这是product 表 表里有商品的信息 及id 还有这个是否需要授权

然后这是权限表

pid对应product 表 的id

我想要的效果是 假设在 product 表里面 is_access为true的时候 就需要 条件 这个商品id 在权限表里
且 uid=当前用户的uid(这个应该就多一个where,没太多好说的)。

关键就是 如何选出 is_access为false 和 is_access为true 且在权限表中的 商品
...全文
156 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
xiaoyang7545 2015-09-16
  • 打赏
  • 举报
回复
引用 2 楼 yupeigu 的回复:
试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
对了 我这个语句是需要排序的。用了union貌似是不能排序的?
LongRui888 2015-09-16
  • 打赏
  • 举报
回复
试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
Tiger_Zhao 2015-09-16
  • 打赏
  • 举报
回复
    SELECT p.*
FROM product p
LEFT JOIN rights r
ON p.id = r.pid
AND p.is_access = true
AND r.uid = @uid
WHERE p.is_access = false
OR r.id IS NOT NULL
xiaoyang7545 2015-09-16
  • 打赏
  • 举报
回复
引用 6 楼 Tiger_Zhao 的回复:
我#1的可以直接加排序啊。
恩 你的也可以。。我刚刚用你的数据没 出来是 因为true 没加引号。。还以为不行~
LongRui888 2015-09-16
  • 打赏
  • 举报
回复
引用 7 楼 xiaoyang7545 的回复:
[quote=引用 5 楼 yupeigu 的回复:] [quote=引用 3 楼 xiaoyang7545 的回复:] [quote=引用 2 楼 yupeigu 的回复:] 试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
对了 我这个语句是需要排序的。用了union貌似是不能排序的?[/quote] 可以的,关键看你要怎么排序,比如:
		select *
		from 
		(
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
        )t
		order by pid
[/quote]
引用 5 楼 yupeigu 的回复:
[quote=引用 3 楼 xiaoyang7545 的回复:] [quote=引用 2 楼 yupeigu 的回复:] 试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
对了 我这个语句是需要排序的。用了union貌似是不能排序的?[/quote] 可以的,关键看你要怎么排序,比如:
		select *
		from 
		(
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
        )t
		order by pid
[/quote]
引用 5 楼 yupeigu 的回复:
[quote=引用 3 楼 xiaoyang7545 的回复:] [quote=引用 2 楼 yupeigu 的回复:] 试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
对了 我这个语句是需要排序的。用了union貌似是不能排序的?[/quote] 可以的,关键看你要怎么排序,比如:
		select *
		from 
		(
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
        )t
		order by pid
[/quote] 用你的 方法 可以实现了 但是我有个疑问 就是为什么 我有2个is_access = true的商品 直接用你union里的第二个子句 查出来 数据条目是有 2*权限表该商品条目数。 而用这一整句放进去 却只有两条呢? 但是由于我本来就只要这样的两条所以这个语句是没问题的。[/quote] 可能是在第二个语句中,关联出来的结果有重复,然后union这个是合并结果集,同时去重的,所以就把重复的结果给去掉了
xiaoyang7545 2015-09-16
  • 打赏
  • 举报
回复
引用 5 楼 yupeigu 的回复:
[quote=引用 3 楼 xiaoyang7545 的回复:] [quote=引用 2 楼 yupeigu 的回复:] 试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
对了 我这个语句是需要排序的。用了union貌似是不能排序的?[/quote] 可以的,关键看你要怎么排序,比如:
		select *
		from 
		(
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
        )t
		order by pid
[/quote]
引用 5 楼 yupeigu 的回复:
[quote=引用 3 楼 xiaoyang7545 的回复:] [quote=引用 2 楼 yupeigu 的回复:] 试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
对了 我这个语句是需要排序的。用了union貌似是不能排序的?[/quote] 可以的,关键看你要怎么排序,比如:
		select *
		from 
		(
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
        )t
		order by pid
[/quote]
引用 5 楼 yupeigu 的回复:
[quote=引用 3 楼 xiaoyang7545 的回复:] [quote=引用 2 楼 yupeigu 的回复:] 试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
对了 我这个语句是需要排序的。用了union貌似是不能排序的?[/quote] 可以的,关键看你要怎么排序,比如:
		select *
		from 
		(
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
        )t
		order by pid
[/quote] 用你的 方法 可以实现了 但是我有个疑问 就是为什么 我有2个is_access = true的商品 直接用你union里的第二个子句 查出来 数据条目是有 2*权限表该商品条目数。 而用这一整句放进去 却只有两条呢? 但是由于我本来就只要这样的两条所以这个语句是没问题的。
Tiger_Zhao 2015-09-16
  • 打赏
  • 举报
回复
我#1的可以直接加排序啊。
LongRui888 2015-09-16
  • 打赏
  • 举报
回复
引用 3 楼 xiaoyang7545 的回复:
[quote=引用 2 楼 yupeigu 的回复:] 试试这个;
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
对了 我这个语句是需要排序的。用了union貌似是不能排序的?[/quote] 可以的,关键看你要怎么排序,比如:
		select *
		from 
		(
		select p.*
		from product p
		where p.is_access = false

		union 

		select p.*
		from product p
		inner join rights r
		on p.id = r.pid
		where p.is_access = true
        )t
		order by pid
hhhttt_ 2015-09-16
  • 打赏
  • 举报
回复
select * from product p
  where  exists (
           select top 1 1 from right r where r.uid=p.uid and r.id=p.pid and p.is_access='true' ) 
   or p.is_access='false'
代码下载链接: https://pan.quark.cn/s/23ff226fe24b ### iTest自动化测试工具知识点详解#### 一、iTest自动化测试工具简介iTest是由业界领先测试设备制造商Spirent所研发的一款自动化测试工具。该工具为用户呈现了一个集成化的自动化测试解决方案,借助这一工具,用户能够完成软件及网络测试的编写与自动化执行。iTest不仅适用于专业的测试工程师,对于非测试人员来说,同样是一个功能强大的工具,能够协助他们对网络中的设备和应用进行访问和自动化操作。#### 二、iTest Lite快速入门指南iTest Lite是一款免费提供给用户的版本,其目的是为用户呈现一个简明的iTest产品概览。用户可以从官方网站(www.fanfaresoftware.com)获取并安装iTest Lite。此工具不仅能够支持用户进行软件和网络测试,还能用于对网络上的设备或应用程序进行管理和自动化。#### 三、iTest的工作流程- **主页内容**:在iTest被启动之后,主页内容将展示在右侧,而活动列表则位于左侧。主页上不仅包含欢迎消息,还会提供iTest工作流程的高级图示以及链接到Fanfare社区的入口,用户可以通过论坛帖子、教程视频等资源进一步了解iTest。 - **活动列表**:这是使用iTest功能的推荐起点。活动列表包含以下几个部分: - **连接设备**:一种便捷的方法来验证iTest是否能够连接到测试设备。 - **构建拓扑结构**:在这一步骤中,可以迅速定义一组想要进行测试的设备或应用程序。 - **开发测试用例**:创建一个自动化的测试用例,用于针对任何特定的拓扑结构进行测试。 - **查看测试报告**:访问个人...
代码下载链接: https://pan.quark.cn/s/89ea75840350 STM32微控制器的实时时钟(RTC)作为一个独立的计时单元,能够在系统重启或从休眠状态激活后持续保持时间设置不变。本文将详细探究STM32 RTC的运行机制,涵盖时钟结构图解析以及时间显示的原理。需要明确的是,STM32的RTC模块坐落于备份领域(Backup domain),它借助32.768kHz的辅助晶体振荡器作为时钟供给。在进行RTC编程实践时,务必小心谨慎地处理与RTC相关的寄存器配置。随后,我们将借助RTC时钟结构图展开深入剖析。时钟结构图主要由两大块构成:APB1接口区块与RTC主控单元。APB1接口区块负责对与RTC关联的寄存器进行数据交互,而RTC主控单元内含两个子模块:RTC分频调节模块以及一个32位可变步长计数器。在RTC主控单元内部,有几个关键寄存器是必须掌握的:1. RTC_DIV(RTC分频调节余数寄存器):此寄存器旨在获取超越秒级的更高精度时间(如0.1秒、0.01秒)。该寄存器在数值减至极值后会由硬件自动重置。其数值由RTC_PRL(RTC分频调节装载寄存器)提供,其时钟频率源自RTCCLK。2. RTC_PRL(RTC分频调节装载寄存器):它为RTC_DIV提供重置数值,同时用于设定时钟频率的缩放比例。例如,若晶体振荡器频率为32.768KHz,将RTC_PRL设定为32767,即可得到每秒的计数速率。3. RTC_CNT(RTC计数器寄存器):该寄存器记录秒数,并可用于触发计数器溢出中断。4. RTC_ALR(RTC闹钟寄存器):用于设定闹钟时刻,一旦计数器的数值与闹钟寄存器匹配,并且中断功能已启用,便会引发一个闹钟中断事件。在物理实现层...

22,297

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧