备忘: $与#, <![cdata[ ]]>

本文介绍了MyBatis中#与$符号的区别及其应用场景。#符号可以进行预编译并进行类型匹配,有效防止SQL注入;$符号则进行字符串拼接,适用于非变量部分。此外还介绍了XML中CDATA的用法。
[b]1. $ 与 #[/b]
在ibatis/MyBatis中我们使用SqlMap进行Sql查询时需要引用参数,在参数引用中遇到的符号#和$之间的区分为,#可以进行预编译,进行类型匹配,而$不进行数据类型匹配,直接当做字符串拼接,所以要注意sql注入风险。

$ 的作用实际上是字符串拼接,
select * from $tableName$
等效于
StringBuffer sb = new StringBuffer(256);
sb.append("select * from ").append(tableName);
sb.toString();

#用于变量替换
select * from table where id = #id#
等效于
prepareStement = stmt.createPrepareStement("select * from table where id = ?")
prepareStement.setString(1,'abc');

对于变量部分, 应当使用#, 这样可以有效的防止sql注入, 未来,# 都是用到了prepareStement,这样对效率也有一定的提升;
$只是简单的字符拼接而已,对于非变量部分, 那只能使用$, 实际上, 在很多场合,$也是有很多实际意义的
例如:
select * from $tableName$ 对于不同的表执行统一的查询。

还可以参考: [url]http://developer.51cto.com/art/200907/138063.htm[/url]


[b]2. <![cdata[ ]]>[/b]
实际上这是xml的用法,因为mybatis中经常见到,所以也放在这里说明。
在xml中'<'和'&'是特殊字符,需要特殊处理,包含在<![cdata[ ]]>中即可。
<think>好的,我现在需要帮助用户解决XML文件中数据格式不正确的问题,特别是处理无效标签和嵌套错误。首先,我需要了解用户提供的示例XML结构,找出其中的问题。 首先,看看用户提供的XML示例: <DefectMarkRoots> <Color><![CDATA[ 255,0,255,0 ]]></Color> <DefectMarks> <DefectMark> <Graphic><![CDATA[ 1]]></Graphic> <pointsPreArr> <X><![CDATA[ 0.3985969]]></X> <Y><![CDATA[ 0.3061225]]></Y> </pointsPreArr> <pointsPreArr> <X><![CDATA[ 0.6186224]]></X> <Y><![CDATA[ 0.3903061]]></Y> </pointsPreArr> </DefectMark> </DefectMarks> </DefectMarkRoots> 用户提到存在无效标签如“残墙、贝根”,但在示例中并没有出现这些标签,可能是在实际文件中有这些错误。因此,我需要先检查示例中的结构问题。例如,是否有标签嵌套错误,或者标签名称不符合规范。 观察示例结构,发现: 1. <pointsPreArr>作为子元素出现在<DefectMark>下,但可能存在重复标签的问题。例如,是否有多个<pointsPreArr>需要被正确包裹在一个父标签中? 2. XML标签名称通常使用英文,而用户提到的“残墙、贝根”可能是中文标签,这不符合XML标准,需要替换为英文。 3. 需要确保所有标签正确闭合,并且嵌套层次正确。 接下来,考虑如何修正这些问题。首先,替换无效的中文标签为合法的英文标签名。例如,如果“残墙”对应某个缺陷类型,可以改为<DamagedWall>,而“贝根”可能是一个拼写错误,需要用户确认正确名称。 然后检查嵌套结构。在示例中,<DefectMark>包含多个<pointsPreArr>元素,每个包含X和Y坐标。这可能是正确的,但需要确认是否符合DTD或Schema要求。如果没有定义多个pointsPreArr,可能需要将它们包裹在父标签如<PointsArray>中。 此外,需要确保所有标签正确闭合,没有遗漏。例如,示例中的每个标签都有正确的闭合标签,没有明显错误。 接下来,用户可能需要使用XML验证工具,如xmllint,来检查错误。同时,建议用户参考相关文档或SDK中的示例,如引用[1]提到的海思芯片开发中的示例程序结构,这可能帮助用户理解正确的XML格式。 最后,生成相关问题,帮助用户深入理解XML结构验证、工具使用和常见错误处理。</think>### 修正XML文件结构的步骤 #### 1. **处理无效标签** 无效标签(如`残墙`、`贝根`)需替换为符合XML命名规范的英文标签。XML标签**必须以字母或下划线开头**,且**禁止使用中文或特殊符号**。例如: ```xml <!-- 错误示例 --> <残墙>...</残墙> <贝根>...</贝根> <!-- 修正示例 --> <DamagedWall>...</DamagedWall> <!-- 假设"残墙"表示破损墙体 --> <RootNode>...</RootNode> <!-- 假设"贝根"是拼写错误 --> ``` #### 2. **修复嵌套错误** 观察示例中`pointsPreArr`的嵌套结构,若需表示多个坐标点,建议使用**统一父标签包裹**: ```xml <!-- 原结构可能导致歧义 --> <pointsPreArr><X>...</X><Y>...</Y></pointsPreArr> <pointsPreArr><X>...</X><Y>...</Y></pointsPreArr> <!-- 修正后 --> <PointGroups> <Point> <X><![CDATA[0.3985969]]></X> <Y><![CDATA[0.3061225]]></Y> </Point> <Point> <X><![CDATA[0.6186224]]></X> <Y><![CDATA[0.3903061]]></Y> </Point> </PointGroups> ``` #### 3. **验证XML语法** 使用工具(如`xmllint`)检查语法: ```bash xmllint --noout your_file.xml # 若无输出则表示无语法错误 ``` #### 4. **参考规范示例** - 若涉及硬件交互(如海思芯片开发),需严格遵循SDK中的XML格式规范[^1]。 - 嵌套层级需业务逻辑匹配,例如`DefectMarkRoots > DefectMarks > DefectMark`的层级关系合理。 #### 修正后的完整示例 ```xml <DefectMarkRoots> <Color><![CDATA[255,0,255,0]]></Color> <DefectMarks> <DefectMark> <Graphic><![CDATA[1]]></Graphic> <PointGroups> <Point> <X><![CDATA[0.3985969]]></X> <Y><![CDATA[0.3061225]]></Y> </Point> <Point> <X><![CDATA[0.6186224]]></X> <Y><![CDATA[0.3903061]]></Y> </Point> </PointGroups> </DefectMark> </DefectMarks> </DefectMarkRoots> ``` ---
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值