网站首页 > 技术文章 正文
我们一般在Windows系统开发程序并进行功能测试,如果上线的时候选择Windows服务器的话,是什么问题都没有。但是当选择Linux系统的时候,就必须注意Linux系统是严格的区别文字大小。
- Windows系统:不区别英文字母的大小写(Windows文件系统不支持大小写应该是更正确的说法)
- Linux系统:区别英文字母的大小写
从Windows迁移到Linux,突然无法读取数据?
有个在Windows运行稳定的系统,随着Windows2003的技术支持结束,决定迁移到Linux系统。
- 系统:Windows2003(32位)
- Web:Apache
- 程序:PHP
- 数据库:MySQL
这次迁移到Linux系统的原因有2个,一个是Windows2008开始最低配置也需要2核2GB,另外一个是公司里来个一个Linux高手。
系统迁移的一般流程如下。
- 新购一台服务器(推荐使用按量付费的云主机,购买物理机会增加固定资产)
- 在新购的服务器,搭建环境(Apache,PHP,MySQL,FTP…)
- 把现行服务器的数据库数据,导入到新服务器
- 把程序上传到新服务器
- 在新服务器进行功能测试
- 如果功能没有问题的话,再次把现行服务器的数据迁移到新服务器
- 域名解析,就基本大功告成了
在第5个步骤发现无法读取一部分数据。
为什么在Windows能正常运行的程序和数据库,在Linux就会出现问题呢。这时一般会怀疑系统环境的问题,因为程序和数据库是一样的。
然而其实是英文字母大小写导致的结果。
比如在首页调取数据库数据的SQL文如下。
SELECT user_name,id from User;
User表在Windows系统上的Table名为user,因为不区别英文字母大小写所以没问题。
而在Linux会怎么样呢?
迁移过来的Table名是user,而在SQL文里指定的是User表。别忘了这家伙(Linux)区别英文字母大小写,因此会提示该表(User表)不存在。
解决方法
大概有3种解决方法,第一个是修改数据库的Table名,第二个是修改程序,第三个是修改MySQL的参数。
第一和第二,就无需多做说明了,而第三种方法是利用MySQL参数lower_case_table_names。
lower_case_table_names
参数lower_case_table_names是,在MySQL里怎么区别Table英文字母大小的,默认是0。
- 0:区别大小写
- 1:不区别大小写(Table名以小写保存)
- 2:不区别大小写(Table名以原来的大小写保存)
这样一来就简单了,可以让MySQL不区别Table名的大小写。在/etc/my.cnf(yum安装时的默认路径)文件的[mysqld]下面添加lower_case_table_names = 1就可以了。
[mysqld]
...
lower_case_table_names = 1
...
修改MySQL参数之后,重启一下数据库。
猜你喜欢
- 2025-07-08 软件测试报错_tomcat运行代码错误日志及问题解决
- 2025-07-08 数据库系统学习基础篇——(一) 初识MySQL
- 2025-07-08 这些MySQL面试题集锦,据说知名互联网公司都用
- 2025-07-08 MySQL 正则表达式最全介绍(mysql replace正则表达式)
- 2025-07-08 深夜整理!55道BAT高频MySQL灵魂拷问,背完跳槽涨薪不再是梦想!
- 2025-07-08 「MySQL学习」MySQL的变量(mysql设置变量命令)
- 2025-07-08 MySQL-SQL介绍(mysql简单介绍)
- 2025-07-08 MySQL低版本升级操作流程(mysql低版本升级操作流程图)
- 2025-07-08 实战经验:Mysql 字符集及排序规则
- 2025-07-08 MySQL开发规范(mysql开发工具介绍)
- 1509℃桌面软件开发新体验!用 Blazor Hybrid 打造简洁高效的视频处理工具
- 532℃Dify工具使用全场景:dify-sandbox沙盒的原理(源码篇·第2期)
- 495℃MySQL service启动脚本浅析(r12笔记第59天)
- 474℃服务器异常重启,导致mysql启动失败,问题解决过程记录
- 472℃启用MySQL查询缓存(mysql8.0查询缓存)
- 452℃「赵强老师」MySQL的闪回(赵强iso是哪个大学毕业的)
- 431℃mysql服务怎么启动和关闭?(mysql服务怎么启动和关闭)
- 429℃MySQL server PID file could not be found!失败
- 最近发表
- 标签列表
-
- c++中::是什么意思 (83)
- 标签用于 (65)
- 主键只能有一个吗 (66)
- c#console.writeline不显示 (75)
- pythoncase语句 (81)
- es6includes (73)
- windowsscripthost (67)
- apt-getinstall-y (86)
- node_modules怎么生成 (76)
- chromepost (65)
- c++int转char (75)
- static函数和普通函数 (76)
- el-date-picker开始日期早于结束日期 (70)
- js判断是否是json字符串 (67)
- checkout-b (67)
- localstorage.removeitem (74)
- vector线程安全吗 (70)
- & (66)
- java (73)
- js数组插入 (83)
- linux删除一个文件夹 (65)
- mac安装java (72)
- eacces (67)
- 查看mysql是否启动 (70)
- 无效的列索引 (74)