mysql数据库切换成kingbase(人大金仓)数据库时遇到的字段不存在问题

一、问题描述

mysql数据库切换成国产数据库人大金仓(kingbase)数据库的遇到的字段不存在的问题,根本原因其实是没有找到相对应的表,报错示例如下图所示:

二、问题解决

1、如果所有的表都发生上述的错误,kingbase的表在xml里面写sql的时候需要带上空间名的前缀,比如public.tableName,不然的话会找不到相应的表,当然了可以直接对kingbase的数据库做统一处理,处理步骤如下:
第一步更改数据库的配置

java 复制代码
ALTER DATABASE 数据库名 SET search_path to "$user", public, sys, sys_catalog, pg_catalog;

第二步重载配置文件

java 复制代码
select sys_reload_conf(); 

第三步可以看下是否生效

java 复制代码
show search_path;

2、如果你的项目中有user表,并且其它表正常,只有user表发生这样的错误,原因是,kingbase中user是一个关键字,你的表名和关键字冲突了,解决方法如下:
方法一: sql中user表加双引号,即:user修改成"user"
方法二: sql中user表前面加上空间名,即:user修改成public.user

相关推荐
2401_831419447 小时前
golang如何实现分布式对象存储_golang分布式对象存储实现攻略
jvm·数据库·python
羑悻的小杀马特7 小时前
深入 LangChain 内存向量存储(Memory Vector Stores):架构解析与优化
数据库·架构·langchain·向量存储
bLEd RING7 小时前
MySQL数据库误删恢复_mysql 数据 误删
数据库·mysql·adb
梦梦代码精7 小时前
LikeShop 是怎么解决数据库瓶颈的?
java·数据库·低代码·php
yexuhgu7 小时前
Golang如何做贪心算法_Golang贪心算法教程【速学】
jvm·数据库·python
qq_229058017 小时前
conda中安装 rdkit版本的postgresql然后在Win11中使用虚拟环境里的rdkit
数据库·postgresql·conda
2401_831419448 小时前
Redis如何实现多维度权重排序_利用ZSet分数计算进行优先级排列
jvm·数据库·python
HalvmånEver8 小时前
MySQL表的内连和外连
linux·数据库·学习·mysql
qq_349317488 小时前
CSS如何实现全屏背景图固定_background-attachment fixed
jvm·数据库·python
qq_460978408 小时前
Go语言如何做环境变量配置_Go语言环境变量管理教程【详解】
jvm·数据库·python