我需要创建一个查询,该查询将根据任务代码是否为空,显示具有最低但最接近 id 的项目名称,该项目也被视为“关键”项目。这可能看起来有点复杂,所以我将它放在一个简化的代码中以简化:
ifnull (Task_Code,
create Key_temp
select id_temp
task_is_key_temp
task_id_temp
proj_name_temp
from projetos_main pm left join pcrs
ON pcrs.num_doc = pm.Task_code
where task_id_temp <= task_id and
task_is_sum_temp = 'true'
order by id desc
limit 1
因此,当任务代码为空时,我想创建一个临时表,用我的主表中的信息填充它,并获得一个既是“关键项目”又具有低于原始 ID 的结果。
问题是,我不知道是否可以使用“Ifnull”创建一个临时表,就像我执行以下操作时一样:
ifnull(Task_code,
CREATE TABLE Key_temp ...)
我收到语法错误。所以这是不可能的,还是我的代码错了?
编辑
这是表结构:
Pcrs
Num_doc|
1 |
2 |
- |
Projetos_main
Id || Task_is_key || Task_id || Proj_name || Task_code |
1 || False || 3 || Name 1 || 1 |
2 || True || 5 || Name 2 || 2 |
3 || False || 5 || Name 3 || - |
Task_code 是引用 Num_doc 的外键。不过,并非所有项目都有 Task_Code,所以当发生这种情况时,我需要显示项目名称,其中最接近的 id 也是关键项目。
所以它应该停在项目 3,意识到 Task_code 是空的,然后得到项目 2,它具有相同的 task_id 并且是一个 key_task。