O seguinte MWE (emprestado deResposta do @Celdor}, onde é usada tabular
a tabela, funciona bem:
\documentclass{article}
\usepackage{array}
\usepackage{xcolor}
\usepackage{listings}
\lstset{language=sql,
keywordstyle=\color{black!30!blue}\bfseries,
columns=flexible,
}
\begin{document}
\noindent\begin{tabular}{w{l}{11cm}|c}
\begin{lstlisting}
SELECT SUM(lo_extendedprice*lo_discount) AS revenue
FROM lineorder, dwdate
WHERE d_yearmonthnum = 199401
AND lo_orderdate = d_datekey
AND lo_discount BETWEEN 4
AND 6 AND lo_quantity
BETWEEN 26 AND 35;
\end{lstlisting} & 1 \\
\end{tabular}
\end{document}
Enquanto isso, sua transformação para usar o tblr
pacote, mesmo com option verb
, não:
\documentclass{article}
\usepackage{tabularray}
\usepackage{xcolor}
\usepackage{listings}
\lstset{language=sql,
keywordstyle=\color{black!30!blue}\bfseries,
columns=flexible,
}
\begin{document}
\noindent\begin{tblr}{colspec = {X[j,m] | c},
rowsep=3pt,
verb}
\begin{lstlisting}
SELECT SUM(lo_extendedprice*lo_discount) AS revenue
FROM lineorder, dwdate
WHERE d_yearmonthnum = 199401
AND lo_orderdate = d_datekey
AND lo_discount BETWEEN 4
AND 6 AND lo_quantity
BETWEEN 26 AND 35;
\end{lstlisting} & 1 \\
\end{tblr}
\end{document}
A compilação acima do MWE gera os seguintes avisos:
Package Listings Warning: Text dropped after begin of listing on input line 1.
! Missing } inserted.
<inserted text>
}
l.25 \end
{tblr}
?
e não produzir nada. Simplifiquei demais a inserção de lstlisting
código ou tabularray
ainda não oferece suporte para isso?
Nesta questão você pode olhar como pergunta de acompanhamento paraErro com `listings` e `tabularray` usados juntos
Responder1
Aqui está uma solução alternativa usando filecontents*
:
\documentclass{article}
\usepackage{tabularray}
\usepackage{xcolor}
\usepackage{listings}
\lstset{
language=sql,
keywordstyle=\color{black!30!blue}\bfseries,
columns=flexible,
}
\begin{document}
\begin{filecontents*}[force]{\jobname-sql.tex}
SELECT SUM(lo_extendedprice*lo_discount) AS revenue
FROM lineorder, dwdate
WHERE d_yearmonthnum = 199401
AND lo_orderdate = d_datekey
AND lo_discount BETWEEN 4
AND 6 AND lo_quantity
BETWEEN 26 AND 35;
\end{filecontents*}
\noindent\begin{tblr}{colspec = {X[j,m] | c},
rowsep=3pt,
verb}
\lstinputlisting{\jobname-sql.tex} & 1 \\
\end{tblr}
\end{document}