I create datagridview with unicode column like:
private void GetUnicodeFormat()
{
string unicodeString = "\u2605";
OneStar = unicodeString;
TwoStar = unicodeString + unicodeString;
ThreeStar = unicodeString + unicodeString + unicodeString;
FourStar = unicodeString + unicodeString + unicodeString + unicodeString;
FiveStar = unicodeString + unicodeString + unicodeString + unicodeString + unicodeString;
}
Then I set it in datagridview like:
foreach (DataGridViewRow row in dgvProjectRanking.Rows)
{
var cellNumberValue = int.Parse(row.Cells[contractedColumnIndex].Value.ToString());
if (cellNumberValue <= 20)
{
row.Cells[scoreColumnIndex].Value = OneStar;
}
else if (cellNumberValue > 20 && cellNumberValue < 40)
{
row.Cells[scoreColumnIndex].Value = TwoStar;
}
else if (cellNumberValue >= 40 && cellNumberValue < 60)
{
row.Cells[scoreColumnIndex].Value = ThreeStar;
}
else if (cellNumberValue >= 60 && cellNumberValue < 80)
{
row.Cells[scoreColumnIndex].Value = FourStar;
}
else if (cellNumberValue >= 80 && cellNumberValue <= 100)
{
row.Cells[scoreColumnIndex].Value = FiveStar;
}
}
This works, I get stars in DataGridView. But now instead do this I want to send values via SQL so I create function in sql like:
CREATE FUNCTION [HELPER].[udf_ProjectContractedPercentage_Set]
(
@ProjectContractedPercentage INT
)
RETURNS VARCHAR(MAX)
AS
BEGIN
DECLARE @NewProjectContractedPercentage VARCHAR(MAX)
,@StarUnicode VARCHAR(10) = '\u2605';
SELECT
@NewProjectContractedPercentage = (CASE
WHEN @ProjectContractedPercentage <= 20
THEN @StarUnicode
WHEN @ProjectContractedPercentage > 20
AND @ProjectContractedPercentage < 40
THEN CONCAT(@StarUnicode , @StarUnicode)
WHEN @ProjectContractedPercentage >= 40
AND @ProjectContractedPercentage < 60
THEN CONCAT(@StarUnicode , @StarUnicode , @StarUnicode)
WHEN @ProjectContractedPercentage >= 60
AND @ProjectContractedPercentage < 80
THEN CONCAT(@StarUnicode , @StarUnicode , @StarUnicode , @StarUnicode )
WHEN @ProjectContractedPercentage >= 80
AND @ProjectContractedPercentage <= 100
THEN CONCAT(@StarUnicode , @StarUnicode , @StarUnicode , @StarUnicode , @StarUnicode)
END)
RETURN
@NewProjectContractedPercentage
END
So I receive values like:
What I need to do in c# to convert this value in stars?, I don't know what is the difference if I have unicode value in c# code or receiving from stored procedure. I think it's exactly the same but is not working so I don't have an idea why not. Help is very appreciated!