mysql以一张表的字段为条件查询另外一张表

时间:2022-04-01 14:51:40

试了好久,差点动用存储过程和触发器,然而项目不让写存储过程就很爆炸。

我的例子:

城市表,cityId,cityName,provinceId

任务表,taskId,region(这个就是城市代码字段)

要求:

根据省Id查询所有市,并且通过市id查询市下面任务数

SELECT
	city.cityName,
 	(SELECT count(*) FROM task WHERE task.region = CONCAT("44-",city.cityId))AS tasks
FROM
 	city
WHERE
 	city.provinceId = 44;

44是省id

#

#

中间出现几个问题

1,我在from后面进行连表city inner join task,发现出现循环结果,原因是因为上面查询字段时候已经查询过表了


/*  对于一个数据库考试考得很渣的人来说,这就很崩溃了  */