T-SQL округлые до десятичных знаков
Как объединить результат matchpercent с двумя десятичными знаками (%)?
Для получения некоторых результатов я использую следующее:
DECLARE @topRank int
set @topRank=(SELECT MAX(RANK) FROM
FREETEXTTABLE(titles, notes, 'recipe cuisine', 1))
SELECT
ftt.RANK,
(CAST(ftt.RANK as DECIMAL)/@topRank) as matchpercent, --Round this
titles.title_id,
titles.title
FROM Titles
INNER JOIN
FREETEXTTABLE(titles, notes, 'recipe cuisine') as ftt
ON
ftt.[KEY]=titles.title_id
ORDER BY ftt.RANK DESC
Ответы
Ответ 1
CAST/CONVERT:
CAST((CAST(ftt.RANK as DECIMAL)/@topRank) AS DECIMAL(n,2)) as matchpercent,
... где n
- это число, достаточно большое, чтобы не усекать слева от десятичной точки. То есть, если вы используете "123.456", вам нужно использовать DECIMAL (7,2), потому что общая длина составляет 7 цифр.