mysql where 变量,MySQL在where子句中使用用户定义的变量

sql query:

select

u.username,

@total_subscribers:=(

select count(s.id)

from subscribers as s

where s.suid = u.uid

) as total_subscribers

from users as u

where @total_subscribers > 0

if i remove where @total_subscribers > 0 query will show all users and their total subscribers

but i want to show only those users who have at least 1 subscriber... after i add the where clause and use the defined variable i get an empty result set.

解决方案

You can do it with group by and having:

select

u.username,

count(s.id) as total_subscribers

from users as u

inner join subscribers as s on s.suid = u.uid

group by u.id

having count(s.id) > 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL定义变量是一种用户可以创建的变量,用于存储任意类型的值,例如数字、字符串和日期等。它可以在 MySQL 会话使用,以便在查询引用该变量的值,也可以在存储过程、函数、触发器等数据库对象使用。以下是 MySQL定义变量的一些常见用法: 1. 定义变量使用 SET 关键字定义变量并赋值,例如: ``` SET @myVar = 'Hello World'; ``` 2. 引用变量:在查询使用 @ 符号引用变量,例如: ``` SELECT @myVar; ``` 3. 修改变量使用 SET 关键字修改变量的值,例如: ``` SET @myVar = 'Hello MySQL'; ``` 4. 计算变量:可以在查询使用定义变量进行计算,例如: ``` SET @num1 = 10; SET @num2 = 5; SELECT @num1 + @num2; ``` 5. 使用变量作为查询条件:可以在 WHERE 子句使用定义变量作为查询条件,例如: ``` SET @name = 'John'; SELECT * FROM users WHERE name = @name; ``` 6. 在存储过程使用变量:可以在存储过程定义使用定义变量,例如: ``` DELIMITER // CREATE PROCEDURE myProcedure() BEGIN DECLARE myVar INT; SET myVar = 100; SELECT myVar; END // DELIMITER ; ``` 7. 在触发器使用变量:可以在触发器定义使用定义变量,例如: ``` DELIMITER // CREATE TRIGGER myTrigger BEFORE INSERT ON myTable FOR EACH ROW BEGIN DECLARE myVar VARCHAR(50); SET myVar = NEW.name; INSERT INTO log_table VALUES(myVar); END // DELIMITER ; ``` 总之,MySQL定义变量可以帮助用户在查询和数据库对象存储和引用数据,提高查询和处理效率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值