利用sqlacodegen自动生成ORM实体类

今天在使用group_by时遇到错误,大概是以下样子:

(cymysql.err.InternalError) (1055, "Expression #2 of SELECT list is not in GROUP BY clause and contains nonaggregated column 
[SQL]CREATETABLE`m_part`(`f_id`INTNOTNULL,`f_name`VARCHAR(20)NULL,PRIMARYKEY(`f_id`))ENGINE=myisamDEFAULTCHARSET=utf8PARTITIONBYRANGE(f_id)(PARTITIONp0VALUESlessTHAN(10),PARTITIONp1VALUESlessTHAN(20))

原因: mysql5.7.5版本开始,sql_mode使用的是默认值( 如上),而之前使用的mysql配置文件中sql_mode=”“,由于这个特性使在使用group_by时出现报错

linux下解决方案:

修改mysql.conf

sudo vim /etc/mysql/mysql.conf.d/mysql.conf

然后将 sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 添加至文件末尾

重启服务: /etc/init.d/mysql restart

问题解决