首页 > 技术文章 > 关于mysql插入数据异常

lesliehe 2017-12-03 11:25 原文

今天创建数据库时,在插入数据时出现了几个问题。(首次在LInux环境下创建数据库)

一个是关于SQL Error [1146] [42S02]: Table 'struts2exec.s_user' doesn't exist

网上搜查到的帖子如下:

  项目在开发的时候在WINDOWS平台下开发的,开发完了之后在LINUX环境上部署好之后,运行时MySQL数据库报错,提示为某个表不存在之类的错误信息,后来修改了MySQL的配置文件将大小写敏感去掉,问题解决。 

编辑/etc/my.cnf文件,在[mysqld]节下 添加 lower_case_table_names=1 参数,并设置相应的值 (备注:为0时大小写敏感,为1时大小写不敏感,默认为0)。 

编辑MySQL安装目录下的my.ini文件,在[mysqld]节下 添加 lower_case_table_names=1(备注:为0时大小写敏感,为1时大小写不敏感,默认为1),可以实现MySql按照建表Sql语句的大小写状态来定义表名。

在 MySQL 中,数据库和表其实就是数据目录下的目录和文件,因而,操作系统的敏感性决定数据库和表命名的大小写敏感。这就意味着数据库和表名在 Windows 中是大小写不敏感的,而在大多数类型的 Unix/Linux 系统中是大小写敏感的。 

但是按照教程在my.cnf下并没有mysqld,于是只好在插入数据时严格区分大小写。

另一个则是关于SQL Error [1054] [42S22]: Unknown column 'xxx' in 'field list

很显然,这是编码问题,解决方案如下:

修改表的编码格式

ALTER TABLE `table` DEFAULT CHARACTER SET utf8;

但是虽然修改了表的编码格式,但是字段的编码格式并没有修改过来,又发现一条语句,作用是修改字段的编码格式:

ALTER TABLE `tablename` CHANGE `字段名1` `字段名2` VARCHAR(36) CHARACTER SET utf8 NOT NULL; 

但是一次只能修改一个字段,还是很麻烦,不方便,最后找到这么一条语句,可以修改整张表的字段:

alter table `tablename` convert to character set utf8;

 

推荐阅读