遇到一个不能为NULL的报错,一个类型为text的字段MYSQL(5.7.38-log - Source distribution)报错mysql #1101 - BLOB, TEXT, GEOMETRY or JSON column 'grading' can't have a default value彻底解决方法通过修改MySQL的配置文件,如果有sql-model就直接修改成:sql-mode=NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION,如果没有则在[mysqld]下加上这句话,之后重启mysql。临时解决方法 set sql-mode=NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION (只对当前连接有效)Strict SQL Mode作用 :不为null的字段不能写入null数据。text字段没有默认值自增长的字段不能自定义值参考文章 >>>
select length(col) from table1; # 字节长度 select char_length(col) from table1; # 字符数量
查询语句分组时,where 语句中不能包含 聚组函数,否则会提示Invalid use of group functionInvalid use of group function即“集函数的无效用法”错句示例:SELECT sname AS '优秀学生姓名',AVG(score) as '平均成绩' FROM grade_info WHERE AVG(score)>90 GROUP BY sno;正确写法:SELECT sname AS '优秀学生姓名',AVG(score) as '平均成绩' FROM grade_info GROUP BY sno HAVING AVG(score) > 90 ;GROUP BY,顾名思义:根据...分组,在SQL中常根据指定字段分组(指定字段内容相同是为一组),然后针对组进行相关操作WHERE和HAVING的区别在于:where 子句的作用是对查询结果进行分组前,将不符合where条件的行去掉,即在分组之前过滤数据,where条件中不能包含聚组函数,使用where条件过滤出特定的行。having 子句的作用是筛选满足条件的组,即在分
UPDATE table_name SET col_name1 = REPLACE( col_name2, 'from', 'to' );
phpmyadmin mysql ddl 设置 auto_increment 再设置默认值 ,auto_increment 失效解决方法:去掉默认值
风里来
最后,我终于解放了我自己……