我需要对 Paradox 数据库执行查询。有一个表,其中包含带有西里尔字母的数据,我正在尝试在这样的查询中使用西里尔字母参数:
select *
from AccessZone zn
where zn.Name= 'Территория'
在 AccessZone 表中,我有名称为“Территория”的记录,但此查询返回 0 行。
我将此查询编码为 windows-1252 编码,但结果相同。
当我得到一个包含西里尔值的查询结果时,我已经破坏了像'??????'这样的符号,所以,我从 windows-1252 解码它们,然后得到正确的值。我决定在使用西里尔符号执行查询时使用这个技巧,但它不影响结果,我仍然有 0 行。
我正在使用 c# 进行编码,如下所示:
private static string DecodeTo1252(string source)
{
Encoding srcEncodingFormat = Encoding.Unicode;
Encoding dstEncodingFormat = Encoding.GetEncoding("windows-1252");
try
{
byte[] output = Encoding.Convert(srcEncodingFormat,
dstEncodingFormat,
srcEncodingFormat.GetBytes(source));
return dstEncodingFormat.GetString(output);
}
catch (Exception)
{
}
return string.Empty;
}
那么,我必须如何构建查询,或对其进行编码以查询 paradox DB?