flowable mysql 表名大小写问题

在部署一个工作流项目(flowable)时,这边把测试库的表直接还原到正式环境,在启动后发现flowable又单独建了一套大写的表名表,之前因为是在windows下创建,表名默认是小写,windows下没有问题,linux下无法识别小写表名。

排查问题

程序自动建表如果完成的很好那当然是大吉大利。自动建表操作是f2来做的,它所建的表都是些核心表,表名为大写。前面说了f1 是在f2 上面扩展的那必然就会有自己的表。只依靠f2自动建表是不行的,项目根本跑不起来。f1提供了initsql,sql中包含了所有的表,有自己的还有f2的那些核心表,表名均为小写。

部署过程先把服务器上的数据库建好然后导入数据,一切正常数据库出现了一堆小写的表。运行f1程序,报错信息是一些表外建重复定义之类的。这时再看数据库出现了很多大写的表名。和小写表名重复的。比如 act_ru_job ACT_RU_JOB。第一次看到有点懵。为什么windwos下没有问题,到linux下就又问题了。把windows下的程序数据库连接换为Linux的一样报错。初步判断是由于操作系统不一样导致的问题。

在mysql中执行下面语句

show variables like '%lower_case_table_names%';

表现的值有三种 0 1 2。

0 linux 下默认规则,表名区分大小写。

1 windows 下默认规则,表名存储在磁盘是小写的,但是比较的时候是不区分大小写。

2 macos,下默认规则,表名存储为给定的大小写但是比较的时候是小写的

这下才明白,程序为啥一直检测不到表存在,然后自己创建。原因就是linux下大小写严格区分的,改为和windwos下的值一样就可以了。

限制

找到my.conf在[mysqld] 下添加 lower_case_table_names=1,保存重启。mysql跑不起来,官方文档上写这个参数只能在数据库初始化操作之前添加,如果数据库已经初始化完成了就不能再添加了,那么怎么办呢?

如果没有重要数据直接删除数据目录,执行 mysqld --initialize --user=mysql --lower-case-table-names=1 要加上--user=mysql。不然数据目录所有者是root启动时会报权限错误。

相关推荐
风曦Kisaki21 分钟前
# Linux Shell 编程入门 Day02:条件测试、if 判断、循环与随机数
linux·运维·chrome
qq_2837200531 分钟前
Python3 模块精讲:pymysql(第三方)- 连接 MySQL
mysql·adb·pymysql
李日灐35 分钟前
< 6 > Linux 自动化构建工具:makefile 详解 + 进度条实战小项目
linux·运维·服务器·后端·自动化·进度条·makefile
czlczl200209251 小时前
MySQL 性能优化:前缀索引(Prefix Index)深度解析
数据库·mysql·性能优化
嵌入式×边缘AI:打怪升级日志1 小时前
嵌入式Linux开发:开源组件、第三方库与许可证详解
linux
计算机安禾1 小时前
【Linux从入门到精通】第34篇:搭建FTP与Samba——跨平台文件共享解决方案
linux·运维·服务器
日取其半万世不竭1 小时前
用 Netdata 实时监控服务器,比 Prometheus + Grafana 轻量得多
linux·服务器·网络·系统架构·负载均衡·zabbix·grafana
java_logo1 小时前
SiYuan 思源笔记 Docker 部署终极指南:Windows+Linux 双平台
windows·笔记·docker·思源笔记·思源笔记部署·docker部署思源笔记·思源笔记文档
jamon_tan1 小时前
Linux下cmake构建方法
linux
JiaWen技术圈2 小时前
内核子系统 nf_tables 深度解析
linux·服务器·安全·运维开发