- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
目前,我正在将所有 Delphi 2007 代码库更新为 Delphi XE2。最大的考虑因素是 ANSI 到 Unicode 的转换,我们通过将所有基本类型(char/string)重新定义为 ANSI 类型(ansichar/ansistring)来处理这个问题。这在我们的许多程序中都有效,直到我开始使用数据库。
当我将从文件读取的信息存储到 SQL Server 2008 数据库中的程序转换时,问题就出现了。使用字符串来定位数据的简单查询突然会失败,例如:
SELECT id FROM table WHERE name = 'something'
name
字段是 varchar
。我发现通过在字符串名称前加上 N
可以成功完成查询。 。我的印象是varchar
只能存储 ANSI 字符,但它似乎存储 Unicode?
更多信息:Delphi 中的名称字段为 string[13]
,但我尝试删除 [13]
。数据库排序规则为SQL_Latin1_General_CP1_CI_AS
。我们使用ADO 与数据库进行交互。连接信息存储在 ODBC 管理器中。
注意:由于 Panagiotis 的一些指导,我已经解决了我的实际问题。我们从 map 文件中读取的名称是 array[1..24] of AnsiChar
。该值被隐式转换为 string[13]
,其中包含空字符。因此,具有 5 个字符的名称实际上在数据库中存储为 5 个字符 + 8 个空字符。
最佳答案
varchar 字段不存储 Unicode 字符。它们将 ASCII 值存储在由字段排序规则指定的代码页中。 SQL Server 将 try to convert characters当您尝试存储 Unicode 或来自不同代码页的数据时,转换为正确的代码页。您可以禁用此功能,但最好的选择是在应用程序中使用 nvarchar 字段和 UnicodeString 来避免整个困惑。
您提到您将应用程序中的所有字符类型更改为 ANSI,而不是 UNICODE 类型。如果您想使用 UNICODE,您应该使用 UNICODE 类型,例如 UnicodeString。否则,当您的值发送到您的服务器时,它们将被转换为 ANSI。当您创建发送到服务器的 AnsiString 时,此转换由您的代码完成。
顺便说一句,您的 select 语句在字段中存储 ASCII 值。如果要将其存储为 unicode 值,则必须在该值前面添加 N,例如
SELECT id FROM table WHERE name = N'something'
即使这样也不能保证您的数据将以 Unicode 形式到达服务器。如果将语句存储在 AnsiString 中,则整个语句将在发送到服务器之前转换为 ANSI。如果您的应用进行了错误的转换,您最终将在服务器上得到损坏的数据。
解决方案非常简单,只需使用参数化语句将 unicode 值作为 unicode 参数传递,并将其存储在 NVarchar 字段中即可。它速度更快,避免所有转换错误并防止 SQL 注入(inject)攻击。
关于sql-server - Unicode 转换、数据库问题(Delphi 2007 到 XE2),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/10551535/
我正在构建一个使用 Oracle 数据库 10g 作为数据库后端的 Web 应用程序。我意识到 Express 版本有限制,但我只是想确保连接数不是其中之一。 Oracle 快捷版 (XE) 是否限制
我是一名开始使用 Oracle 数据库的新手,在将 Oracle XE 11g x64 的最新版本安装到 Microsoft Windows 7 x64 Enterprise 时遇到了问题。 安装过程
我有一个 USB 连接到 device发出串行信息。当我运行下面的 Python 脚本(在 Jupyter Notebook 中)时,我从中得到了奇怪的信息。 import serial ser =
我们有一台运行 Delphi XE Professional 的机器,它会在 IDE 中键入时更改某些键的值。它将字母和数字键更改为数字。按下下一个键将按顺序输入下一个数字,直到 9,然后从 0 重新
从昨天开始,我的源代码中的所有蓝点(编译行)都移动了一行。因此,第一个点从“var”而不是“begin”开始,最后一个点是函数最后一个“end”之前的一行。 我删除了除 DPR、PAS、DFM 和 D
我在 RegexBuddy 中构建了一个匹配模式,其行为完全符合我的预期。但我无法将其转移到 Delphi XE,至少在使用最新内置的 TRegEx 或 TPerlRegEx 时是这样。 我的现实世界
TBytes 变量的正确使用模式是什么?根据我的理解,TBytes不是一个类,而是一个“动态字节数组”。我不确定内存在哪里分配,何时释放,以及将其从生产者传递到消费者的最佳方式是什么。我希望我的生产者
我创建了一个自定义 MSBuild .targets我通过 IDE 将其包含在 Delphi XE 项目中,并从项目管理器的上下文菜单中启用它。尽管文件有效,但在我重新保存项目文件后它总是被禁用。 这
有谁知道 http://reportman.sourceforge.net/可用于 Delphi XE 吗? 最佳答案 我已经成功获得Reportmanager 2.9b通过将以下行添加到文件 rpc
Oracle XE Oracle是这样介绍XE的:11g XE(Express Edition)简化版是在Oracle11gR2基础之上一个入门级的小体量数据库,免费用于开发/部署与发布,下载很快
我已经安装了 docker 在 Ubuntu 21.10 并跟随官方 instructions 我拉甲骨文 11g xe 图片:docker pull oracleinanutshell/oracle
一段时间以来,我一直在寻找解决问题的方法,但似乎没有任何效果,这是我重新安装之前的最后一次尝试。 我今天通过其安装向导安装了 Oracle XE 11g 第 2 版,并且一切顺利。我似乎遇到的麻烦是我
我需要模拟汽车在平方区域上移动(比方说)。 任何人都可以轻松想象计算(x/y 坐标、轨迹、速度、加速度、暂停......) 之前的版本(跨千年错误开发...... 21 年前)运行到 Applicat
我已经下载了适用于 Windows 64 位的 Oracle XE 18c,并尝试将其安装在 Windows 10 机器上。我检查了 SHA-256 校验和,它是正确的。 安装开始正常,但是当它复制新
我需要通过客户端操作删除服务器上的物理文件,然后将文件删除事件通知远程数据库-希望这完全在serverSide上发生。 更高版本的Delphi公开了许多以前在WinAPI调用中被锁定的目录服务。目前,
这几年来我一直没有使用Delphi(我使用的最新版本是D2005),现在我需要在DelphiXE中做一些工作。我的问题是,如何在Delphi IDE中禁用声明包装?目前,我使用Modelmaker的代
如何打开应用程序初始化所在的程序单元?我需要进行一些更改。 另外,除了显示的当前单位以外,还可以在程序中搜索所有单位吗? Delphi 5有一个弹出窗口,您可以选择它。 最佳答案 每个项目均由sing
如何配置Datasnap REST服务器(在Windows上作为服务运行)以处理Delphi XE中的https调用?周围有什么好的例子吗? 向上的Delphi XE2似乎具有其他组件-这是否意味着X
我尝试以这种方式列出程序: type TProc = procedure of object; TMyClass=class private fList:Tlist; function getItem
我刚刚发现了 Delphi 的实时绑定(bind)。并创建了我的第一个组件来处理变频器的控制字。该组件本身似乎在表单设计器中测试它效果很好。但是,编译和运行应用程序不起作用。来自 livbinding
我是一名优秀的程序员,十分优秀!