flowable mysql 表名大小写问题

news/2025/1/10 6:55:56 标签: mysql, flowable, windows, linux

在部署一个工作流项目(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启动时会报权限错误。


http://www.niftyadmin.cn/n/5818315.html

相关文章

ASP.NET Core 实现微服务 -- Polly 服务降级熔断

在我们实施微服务之后,服务间的调用变的异常频繁。多个服务之间可能是互相依赖的关系。某个服务出现故障或者是服务间的网络出现故障都会造成服务调用的失败,进而影响到某个业务服务处理失败。某一个服务调用失败轻则造成当前相关业务无法处理&#xff1…

T-SQL语言的学习路线

T-SQL语言的学习路线 引言 在当今的数据驱动时代,掌握数据库语言尤为重要。而在众多数据库语言中,T-SQL(Transact-SQL)作为微软SQL Server的扩展语言,因其强大的功能和灵活性,成为了很多开发者和数据分析…

自然语言转 SQL:通过 One API 将 llama3 模型部署在 Bytebase SQL 编辑器

使用 Open AI 兼容的 API,可以在 Bytebase SQL 编辑器中使用自然语言查询数据库。 出于数据安全的考虑,私有部署大语言模型是一个较好的选择 – 本文选择功能强大的开源模型 llama3。 由于 OpenAI 默认阻止出站流量,为了简化网络配置&#…

python 文件读写with open模式r,r+,w,w+,a,a+的区别

模式可做操作若文件不存在是否覆盖r只能读报错-r可读可写报错是w只能写创建是w 可读可写创建是a  只能写创建否,追加写a可读可写创建否,追加写 例子: def file_operation():with open(/wzd/test.txt, moder) as f:# f.write(abc)r f.rea…

【LeetCode】力扣刷题热题100道(1-5题)附源码 链表 子串 中位数 回文子串(C++)

目录 1.两数之和 2.两数相加-链表 3.无重复字符的最长子串 4.寻找两个正序数组的中位数 5.最长回文子串 1.两数之和 给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 target 的那 两个 整数,并返回它们的数组下标。…

【Flutter】使用ScrollController配合EasyRefresh实现列表预加载:在还未滑动到底部时加载下一页数据

需求/背景 在我们的业务场景中,列表的加载使用easy_refresh组件: https://pub.dev/packages/easy_refresh 大概效果是往上滑动到一定的offset会触发一个上滑加载,可以触发一些网络请求拉取列表后面的数据来展示。 这种模式一般在一页翻完…

uvm的m_sequencer和p_sequencer

p_sequencer 基本概念 p_sequencer是一个指向uvm_sequencer(序列发生器)的指针(句柄)。它在uvm_sequence(序列)中使用,用于访问序列发生器的成员和方法。通过uvm_declare_p_sequencer宏来声明…

第6章——HTTP首部

第六章——HTTP首部 HTTP报文结构 ​ 都必有报文首部 HTTP请求报文 HTTP响应报文 HTTP首部字段 ###传递重要信息 首部字段结构 ​ 首部字段名:字段值(,字段值,字段值) 首部字段类型 ​ 通用首部字段 请求首部字…