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

学生个人网站设计推广渠道

学生个人网站设计,推广渠道,c 类似wordpress,四川建设网评标专家库目录 1.问题发现 2.ONLY_FULL_GROUP_BY模式 2.1. 严格模式 (ONLY_FULL_GROUP_BY 启用,MySQL 5.7.5 默认) 2.2 宽松模式 (ONLY_FULL_GROUP_BY 禁用,旧版本默认) 3. 如何避免问题? 方案 1:严格模式 正确使用 GROUP BY 方案…

目录

1.问题发现

2.ONLY_FULL_GROUP_BY模式

2.1. 严格模式 (ONLY_FULL_GROUP_BY 启用,MySQL 5.7.5+ 默认)

2.2 宽松模式 (ONLY_FULL_GROUP_BY 禁用,旧版本默认) 

3. 如何避免问题? 

方案 1:严格模式 + 正确使用 GROUP BY

方案 2:使用聚合函数明确处理非聚合列

方案 3:临时禁用严格模式(不推荐)

4.总结


1.问题发现

        项目使用的mysql数据库,换高版本数据库后发现好多查询sql报错。什么情况,以前不是挺稳定。追踪dao sql查看后发现有很多sql的非聚合列未出现在group by中,这多sql有问题。但是之前好像没有问题,隐约记得mysql查询可以非聚合列不放在group by中。查了资料后原来是mysql8.0默认开启了ONLY_FULL_GROUP_BY模式。

2.ONLY_FULL_GROUP_BY模式

2.1. 严格模式 (ONLY_FULL_GROUP_BY 启用,MySQL 5.7.5+ 默认)

  • 会直接报错(错误代码 1055

  • 错误信息类似:

ERROR 1055 (42000): Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 'db.table.column' which is not functionally dependent on columns in GROUP BY clause; this is incompatible with sql_mode=only_full_group_by
  • 必须将所有非聚合列都包含在 GROUP BY 中,或者用聚合函数处理它们。

2.2 宽松模式 (ONLY_FULL_GROUP_BY 禁用,旧版本默认) 

MySQL 会从每个分组中任意选择一个值返回,但不保证确定性:

  • 可能是该分组的第一条记录的值

  • 也可能是最后一条、随机一条,取决于存储引擎和查询执行计划

  • 多次执行同一查询可能返回不同的值(数据不稳定)

示例:

假设有一张表 orders

SELECT customer_id, order_date,  -- 不在 GROUP BY 中,且每个 customer_id 有多个 order_dateSUM(amount) 
FROM orders 
GROUP BY customer_id;

在宽松模式下:

  • 对于每个 customer_idorder_date 的值是不确定的(可能是该客户最早/最晚/某次订单的日期)

  • 查询结果不可靠,可能误导业务逻辑。

3. 如何避免问题? 

方案 1:严格模式 + 正确使用 GROUP BY

-- 包含所有非聚合列
SELECT customer_id, order_date, SUM(amount)
FROM orders
GROUP BY customer_id, order_date;

方案 2:使用聚合函数明确处理非聚合列

-- 用 MAX/MIN/GROUP_CONCAT 等聚合函数
SELECT customer_id, MAX(order_date) AS latest_order_date,SUM(amount)
FROM orders
GROUP BY customer_id;

方案 3:临时禁用严格模式(不推荐)

SET SESSION sql_mode = '';  -- 关闭 ONLY_FULL_GROUP_BY

4.总结

模式行为可靠性建议
严格模式直接报错✅ 推荐,强制写出明确查询
宽松模式返回任意值❌ 避免使用,结果不可预测

最佳实践:始终启用 ONLY_FULL_GROUP_BY,并确保查询逻辑明确。

http://www.wangmingla.cn/news/166834.html

相关文章:

  • 怎么做百度采购网站西安外包网络推广
  • 辽阳企业网站建设价格上海百度推广公司排名
  • 接网站建设单子注意事项企业营销推广怎么做
  • 长沙网站建设工作室线上推广网络公司
  • 做房地产要自己开网站推广赚钱一个2元
  • 浙江英文网站建设百度推广一般多少钱
  • 用jsp做的购物网站网页制作html代码
  • 百度推广 网站建设网络推广常见的方法
  • 企业网站建设设计方案做网站的平台
  • 郑州做网站的大公司现在最火的发帖平台
  • 十堰做网站公司快速开发平台
  • wordpress page显示seo学院
  • 为什么要用php做网站建网站需要多少钱和什么条件
  • 下载国际新闻app软件网站seo排名优化工具在线
  • 培训建设网站谷歌浏览器下载手机版安卓官网
  • 网站推广到海外怎么做百度搜索app
  • 哪个网站可以做思维导图北京seo营销公司
  • 答题做任务网站百度问答首页
  • 易语言如何做验证系统官方网站河源今日头条新闻最新
  • java做网站需要哪些技术百度推广竞价是什么意思
  • 做网站遇到各种问题必应收录提交入口
  • 台州路桥做网站的公司贵阳网站建设公司
  • 公司门户网站该怎么做培训网址
  • 一品威客做网站靠谱吗如何免费开自己的网站
  • seo做的比较好的网站的几个特征360搜索建站
  • 广州响应式网站建设seo的特点是什么
  • 公司网站开发实例指数平滑法
  • 佛山网站建设百家号sem竞价推广托管
  • 万网怎样做网站调试优化seo教程
  • asp网站开发环境抖音流量推广神器软件