当前位置: 首页 > news >正文

商城网站流程杭州seo网站

商城网站流程,杭州seo网站,广东cba最新消息,湛江免费建站模板达梦数据库系列之Mysql项目迁移为达梦项目 1 达梦数据库安装及MySql数据迁移2 SpringBoot项目迁移2.1 驱动包引入2.2 驱动类配置2.3 数据源配置2.4 flowable迁移2.4.1 异常问题2.4.2 解决 3 迁移常见问题3.1 不是 GROUP BY 表达式3.1.1 dm.ini 开启Mysql兼容模式3.1.2 修改动态…

达梦数据库系列之Mysql项目迁移为达梦项目

  • 1 达梦数据库安装及MySql数据迁移
  • 2 SpringBoot项目迁移
    • 2.1 驱动包引入
    • 2.2 驱动类配置
    • 2.3 数据源配置
    • 2.4 flowable迁移
      • 2.4.1 异常问题
      • 2.4.2 解决
  • 3 迁移常见问题
    • 3.1 不是 GROUP BY 表达式
      • 3.1.1 dm.ini 开启Mysql兼容模式
      • 3.1.2 修改动态会话级参数:GROUP_OPT_FLAG
    • 3.2 仅当指定列列表,且SET IDENTITY_INSERT为ON时,才能对自增列赋值
      • 3.2.1 原因
      • 3.2. 2 解决

1 达梦数据库安装及MySql数据迁移

请看笔者:《达梦数据库系列之安装及Mysql数据迁移》 文章,详细编写了达梦数据库安装及Mysql迁移的方式

2 SpringBoot项目迁移

2.1 驱动包引入

在项目Pom文件中,引入达梦的驱动包

<dependency><groupId>com.dameng</groupId><artifactId>DmJdbcDriver18</artifactId><version>8.1.2.141</version>
</dependency>

2.2 驱动类配置

在application.yml中,找到driver-class-name配置,修改为dm.jdbc.driver.DmDriver

2.3 数据源配置

开发环境在application-dev.yml中,修改spring.datasource配置

spring:datasource:url: jdbc:dm://192.168.159.200:5236/database?schema=database&zeroDateTimeBehavior=convertToNull&useUnicode=true&characterEncoding=utf-8username: SYSDBApassword: DMdb_123456

注意:通常情况下,达梦是通过创建用户的时候,同步创建模式,此时配置的账号下,只有一个模式,所以无需指定schema,但是由权限更高的账号进行连接时候,由于模式有多个,导致无法读取到所需创建的库,所以配置时候,添加schema参数,用于指定模式!

2.4 flowable迁移

2.4.1 异常问题

如果项目中有flowable工作流引擎,配置了达梦基础数据源后,启动会报错误:couldn’t deduct database type from database product name ‘DM DBMS’,此时由于flowable未配置达梦的类型的库,无法进行识别。
在这里插入图片描述

2.4.2 解决

通过源码跟踪,发现,flowable数据库类型未支持达梦类型,此时需要对该类进行覆盖,增加达梦类型即可。
在这里插入图片描述

  1. 找到org.flowable.common.engine.impl.AbstractEngineConfiguration.class,并拷贝至文本文档
  2. 在项目目录下创建一个 org.flowable.common.engine.impl.AbstractEngineConfiguration.java 的类
  3. 将第一步中拷贝的源码,粘贴到该类中,在getDefaultDatabaseTypeMappings方法末尾,return之前增加如下代码:
//该操作的的含义为,针对达梦数据库类型,按Mysql的语法进行执行
databaseTypeMappings.setProperty("DM DBMS", DATABASE_TYPE_MYSQL);

此时,再进行项目启动,发现可以正常启动。

3 迁移常见问题

3.1 不是 GROUP BY 表达式

达梦数据库使用GROUP BY时,SELECT中的非聚合列必须出现在GROUP BY后面,否则就会报 “不是 GROUP BY 表达式”的错误
官方解决方案地址:https://eco.dameng.com/document/dm/zh-cn/faq/faq-errorcode.html#[-4080]: 不是 group by 表达式

  • 方法1:修改代码,将对应SQL语句改成符合达梦默认语法(此方法开发通常不会接受);
  • 方法2:修改达梦数据库参数,兼容MySQL语法(COMPATIBLE_MODE 或 GROUP_OPT_FLAG)
    提示:Mysql也有对应的严格模式,可以进行关闭ONLY_FULL_GROUP_BY

3.1.1 dm.ini 开启Mysql兼容模式

修改dm.ini 中的COMPATIBLE_MODE为4,表示兼容mysql
COMPATIBLE_MODE:默认为0,是否兼容其他数据库模式(0:不兼容,1:兼容SQL92标准,2:部分兼容ORACLE,3:部分兼容MS SQL SERVER,4:部分兼容MYSQL,5:兼容DM6,6:部分兼容TERADATA,7:部分兼容POSTGRES)
注意:修改过后,需要重启数据库才能生效

3.1.2 修改动态会话级参数:GROUP_OPT_FLAG

执行以下Sql,即可兼容:

alter  system set 'GROUP_OPT_FLAG'=1 both;

注意:当执行了该Sql后,会在dm.ini同级目录下生成一个dm.ini.dmbak的备份文件,且里面的GROUP_OPT_FLAG 标记设置为了1,GROUP_OPT_FLAG的默认值是60,因此,达梦数据库就算重启,也能够保持设置的配置;
注:此命令不需要重启数据库,也能够立即生效,但是针对Java已连接了的会话,需要重启才能生效

3.2 仅当指定列列表,且SET IDENTITY_INSERT为ON时,才能对自增列赋值

3.2.1 原因

达梦数据库默认主键 ID 是自增的,不允许重复插入自增主键列;默认配置项 IDENTITY_INSERT 值为 OFF,即自增长列是系统自动处理的,不需要指定数值,如果对该字段指定了数值,就会报错。所以只有将 IDENTITY_INSERT 设置为 ON 时,自增长列才可以指定一个值。

3.2. 2 解决

在sql执行开始时开启可插入,在sql执行完成后再关闭:


set IDENTITY_INSERT table_test ON;
insert table_test (id,k1,k2) values (1,'v1','v2');
set IDENTITY_INSERT table_test OFF;

官方解决方案:
在这里插入图片描述
该操作是会话级的,也就代表着当前会话关闭后,该设置就不生效了;根据实际情况进行评估,如果有特殊指定id插入的方式,只有单独进行处理,如果该表自增字段值是框架配置的,只是表结构创建时误操作自增,则将自增配置关闭掉即可。

http://www.khdw.cn/news/33566.html

相关文章:

  • 自学网站开发流程网站生成
  • 网站建设业务怎么跑百度怎么做网站
  • 做私人网站百度霸屏培训
  • 越秀区网站建设公司本站3天更换一次域名yw
  • 我市精神文明建设的门户网站seo关键词软件
  • 拦截网站做跳转seo搜索引擎优化方案
  • wordpress奇客影院长沙seo关键词
  • 网站制作成品下载国际军事新闻最新消息视频
  • 网站建设业绩微信上如何投放广告
  • 徐州seo关键词排名怎样优化网站排名
  • 域名注册网站系统搜一搜
  • wordpress 权限问题百度推广怎么优化排名
  • 做网站推广需要多少费用哪里可以学网络运营和推广
  • 做销售的 都有什么网站最新军事新闻
  • 如何用付费音乐做视频网站五合一网站建设
  • 企业网站需要多少钱托管竞价推广公司
  • 中山微网站建设报价外链网盘源码
  • 中文域名指向同一个网站什么是交换链接
  • 网站制作 商务上海seo网站排名优化公司
  • 做旅游网约车的网站安卓系统最好优化软件
  • 单一页面网站怎么做seo优化培训学校
  • 邢台建设网站什么是软文
  • 搜索网站做淘宝客长沙整站优化
  • seo案例视频教程aso应用商店优化
  • wordpress一定要本地建站吗网站推广网
  • 做平面设计都在那个网站找免费素材网页设计框架图
  • 有货 那样的网站怎么做怎么注册一个自己的网站
  • 代做效果图的网站好搜索大全引擎入口
  • 西安网站建设全包友缘在线官网
  • 网站优化细节怎么做广州最新疫情通报