Ibatis中#和$的区别
2012-02-29 14:33
225 查看
昨天一个项目中在写ibatis中的sql语句时,order
by #field#, 运行时总是报错,后来上网查了查,才知道这里不该用#,而应该用$,随即查了下#与$的区别.
总结如下:
1.#是把传入的数据当作字符串,如#field#传入的是id,则sql语句生成是这样,order by "id",这当然会报错..
2.$传入的数据直接生成在sql里,如#field#传入的是id,则sql语句生成是这样,order by id, 这就对了.
3.#方式能够很大程度防止sql注入.
4.$方式无法方式sql注入.
5.$方式一般用于传入数据库对象.例如传入表名.
6.一般能用#的就别用$.
就这么多了.
by #field#, 运行时总是报错,后来上网查了查,才知道这里不该用#,而应该用$,随即查了下#与$的区别.
总结如下:
1.#是把传入的数据当作字符串,如#field#传入的是id,则sql语句生成是这样,order by "id",这当然会报错..
2.$传入的数据直接生成在sql里,如#field#传入的是id,则sql语句生成是这样,order by id, 这就对了.
3.#方式能够很大程度防止sql注入.
4.$方式无法方式sql注入.
5.$方式一般用于传入数据库对象.例如传入表名.
6.一般能用#的就别用$.
就这么多了.
相关文章推荐
- spring中ibatis 关于数据库的配置$个#的区别
- ibatis 到 MyBatis区别
- iBatis 向 MyBatis 移植( iBatis 向 MyBatis 区别)
- ibatis的$param$与#param#的区别
- hibernate和ibatis的区别
- ibatis与hibernate有什么区别啊?
- Hibernate VS MyBatis 区别 Hibernate3和MyBatis(iBatis)的执行效率比较
- iBatis 到 MyBatis区别
- ibatis中#和$用法区别
- ibatis #跟$的区别
- MyBatis/Ibatis中#和$的区别
- hibernate、ibatis、jdbc 三者之间的区别
- Hibernate和Ibatis区别
- ibatis中isnotempty和isnotnull的区别
- IBatis和Hibernate区别
- Hibernate和MyBatis(ibatis)的区别
- ibatis $与#的区别和使用
- MyBatis/Ibatis中#和$的区别
- ibatis 中 $与#的区别
- ibatis中$与#的区别