瀚高数据库中,对象不存在问题的处理思路及解决方案

**瀚高数据库
目录
环境
文档用途
详细信息

环境

系统平台:N/A

版本:6.0,4.5
文档用途

使用瀚高数据库可能会遇到应用系统中报对象等不存在的问题,可参照本文处理。

详细信息
1、常见报错信息展示:

msgid "table "%s" does not exist"

msgstr "表 "%s" 不存在"

msgid "function "%s" does not exist"

msgstr "函数 "%s" 不存在"

msgid "No function matches the given name and argument types. You might need to add explicit type casts."

msgstr "没有匹配指定名称和参数类型的函数. 您也许需要增加明确的类型转换."

msgid "operator does not exist: %s"

msgstr "操作符不存在: %s"

以上报错信息可以分为两类:

第一类:表、索引、序列、视图、函数等对象

1)表、索引、序列、视图等在系统表pg_class中可以查到的;

2)函数(存储过程)在瀚高数据库中,重载现象很多,也就是不同的参数类型或个数可以使用同名函数;在进行DDL、DQL等操作时一定要根据参数类型匹配到对应的同名函数,否则出错;

第二类:类型转换和操作符,基本归结为类型不匹配问题;有时可以使用这两种方式解决同一个问题。

2、当遇到第二类问题时,不建议直接去创建隐式转换或操作符去解决问题;

2.1 建议先从自己的代码与数据库类型进行排查,兼顾整个项目;确定代码实际要用的字段类型、数据库的字段类型,尽可能的修改成一致的数据库类型去解决问题;如果是SQL中的,建议在SQL中添加转换或使用双冒号转换;

2.2 以上方案解决不了的再创建隐式转换或操作符处理;这个问题可参照如下文章解决,本文不再详述,如下:

016958304 类型转换处理思路(APP)

018104201 瀚高数据库中java代码类型与bit对应(APP)

012800904 类型转换处理常用示例(APP)

3、当遇到第一种问题时,如下解决:

3.1 表、索引、序列、视图等在系统表pg_class中可以查到的,如下查询:

cpp 复制代码
select pc."oid", pc.relname, pn.nspname as "schema", pa.rolname "owner"

from pg_class pc 

join pg_namespace pn on pn."oid" =pc.relnamespace 

join pg_authid pa on pa.oid = pc.relowner 

where relname = '';

函数(存储过程)如下查询:

cpp 复制代码
select pp."oid", pp.proname, pn.nspname "schema", pa.rolname "owner", pg_get_functiondef(pp."oid") def 

from pg_proc pp

join pg_namespace pn on pp.pronamespace = pn."oid" 

join pg_authid pa on pp.proowner = pa."oid" 

where pp.proname = '';

查出对象的所属用户,模式等;查找对象是否存在;若不存在,那就是确实未创建该对象或连接的数据库不对;注意函数还要匹配参数个数和类型。

以上sql需要在对应的database执行。

改正后,再次测试。

3.2 jdbc等类似url未加currentSchema参数,conf(data目录下的postgresql.conf或postgresql.auto.conf)配置文件中的search_path参数未添加对象所属的schema,search_path默认如下:

cpp 复制代码
  search_path = '"$user", public'

如果对象不在上述schema中,则需要添加上,否则报错,如下添加模式sch1:

cpp 复制代码
  search_path = '"$user", public, sch1'

3.3 jdbc等类似url添加了currentSchema参数,但是值不包含对象所属的schema,也会报错,添加上即可解决,如下:

cpp 复制代码
  jdbc:postgresql://ip:port/database?currentSchema=sch1

如果查询的对象在sch2中,这里只添加了sch1,就会报错,改正如下:

cpp 复制代码
  jdbc:postgresql://ip:port/database?currentSchema =sch1,sch2

需要注意,添加了currentSchema参数,相当于把当前的会话的search_path参数值覆盖为currentSchema的值,因此如果创建的对象在public下,也需要把public添加上。

4、当遇到第二种问题时,也可以查询系统表pg_operator和pg_cast,确定对象是否存在,是新创建还是更改对象的属性。

相关推荐
阳冬园9 分钟前
mysql数据库 主从同步
数据库·主从同步
Mr.131 小时前
数据库的三范式是什么?
数据库
Cachel wood1 小时前
python round四舍五入和decimal库精确四舍五入
java·linux·前端·数据库·vue.js·python·前端框架
Python之栈2 小时前
【无标题】
数据库·python·mysql
风_流沙2 小时前
java 对ElasticSearch数据库操作封装工具类(对你是否适用嘞)
java·数据库·elasticsearch
亽仒凣凣2 小时前
Windows安装Redis图文教程
数据库·windows·redis
亦世凡华、2 小时前
MySQL--》如何在MySQL中打造高效优化索引
数据库·经验分享·mysql·索引·性能分析
YashanDB2 小时前
【YashanDB知识库】Mybatis-Plus调用YashanDB怎么设置分页
数据库·yashandb·崖山数据库
ProtonBase2 小时前
如何从 0 到 1 ,打造全新一代分布式数据架构
java·网络·数据库·数据仓库·分布式·云原生·架构
云和数据.ChenGuang7 小时前
Django 应用安装脚本 – 如何将应用添加到 INSTALLED_APPS 设置中 原创
数据库·django·sqlite