如何在项目中使用人大金仓替换mysql

news2024/12/13 19:34:51

文章目录

  • 数据库连接配置调整
    • 驱动和连接字符串修改:
    • 用户名和密码:
  • SQL 语法兼容性检查
    • 数据类型差异处理:
    • 函数差异:
    • SQL语句
    • 客户端 SQL 交互工具
  • 数据迁移
    • 数据库、用户移植
    • 数据迁移工具使用:
    • 迁移过程中的问题及解决方案
  • 迁移后项目功能状态
  • KingBase的后续使用参考资料

数据库连接配置调整

驱动和连接字符串修改:

  1. 在项目的配置文件(如 Spring Boot 项目中的application.properties或application.yml)中,将 MySQL 的驱动类名和连接字符串替换为人大金仓数据库对应的内容。
  2. 对于 MySQL,连接字符串通常是jdbc:mysql://localhost:3306/your_database_name,驱动类名是com.mysql.cj.jdbc.Driver。而人大金仓数据库的连接字符串一般是jdbc:kingbase8://localhost:54321/your_database_name?currentSchema=mycnblog,驱动类名是com.kingbase8.Driver
  3. 例如,在application.properties文件中修改如下:
    原 MySQL 配置:
 spring.datasource.driver - class - name=com.mysql.cj.jdbc.Driver
 spring.datasource.url=jdbc:mysql://localhost:3306/your_database_name
  1. 修改为人大金仓数据库配置:
 spring.datasource.driver - class - name=com.kingbase8.Driver
 spring.datasource.url=jdbc:kingbase8://localhost:54321/your_database_name

用户名和密码:

同时,确保数据库用户名和密码正确配置。如果在 MySQL 和人大金仓数据库中的用户名和密码不同,需要在配置文件中更新为人大金仓数据库的登录凭证。

SQL 语法兼容性检查

数据类型差异处理:

KingbaseES 对 MySQL的基本数据类型如数值类型(整型、浮点型、定点数类型)、文本字符串类型(CHAR、VARCHAR、TINYTEXT、MEDIUMTEXT、LONGTEXT)、位类型、日期时间类型(YEAR、TIME、DATE、DATETIME、TIMESTAMP)、枚举类型ENUM、集合类型SET、二进制类型(BINARY、VARBINARY、BLOB)、空间类型(GEOMETRY、POINT、LINESTRING、POLYGON)、JSON类型(JSON对象、JSON数组)可以原生支持,或者通过转换进行支持

具体兼容与转换点击这里查看

函数差异:

  • 兼容MySQL常用的日期时间函数

  • 兼容数值函数,如:ABS、ACOS、CEIL、CEILING等

  • 兼容BIT_LENGTH、CHAR_LENGTH、CONCAT、FIND_IN_SET、OCTET_LENGTH等字符函数

  • 兼容AVG、BIT_AND、BIT_OR、GROUP_CONCAT、STDDEV_POP等聚集函数

  • 兼容CUME_DIST、DENSE_RANK、FIRST_VALUE、LAST_VALUE等窗口函数

  • 兼容JSON函数

  • 兼容和base64的转换函数:to_base64、from_base64等

具体函数差异点击这里查看

SQL语句

在 KingbasES 中,对大多数常用的 MySQL特有 SQL 语句均提供了原生支持。这项措施使得 MySQL 应用程序在 KingbaseES 系统中通常只需很少的代码变动就可正常运行。

  • 以下列出不兼容的sql
sqlMySQLKingBase描述
位操作符: #不支持支持#是位异或操作符。它用于对两个二进制数的每一位进行异或运算。
RLIKE支持不支持用于正则表达式匹配
全局临时表不支持支持全局临时表是一种特殊的临时表。临时表主要用于存储临时数据,这些数据在特定的会话或者事务处理结束后通常会自动删除。而全局临时表与普通临时表的区别在于,它可以在多个会话之间共享数据,并且在所有引用它的会话都结束后,全局临时表中的数据才会被清除。
序列不支持支持序列是一种数据库对象,用于生成唯一的、按照一定规则递增递减的数值序列。通常用于为主键或其他需要唯一标识的列提供自动增长的数值。例如,在一个包含用户信息的表中,用户 ID 列需要一个唯一的、递增的数值作为标识,就可以使用序列来为每次插入新用户记录时生成新的用户 ID。
不支持支持在数据库领域,“包” 是一种将相关的数据库对象(如存储过程、函数、变量、游标等)组合在一起的机制。它提供了一种组织封装数据库逻辑的方式,类似于面向对象编程中的类,使得数据库开发更加模块化、易于管理和维护。传统的 MySQL 没有像一些高级数据库(如 Oracle、Kingbase)那样提供包的概念。这意味着在 MySQL 中,没有直接的语法来创建一个包含多个相关数据库对象的包结构。MySQL 通过其他方式来实现类似的功能整合。例如,通过合理的数据库架构设计命名规范,将相关的存储过程和函数放在同一个数据库中,并通过良好的注释和文档来表明它们之间的关联。但这种方式没有像包那样提供严格的封装和访问控制机制。
LOGFILE GROUP支持不支持1. MySQL 中的情况: 在 MySQL 中,支持日志文件组(LOGFILE GROUP)。在 MySQL 的某些存储引擎(如 InnoDB)中,日志文件组用于存储事务日志,这些日志可以帮助数据库在系统故障、意外关闭等情况下恢复数据。例如,InnoDB 存储引擎使用日志文件组来实现预写式日志(Write - Ahead Logging,WAL)机制。通过将事务的修改操作先记录到日志文件组中的日志文件中,然后再将修改应用到实际的数据文件,这样在数据库出现故障时,可以根据日志文件中的记录来恢复未完成的事务,从而保证数据的完整性。2. 在 Kingbase 中,虽然没有 LOGFILE GROUP,但有类似的日志机制,如重做日志(Redo Log)等。这些日志系统在后台默默地工作,记录数据库的更改操作,并且在数据库启动、恢复等过程中发挥关键作用。开发人员和管理员通常不需要像在 MySQL 中管理日志文件组那样直接操作这些日志组件,而是通过 Kingbase 提供的备份、恢复工具和一些系统参数来间接管理数据库的恢复性能和数据完整性。例如,通过配置备份策略、检查点(Checkpoint)频率等参数来确保数据库在出现故障时能够快速、准确地恢复。
外部表不支持支持外部表是一种特殊的数据库表,它的数据存储在数据库外部的文件(如文本文件、CSV 文件、XML 文件等)中。通过定义外部表,数据库可以像访问内部普通表一样访问外部文件中的数据,提供了一种将外部数据集成到数据库环境中的方式。
DBLINK不支持支持DBLINK 是一种数据库对象,用于在一个数据库实例与另一个数据库实例之间建立连接通道。通过这个连接,可以在本地数据库中访问远程数据库中的对象(如表、视图、存储过程等),就好像这些远程对象是本地数据库的一部分一样。这为分布式数据库应用场景提供了强大的支持,使得不同数据库之间的数据共享和交互变得更加便捷。
DO支持支持(有差异)在 MySQL 中,DO是一个执行表达式但不返回结果集的语句。它主要用于执行存储过程或者函数调用,并且丢弃返回值(如果有的话)。例如,当调用一个存储过程只是为了执行其中的操作逻辑(如插入、更新、删除数据等操作),而不需要返回结果时,可以使用DO语句。 Kingbase(人大金仓数据库)没有与 MySQL 中DO语句完全相同的语法和功能。在 Kingbase 中,调用存储过程通常会返回结果集(如果存储过程有返回值的话),并且使用的语法与 MySQL 有所不同。
insert delayed支持不支持在 MySQL 中,INSERT DELAYED是一种特殊的插入语句。当使用INSERT DELAYED时,MySQL 会将插入操作放入一个内部队列,然后立即返回给客户端,而不是等待插入操作实际完成。这样客户端就可以继续执行其他操作,而插入操作会在后台由 MySQL 服务器在适当的时候处理。这种方式主要用于在高并发写入场景下,提高客户端的响应速度。
set password for支持不支持在 MySQL 中,SET PASSWORD FOR语句用于设置用户的密码。它提供了一种灵活的方式来管理用户账户的安全性。可以通过这个语句为特定用户设置新密码,包括为本地用户、远程用户或者通过特定主机连接的用户设置密码。在 Kingbase 中,通常使用ALTER USER语句来修改用户密码。
check/checksum table支持不支持CHECK(表检查) 在 MySQL 中,CHECK语句主要用于检查表的完整性。对于某些存储引擎(如 MyISAM),它可以检查表是否存在错误,比如索引是否损坏、数据行是否有问题等。不过,不同存储引擎对CHECK命令的支持程度有所不同。例如,InnoDB 存储引擎会自动处理很多数据完整性的问题,CHECK操作对它的作用相对有限。CHECKSUM TABLE(计算表的校验和)CHECKSUM TABLE用于计算并返回一个或多个表的校验和。校验和是根据表中的数据内容计算出来的一个数值,它可以用于快速比较表在不同时间点的数据完整性。如果表的数据发生了变化,校验和通常也会改变。
show语句支持支持(有差异)
foreach语句不支持支持FOREACH是一种循环控制结构,用于遍历数组、集合或其他可迭代的数据结构中的元素。在数据库环境中,当涉及到处理批量数据,如对表中的多行数据进行相同的操作,或者对一个数组类型的变量中的多个元素进行处理时,FOREACH循环可以提供高效且简洁的方式来完成任务。
continue语句不支持支持在程序设计中,CONTINUE语句是一种控制流语句。通常用于循环结构(如FOR循环、WHILE循环等)中,当执行到CONTINUE语句时,它会跳过当前循环体中剩余的语句,直接进入下一次循环迭代。这样可以根据特定的条件跳过某些不必要的操作,提高程序的执行效率和灵活性。
exit语句不支持支持在一个存储过程中,如果满足某个条件,可以使用EXIT语句来立即终止存储过程的执行。
execute immediate语句不支持支持支持的含义:在 Kingbase(人大金仓数据库)中,EXECUTE IMMEDIATE语句提供了一种直接执行动态 SQL 的方式。它允许将一个包含 SQL 语句的字符串变量直接作为参数传递给这个语句,数据库引擎会立即执行这个动态构建的 SQL 语句。
异常处理exception语句不支持支持在数据库编程中,异常处理是一种机制,用于捕获和处理在程序执行过程中出现的错误或异常情况。这些异常可能包括数据库操作错误(如插入违反约束的数据、查询不存在的表等)、运行时错误(如变量未初始化、除数为零等)或者外部资源访问错误(如网络故障导致的数据库连接中断)等。通过使用异常处理语句,可以使程序更加健壮,避免因为异常导致程序崩溃,并且能够在出现异常时执行一些特定的恢复或报告操作。
  • SAVEPOINT、ROLLBACK TO SAVEPOINT、RELEASE SAVEPOINT等
    点击查看详细的sql差异详情1
    点击查看详细的sql差异详情2

客户端 SQL 交互工具

在实际应用中,通常客户 DDL 脚本和报表是通过 SQL 交互工具移植的。针对这种情况,KingbaseES 提供了如下 SQL 交互工具:

ksql:命令行的 SQL 交互工具,类似 MySQL 的 命令行。

Kstudio:图形化的 SQL 交互工具,类似 MySQL的图形化工具。

通过上述工具,用户可连接数据库服务器,运行数据库实用程序,发送 SQL 语句,运行 SQL 脚本,或运行KingbaseES 数据库管理命令实施数据库管理等。

数据迁移

数据库、用户移植

数据库是各种 SQL 和 PL/SQL 数据库对象的存放容器,而用户是这些对象的管理者和使用者。因此,在迁移数据库对象之前,一般应先迁移数据库、用户。

那么,如何移植这些内容呢?应在目的数据库 KingbaseES 上创建与源数据库 MySQL同名的数据库、用户。

另外,所创建数据库的字符集应与 MySQL数据库字符集一致.

数据迁移工具使用:

使用KingBase自带的迁移工具(KDTS进行数据迁移).
数据库迁移工具在完全安装时已经安装好了, 点击开始, 找到数据库迁移工具, 双击打开.
在这里插入图片描述

  1. 然后在浏览器中输入url: http://127.0.0.1:54523, 使用在金仓官网注册的账号进行登录.

  2. 登录成功后在数据源管理中添加源库和目标库连接. 在添加时需要输入必要的连接信息.
    在这里插入图片描述

  3. 之后在迁移任务管理中新建迁移任务, 按照指引填写必要的对比信息.
    在这里插入图片描述

迁移过程中的问题及解决方案

  1. 数据类型转换的问题:
    在新建迁移任务时, 最后一步是配置数据类型的参数, 这里有一些参数根据自己的需要进行更改, 否则可能会造成数据缺失等的问题. 如图
    在这里插入图片描述
    针对源数据类型是varchar时, 在源库中制定了长度的, 目标库中也会指定长度. 在源库中没有指定长度时, KingBase会默认长度为1, 这样在迁移过程中会对数据进行截取. 造成数据缺失的情况. 可以在配置中进行更改从而防止此问题.
    以上例为参考, 对其他类型的数据也需要进行必要配置. 以保证数据完整性和可用性.
  2. 持续更新中…

迁移后项目功能状态

目前正常.

KingBase的后续使用参考资料

  • 数据库管理员指南
  • 数据库开发指南
  • KingbaseES_SQL语言参考手册

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2258930.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【DVWA】XSS(Stored)

倘若人生一马平川,活着还有什么意思呢。 1.XSS(Stored)(Low) 相关代码分析 trim(string,charlist) 函数移除字符串两侧的空白字符或其他预定义字符,预定义字符包括、\t、\n、\x0B、\r以及空格,可选参数charlist支持添加额外需要删除的字符…

数据分析python小工具录入产品信息到Excel

在没有后台管理系统的时候,有时候为了方便起见,想提供一个输入框让运营人员直接输入,然后数据就会以数据库的形式存进数据库 效果图: 输入用户名 输入数据 输入信息后点击添加到表格,检查后方便批量保存到excel …

HTML和JavaScript实现商品购物系统

下面是一个更全面的商品购物系统示例,包含新增商品、商品的增加删除以及结算找零的功能。这个系统使用HTML和JavaScript实现。 1.功能说明: 这个应用程序使用纯HTML和JavaScript实现。 包含一个商品列表和一个购物车区域。商品列表中有几个示例商品&a…

C# 探险之旅:第三节 - 有趣的变量命名

欢迎再次回到我们的C#魔法森林。今天,我们要一起探索一个既有趣又实用的技能——变量命名。想象一下,你正在为你的小精灵们(变量)起名字,好的名字不仅能让它们更容易被识别,还能让你的魔法书(代…

JavaEE 【知识改变命运】04 多线程(3)

文章目录 多线程带来的风险-线程安全线程不安全的举例分析产出线程安全的原因:1.线程是抢占式的2. 多线程修改同一个变量(程序的要求)3. 原子性4. 内存可见性5. 指令重排序 总结线程安全问题产生的原因解决线程安全问题1. synchronized关键字…

ASP.NET|日常开发中连接Sqlite数据库详解

ASP.NET|日常开发中连接Sqlite数据库详解 前言一、安装和引用相关库1.1 安装 SQLite 驱动1.2 引用命名空间 二、配置连接字符串2.1 连接字符串的基本格式 三、建立数据库连接3.1 创建连接对象并打开连接 四、执行数据库操作4.1 创建表(以简单的用户表为例…

DS记录中

DataX/hdfswriter/doc/hdfswriter.md at master alibaba/DataX GitHub DataX 写入文档 https://dolphinscheduler.apache.org/zh-cn/docs/3.2.2/architecture/task-structure DS文档 DS 项目举例 流程 数据库(Datax) -> ODS (shell)->ADS(…

Node.js express

1. express 介绍 express 是一个基于 Node.js 平台的极简、灵活的 WEB 应用开发框架,官方网址:https://www.expressjs.com.cn/简单来说,express 是一个封装好的工具包,封装了很多功能,便于我们开发 WEB 应用&#xff…

网络应用技术 实验八:防火墙实现访问控制(华为ensp)

目录 一、实验简介 二、实验目的 三、实验需求 四、实验拓扑 五、实验步骤 1、设计全网 IP 地址 2、设计防火墙安全策略 3、在 eNSP 中部署园区网 4、配置用户主机地址 5、配置网络设备 配置交换机SW-1~SW-5 配置路由交换机RS-1~RS-5 配置路由器R-1~R-3 6、配置仿…

分布式日志系统设计

一、分布式日志系统定义 分布式日志系统是一种用于收集、存储和分析大规模分布式系统日志的系统。它可以帮助开发人员和系统管理员实时监控和调试系统,提高系统可靠性和可用性,同时也可以用于日志分析和故障排查。 二、简单设计思路 日志收集&#xff…

详解RabbitMQ在Ubuntu上的安装

​​​​​​​ 目录 Ubuntu 环境安装 安装Erlang 查看Erlang版本 退出命令 ​编辑安装RabbitMQ 确认安装结果 安装RabbitMQ管理界面 启动服务 查看服务状态 通过IP:port访问 添加管理员用户 给用户添加权限 再次访问 Ubuntu 环境安装 安装Erlang RabbitMq需要…

java+springboot+mysql私人会所管理系统

项目介绍: 使用javaspringbootmysql开发的私人会所管理系统,系统包含管理员、技师、用户角色,功能如下: 管理员:用户管理;服务项目;技师管理;房间管理;预约管理&#x…

Java面试之Happens-Before原则

此篇接上一篇的Java面试之volatile关键字。 首先,这是Java语言中的一个“先行发生”(Happens-Before)的原则。是判断数据是否存在竞争,线程是否安全的非常有用的手段,也是Java内存模型中定义的两项操作之间的偏序关系。 其次,Happ…

TensorFlow深度学习实战(1)——神经网络与模型训练过程详解

TensorFlow深度学习实战(1)——神经网络与模型训练过程详解 0. 前言1. 神经网络基础1.1 神经网络简介1.2 神经网络的训练1.3 神经网络的应用 2. 从零开始构建前向传播2.1 计算隐藏层节点值2.2 应用激活函数2.3 计算输出层值2.4 计算损失值2.4.1 在连续变…

C++鼠标轨迹算法(鼠标轨迹模拟真人移动)

一.简介 鼠标轨迹算法是一种模拟人类鼠标操作的程序,它能够模拟出自然而真实的鼠标移动路径。 鼠标轨迹算法的底层实现采用C/C语言,原因在于C/C提供了高性能的执行能力和直接访问操作系统底层资源的能力。 鼠标轨迹算法具有以下优势: 模拟…

Java从入门到工作2 - IDEA

2.1、项目启动 从git获取到项目代码后,用idea打开。 安装依赖完成Marven/JDK等配置检查数据库配置启动相关服务 安装依赖 如果个别依赖从私服下载不了,可以去maven官网下载补充。 如果run时提示程序包xx不存在,在项目目录右键Marven->Re…

【AI知识】过拟合、欠拟合和正则化

一句话总结: 过拟合和欠拟合是机器学习中的两个相对的概念,正则化是用于解决过拟合的方法。 1. 欠拟合: 指模型在训练数据上表现不佳,不能充分捕捉数据的潜在规律,导致在训练集和测试集上的误差都很高。欠拟合意味着模…

汽车升级到底应不应该设置“可取消“功能

最近,汽车OTA(Over-the-Air)升级频频成为车主讨论的热点。有些车主反映,一些升级增加了实用功能,而另一些却让体验变得复杂甚至带来不便。于是,大家不禁发问:汽车升级功能究竟应不应该允许“可取…

优选算法——分治(快排)

1. 颜色分类 题目链接:75. 颜色分类 - 力扣(LeetCode) 题目展示: 题目分析:本题其实就要将数组最终分成3块儿,这也是后面快排的优化思路,具体大家来看下图。 这里我们上来先定义了3个指针&…

[Maven]下载安装、配置与简介

很多框架的下载使用的流程和思路是差不多的,这里以maven做详细介绍。 下载安装与配置变量 下载 首先,我们要使用maven,必须先下载它的相关文件。想要下载,我们可以直接搜索maven。找到它的官网。这里不绕弯子,直接给出…