当前位置:首页 » 编程语言 » mybatis的动态sql

mybatis的动态sql

发布时间: 2023-10-10 06:58:45

⑴ mybatis 中 #{} 和 ${} 的区别及应用场景

动态 sql 是 mybatis 的主要特性之一,在 mapper 中定义的参数传到 xml 中之后,在查询之前 mybatis 会对其进行动态解析。

mybatis 为我们提供了两种支持动态 sql 的语法:#{} 以及 ${} 。

如: #{} : 根据参数的 类型 进行处理,比如传入String类型,则会为参数加上双引号。#{} 传参在进行SQL预编译时,会把参数部分用一个占位符 ? 代替,这样可以防止 SQL注入。

如: ${} : 将参数取出不做任何处理,直接放入语句中,就是简单的字符串替换,并且该参数会参加SQL的预编译,需要手动过滤参数防止 SQL注入。

因此 mybatis 中优先使用 #{};当需要动态传入 表名或列名 时,再考虑使用 ${} 。

正确的写法应该是使用 ${order_by},这样解析后就是一个列名,然后才能对数据进行排序,已达到业务需求。

⑵ mybatis中动态sql执行原理

解释器模式: 初始化过程中构建出抽象语法树,请求处理时根据参数对象解释语法树,生成sql语句。
工厂模式: 为动态标签的处理方式创建工厂类(SqlTagHandlerFactory),根据标签名称获取对应的处理方式。
策略模式: 将动态标签段销明处理方式抽象为接口,针对不同标签有相应的握告实现类。解释抽象语法树斗含时,定义统一的解释流程,再调用标签对应的处理方式完成解释中的各个子环节

热点内容
阿里云服务器镜像市场 发布:2025-02-01 09:46:04 浏览:524
任子行服务器管理口默认地址 发布:2025-02-01 09:42:58 浏览:995
设备作为FTP客户端时 发布:2025-02-01 09:35:07 浏览:935
安卓如何登录ios明日之后 发布:2025-02-01 09:31:59 浏览:305
怎么查看手机存储卡 发布:2025-02-01 09:31:51 浏览:340
java知识点总结 发布:2025-02-01 09:08:32 浏览:684
如何在手机版给服务器加光影 发布:2025-02-01 09:02:14 浏览:727
简单神器安卓系统的哪个好 发布:2025-02-01 09:00:48 浏览:354
社保卡密码如何异地改密码 发布:2025-02-01 08:57:22 浏览:33
什么安卓平板最好能开120帧 发布:2025-02-01 08:55:58 浏览:380