当前位置: 首页 > news >正文

网站信息安全保障制度建设情况蚌埠网站关键词优化

网站信息安全保障制度建设情况,蚌埠网站关键词优化,房产交易网上预约平台,海外高延迟服务器做网站1: 问题出现的场景 系统中有一个复杂SQL内嵌套了多个子查询.在改动时需要将SQL的最后一行加上having来做额外的过滤处理. 添加完having语句后发现SQL能够正常执行就直接将代码提交到了测试环境.结果在测试环境报错Unknown column ‘xxx‘ in ‘having clause. 2: 分析问题 1…

1: 问题出现的场景

系统中有一个复杂SQL内嵌套了多个子查询.在改动时需要将SQL的最后一行加上having来做额外的过滤处理. 添加完having语句后发现SQL能够正常执行就直接将代码提交到了测试环境.结果在测试环境报错Unknown column ‘xxx‘ in ‘having clause. 

2: 分析问题

1:  经过日志获取SQL发现出现了两条SQL.  其中一条SQL 是  SELECT  count( 0 ) FROM  xxx;

这条sql是  PageHelp插件在开启分页后自动生成的获取总数的语句. 问题就是出现在这条SQL上.

2: 简化后的正常sql如下.

pageHelp生成的sql如下

两者对比就发现. pageHelp生成的sql没有生成最后一个大括号.而是直接用了原sql最后一个大括号来当做结束.这个明显是有问题的.

因为pageHelp正常情况下生成的统计sql会以 ) tmp_count  结尾.

这个时候有读者开始问了. 这个异常sql也能正常执行啊.顶多就是分页数据统计不准确罢了. 

没错.此时sql确实能正常执行. 但是加上having语句后就变了.

加上这条Having后.在执行sql就会发现报错了. 因为mysql此时无法识别该语法了. 这也是为什么我们系统之前用了很长时间都没有出现错误.而加上having后就会报错了. 

3:问题原因及解决办法

此时发现问题根源并不是havging导致的.而是原本就pageHelp插件在复杂的sql情况下原本就存在解析错误.而having只是压断它的最后一根稻草罢了.

发现问题了就该解决问题了.

解决方法: 通过重写mybatis方法来阻止pageHelp生成的sql.

在原sql的id后面加上 _COUNT 就能重写该方法了.

此时在执行分页查询的时候.就不会走pageHelp的SQL,而是重写的这个sql方法了. 问题也就不会出现了

http://www.yayakq.cn/news/256125/

相关文章:

  • 石家庄招聘哪个网站做的好青岛 网站建设
  • 华为公司网站建设方案网络营销运营公司
  • 网站构建的友情链接怎么做万网网站建设特点
  • 昆明seo网站建设费用可拖拽建设网站没有了吗
  • wordpress 404错误青岛优化网站关键词
  • 汕头珠宝网站建设住房和城乡建设厅施工员证
  • 有专业做网站世界杯比分查询
  • 江西网站设计哪家强wordpress togetherjs
  • 个人网站做贷款广告邢台网站网页设计
  • 企业网站怎么做才能留住客户wordpress python代码
  • 威海外贸网站建设联系方式深圳网站制作 公司
  • 秦皇岛 网站建设烟台响应式网站建设
  • 青之峰做网站wordpress建外贸站
  • 怎么登录小程序平台网站是怎么优化的
  • 济南营销网站建设wordpress快速网店主题
  • 怎样建立和设计公司网站网站代理什么意思
  • 山东省城建设计院网站深圳高端做网站公司
  • 做电影网站多少带宽在哪个网站做推广比较好
  • 上海黄金网站设计网站建设关键要做好哪些工作
  • 陕西省住房和城乡建设厅网站上查询余杭住房和城乡建设局网站
  • 山东省住房和建设厅网站诸暨做网站广告的电话
  • 营销类网站设计 要点多媒体网页设计
  • 互联网网站如何做培训计划模板
  • 江安县规划和建设局网站企业网站建设资金预算表
  • 大港油田建设网站wordpress 拍卖主题
  • 手机企业网站建设vs2008 做网站
  • 摄影师网站建设wordpress+论坛+注册
  • 婚纱网站建设 最开始网页微信版传输助手
  • 网站每天一条推送怎么做的网站开发gxjzdrj
  • 复兴区建设局网站东莞保安公司电话