別のエイリアスを作成するために2つのエイリアスを減算しようとしていますが、「未知の列」エラーが発生しています。他の2つのエイリアスの数学結果を使用してエイリアスを作成する
select o.id, o.name,
(select sum(l.source_expense)
from `assignments` as a
left join `leads` as l on (l.id = a.lead_id)
where a.{$this->sql_column}=o.id
and l.date_created between {$this->date_from} and {$this->date_to}
and find_in_set(l.vertical_id, '".implode(',', $this->app_user->verticals)."')
) as `expense`,
(select sum(a.buyer_revenue)
from `assignments` as a
left join `leads` as l on (l.id = a.lead_id)
where a.refunded=0
and a.{$this->sql_column}=o.id
and l.date_created between {$this->date_from} and {$this->date_to}
and find_in_set(l.vertical_id, '".implode(',', $this->app_user->verticals)."')
) as `revenue`,
`revenue` - `expense` as `profit`
from {$this->sql_table} as o
基本的に、私はexpense
からrevenue
を差し引いてprofit
エイリアスを作成したいと思います:
は、ここに私のSQLです。その理由は、私がdatatablesを使用していて、列をソート可能にしたいからです。 PHPでこれを簡単に行うことができます。
どうすればこの問題を解決できますか?
編集 - 私は以下の答えを試してみたが、PHPStormから「それぞれの派生テーブルにエイリアスがある」エラーが発生し、クエリを実行しようとすると構文エラーが発生する。相続人
新しいクエリ:
select t.id, t.name, t.expense, t.revenue, t.revenue - t.expense as profit
from(select o.id, o.name,
(select sum(l.source_expense)
from `assignments` as a
left join `leads` as l on (l.id = a.lead_id)
where a.{$this->sql_column}=o.id
and l.date_created between {$this->date_from} and {$this->date_to}
and find_in_set(l.vertical_id, '".implode(',', $this->app_user->verticals)."')
) as `expense`,
(select sum(a.buyer_revenue)
from `assignments` as a
left join `leads` as l on (l.id = a.lead_id)
where a.refunded=0
and a.{$this->sql_column}=o.id
and l.date_created between {$this->date_from} and {$this->date_to}
and find_in_set(l.vertical_id, '".implode(',', $this->app_user->verticals)."')
) as `revenue`
from {$this->sql_table} as o
) as t
他の回答と同じですが、エラーが発生しました - "それぞれの派生テーブルには別名が必要です" – kjdion84
@ kjdion84あなたの完全な質問を投稿してください。 – sagi
@ kjdion84あなたは 'O. 'T.Column>の代わりに外側のクエリで(IDと名前)、修正してもう一度やり直してください –
sagi