No UNE la asignación de @col con tus otras consultas.
Tenga una consulta para asignar un valor a @col y una consulta separada para incluir ese registro en sus resultados.
SELECT @col := col AS col -- Fetch particular record given a value of
FROM tbl -- "col", assigning the identifier to @col.
WHERE col = 'd'
SELECT col -- Now include the above record in the
FROM tbl -- Final result-set
WHERE col = @col
UNION ALL
SELECT col -- Fetch the immediately preceding record,
FROM ( SELECT col -- ordered by "col"
FROM tbl
WHERE col < @col
ORDER BY col DESC
LIMIT 1) preceding
UNION ALL
SELECT col -- Fetch the immediately following record,
FROM ( SELECT col -- ordered by "col"
FROM tbl
WHERE col > @col
ORDER BY col ASC
LIMIT 1) following
ORDER BY col ASC;