我有一个查询选择,可以直接在MySql
中很好地工作,但是,我想知道是否必须在Laravel 5.7
类的Controller
中进行复制才能发送将其显示在我的视图中,并使用数据创建一个表,然后执行以下查询:
SELECT
B.ID,
A.nome,
A.vulgo,
A.rg,
A.sexo,
I.indiciado_por,
B.area_atuacao,
C.carta,
N.naipe,
B.data_entrada,
S.situacao,
B.data_saida,
B.observacoes
FROM
baralho B
INNER JOIN baralho_naipe N ON
B.id_naipe = N.naipe_id
INNER JOIN baralho_carta C ON
B.id_carta = C.carta_id
INNER JOIN baralho_situacao S ON
B.id_situacao = S.situacao_id
INNER JOIN(
SELECT
id_baralho,
GROUP_CONCAT(indiciado.indicio SEPARATOR '/') AS indiciado_por
FROM
baralho_has_baralho_indicio
INNER JOIN baralho B ON
baralho_has_baralho_indicio.id_baralho = B.id
INNER JOIN baralho_indicios indiciado ON
baralho_has_baralho_indicio.id_baralho_indicio = indiciado.indicio_id
GROUP BY
B.id
HAVING
B.id = B.id
) AS I
ON
B.id = I.id_baralho
INNER JOIN(
SELECT
id_baralho,
ALVO.nome,
ALVO.vulgo,
ALVO.rg,
ALVO.sexo
FROM
baralho_has_baralho_alvo
INNER JOIN baralho B ON
baralho_has_baralho_alvo.id_baralho = B.id
INNER JOIN baralho_alvos ALVO ON
baralho_has_baralho_alvo.id_baralho_alvo = ALVO.id_alvo
GROUP BY
B.id
HAVING
B.id = B.id
) AS A
ON
B.id = A.id_baralho
ORDER BY
B.id ASC
如何在Laravel上执行此查询?请帮助我,我是Laravel的初学者,感谢您的帮助
答案 0 :(得分:0)
我认为这会起作用
DB::table('baralho AS B')
->join('baralho_naipe AS N', 'B.id_naipe', '=', 'N.naipe_id')
->join('baralho_carta AS C', 'B.id_carta', '=', 'C.carta_id')
->join('baralho_situacao AS S', 'B.id_situacao', '=', 'S.situacao_id')
->join(DB::raw("(SELECT
id_baralho,
GROUP_CONCAT(indiciado.indicio SEPARATOR '/') AS indiciado_por
FROM
baralho_has_baralho_indicio
INNER JOIN baralho B ON
baralho_has_baralho_indicio.id_baralho = B.id
INNER JOIN baralho_indicios indiciado ON
baralho_has_baralho_indicio.id_baralho_indicio = indiciado.indicio_id
GROUP BY
B.id
HAVING
B.id = B.id) AS I"), 'B.id', '=', 'I.id_baralho')
->join(DB::raw("(SELECT
id_baralho,
ALVO.nome,
ALVO.vulgo,
ALVO.rg,
ALVO.sexo
FROM
baralho_has_baralho_alvo
INNER JOIN baralho B ON
baralho_has_baralho_alvo.id_baralho = B.id
INNER JOIN baralho_alvos ALVO ON
baralho_has_baralho_alvo.id_baralho_alvo = ALVO.id_alvo
GROUP BY
B.id
HAVING
B.id = B.id) AS A"), 'B.id', '=', 'A.id_baralho')
->orderBy('B.id', 'ASC')
->get();