3

我需要对 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?

4

1 回答 1

0

Paradox 在 DOS 和 Windows 产品中有多个版本。但是大多数或所有这些都在该系统中使用带有“代码页”的 ascii 编码。您可能会得到正确的记录。但我不确定如何以 Unicode 显示它。我认为 Unicode 在显示获得的数据时出现问题。我认为您必须了解最初存储数据时使用的代码页。Paradox 可能将此称为排序顺序,至少在某些版本中,它是由 Paradox.sor 表定义的。

于 2013-05-16T12:56:50.617 回答