在SELECT子句中写入了聚合函数和GROUP BY子句以外的其他内容没有报错

在SELECT子句中写入了聚合函数和GROUP BY子句以外的其他内容没有报错


刚刚试了一下,在SELECT子句中写入了聚合函数和GROUP BY子句以外的其他内容运行了一下居然可以,虽然内容没有意义,但是为什么没有报错呢
http://img1.sycdn.imooc.com//climg/5fd9a76c09102af306640282.jpg


在这里输入代码,可通过选择【代码语言】突出显示

正在回答

登陆购买课程后可参与讨论,去登陆

1回答

同学你好,1. 老师在严格模式下测试,会直接报错。如下图所示:

http://img1.sycdn.imooc.com//climg/5fbf1b2309d3bf7106530138.jpg

而老师在非严格模式下进行测试,就可以直接查询数据,如下图所示:


http://img1.sycdn.imooc.com//climg/5fbf1b880960d3f805890167.jpg

2. 可能同学的MySQL是非严格模式,所以可以正常进行查询。同学想要设置为严格模式,则可以修改my.ini文件的sql_mode(如果没有,则添加上就可以了)。如下所示:

sql_mode = 'STRICT_TRANS_TABLES'  ; 或者配置成 STRICT_ALL_TABLES

非严格模式,设置为

sql-mode="NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES"

然后重启MySQL试一下。

  • 慕前端1399731 提问者 #1

    好的,谢谢。严格模式和非严格模式主要应用于什么情况呢

    2020-12-16 15:21:44
  • 迎接晨曦 回复 提问者 慕前端1399731 #2

    同学你好,1. 在MySQL集群中(在多个服务器部署),肯定是要统一MySQL的执行模式为严格模式,要不然有的MySQL节点能执行SQL,有节点不能执行这条SQL,单节点MySQL(在一个服务器中部署)用严格模式还是宽松模式无所谓。

    2. 关于MySQL集群同学可查看https://www.imooc.com/article/277999 进行了解。

    注:现阶段同学知道即可,可以在有一定基础后进行学习,更便于同学理解哦~

    祝学习愉快!

    2020-12-16 16:57:38
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星

相似问题

登录后可查看更多问答,登录/注册

计算机基础课
  • 参与学习       244    人
  • 解答问题       162    个

1000位程序员+大厂HR联袂推荐,面向所有程序员的计算机核心知识体系,优惠中~

了解课程
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师