国产数据库适配-南大通用(Gbase)问题整理

Gbase 函数

[GBase 8s 教程]GBase 8s 常用函数、表达式_gbase函数-CSDN博客

Gbase 8s hibernate方言包下载:

Index of /dl/hibernate

select * from sysmaster:sysdbslocale

  • 导出数据

su - gbasedbt

export DB_LOCALE=zh_CN.57372

export CLIENT_LOCALE=zh_cn.utf8

执行下面这条命令会把ta的库导出到当前目录下的ta.exp文件夹中,其中表结构和表数据是分开存储的。

dbexport ta;

  • 导入数据:

dbimport ta -d datadbs1 -l buffered

启动数据库服务:

oninit -vy

关闭数据库服务:

onmode -ky

查看数据库版本和运行模式:

onstat -

Springboot工程 适配南大通用(gbase 8s)

引入驱动包和方言包

hibernate-5.3.20_dbt-2.0_v1.0.jar gbasedbtjdbc.jar

 driver-class-name: com.gbasedbt.jdbc.IfxDriver
  url: jdbc:gbasedbt-sqli://10.7.215.249:9088/sysmaster:GBASEDBTSERVER=gbaseserver;db_locale=zh_cn.utf8;client_locale=zh_cn.utf8;NEWCODESET=utf8,utf8,57372
  username: gbasedbt
  password: gbasedbt123
  dialect: org.hibernate.dialect.GBasedbtDialect

问题整理:

使用了Mybatis-plus的分页插件时,需要手动设置方言类型为POSTGRE_SQL
PaginationInterceptor pageHelper=new PaginationInterceptor();
pageHelper.setDialectType(DbType.POSTGRE_SQL.getDb());

  • 创建自增id语句 (SERIAL 类型表示自增)
CREATE TABLE ctl_perf_auth_info (
	id  SERIAL NOT NULL,
	create_time DATETIME YEAR TO FRACTION(5),
	remark TEXT,
	PRIMARY KEY (id) CONSTRAINT u564_1587
)
 in datadbs1 ;
  • 主键自增报错:

把表的主键自增类型设置为SERIAL

  • 在SELECT 列表中所有未包含在组函数中的列都应该包含在GROUP BY 子句中.
  • order by 后 面的字段必须出现在select 列中。
  • 不支持IF函数,需要换成下面的写法

示例:

select
					dvc_address as dvcAddress,
					dvc_name as dvcName,
						case when
						alarm_level = 1
						then SEND_TIMES
						else 0 end
					 as low,
						case when
						alarm_level = 2
						then SEND_TIMES
						else 0 end
					 as  middle,
						case when
						alarm_level = 3
						then SEND_TIMES
						else 0 end
					 as  high
				from sim_d_alarm
  • 创建序列
CREATE SEQUENCE sim_sequence 
 INCREMENT BY 1 START WITH 1 
 MAXVALUE 99999999 MINVALUE 0 
 NOCYCLE CACHE 10 ORDER; 
  • TEXT 类型的字段在数据库里无法进行比较和聚合,需要改成varchar类型
  • 不支持date_format函数,需要替换成TO_CHAR
  • concat函数只支持两个参数
  • 查询语句中的字段和表名不能使用`符号
  • group_concat函数需要替换成wm_concat()
  • boolean类型的值,不是0和1,而是 t、f,分别代表true和false,不区分大小写

例如:data_flag 的字段类型为布尔,这查询语法如下

select * from lateral_threat_main _main where _main.data_flag = 'T'
  • 不支持now()函数,需要替换成下面的写法
select to_char(sysdate,'yyyy-mm-dd hh24:mi:ss')from dual
  • 不支持LOCATE(substr,str) 函数,需要用INSTR(str,substr)代替,注意参数是反过来的
  • 大小写问题,如果设置了大小写不敏感属性,则查询语句中返回的列名全部为小写。如图所示:
  • mybatis代码分页的写法,参数需要用$符号,不能用#号

select * from t_user where 1 = 1 limit ${pageNum},${pageSize}

关键字:

user、enable、label、type...

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

复制粘贴——QT实现原理

复制粘贴——QT实现原理 QT 剪贴板相关类 QClipboard 对外通用的剪贴板类,一般通过QGuiApplication::clipboard() 来获取对应的剪贴板实例。 // qtbase/src/gui/kernel/qclipboard.h class Q_GUI_EXPORT QClipboard : public QObject {Q_OBJECT private:explici…

如何制作一份吸引人的家具展示册

对于家具销售商来说,一份吸引人的家具展示册是至关重要的。它不仅可以帮助销售商展示产品,还可以吸引潜在客户的注意力,并激发他们的购买欲望。 那现在就有人问我,新手该怎么办?不会制作?其实这个问题早就…

玩转大数据17:数据采集与实时流处理的架构设计

引言 随着大数据技术的不断发展,数据采集与实时流处理成为了许多企业和组织的核心需求。本文将介绍一种数据采集与实时流处理的架构设计,包括数据采集、实时流处理、数据存储和数据分析等方面。 一、数据采集 数据采集是整个架构的基础,它…

用栈解决迷宫问题

思想 使用栈来解决迷宫问题的思想是通过深度优先搜索算法来探索迷宫中的路径。栈的特点是后进先出,这正好符合深度优先搜索的思想,即先探索一个方向直到无法继续为止,然后回溯到上一个节点,再探索其他方向。 具体来说&#xff0…

ubuntu20.04里面安装目标检测数据标注软件labelImg的详细过程

1.在github克隆仓库到本地 地址:https://github.com/Ruolingdeng/labelImg.git 或者百度网盘下载 链接:https://pan.baidu.com/s/1p-478j5WOTN0TKmv3qh-YQ?pwdl8bj 提取码:l8bj 2、进入到labelimg的文件夹,安装pyqt相关依赖包 …

C# 实现图片的压缩和改变大小png、jpg和gif

环境 .net6 Magick.NET-Q16-AnyCPU 13.5 Magick.NET源码 代码 using ImageMagick;namespace ImageCompress {internal class Program{static void Main(string[] args){string inputPath "imgloading.gif"; // 输入的GIF文件路径 string outputPath "im…

vue2+datav可视化数据大屏(3)

接上一节所说,当我们将接口封装完了后,我们需要给大屏进行内容填充啦 1,新建组件 📓 我们在ser-views文件夹下新建9个vue组件,如下图所示,我给编号为1到9 📓在组件里写入内容我是第一块...一次类推&#x…

小机器人,电子锁,牙刷,表类开关,磁阀开关等一些安防直流驱动的选型介绍分析 5V,大电流,小封装

安防监控是一门被人们日益重视的新兴行业,就目前发展来看,应用普及程度越来越广,科技含量也越来越高,几乎所有高新科技都可促进其发展,尤其是信息时代的来临,更为该行业的发展提供契机。其中安防领域最为典…

【RTOS学习】FreeRTOS中的链表 | 堆的管理

🐱作者:一只大喵咪1201 🐱专栏:《RTOS学习》 🔥格言:你只管努力,剩下的交给时间! 目录 🥩FreeRTOS中的链表🥞初始化🥞尾部插入🥞按顺…

JS对象笔记

对象声明 对象也只是一种数据类型/字面值。写对象这个字面值有两种写法,一种是普通的对象,这种对象用new 构造函数(),另一种是JS内特有的json对象。这个对象是直接{}就代表对象。且也是在堆内。 对象的构成 无论是上…

Ransac 算法的探索和应用

Ransac 算法python 应用和实现 Ransac 算法是一种常用的图像匹配算法,在参数估计领域也经常被使用到。针对估计各种曲线的鲁棒模型参数,效果显著。这里对ransac算法进行某些探索。 python program: import numpy as np import matplotlib.pyplot as p…

Profibus、Profinet、Ethernet有什么区别?

PROFINET 是一种新的以太网通讯系统,是由西门子公司和 Profibus 用户协会开发。 PROFINET 具有多制造商产品之间的通讯能力,自动化和工程模式,并针对分布式智能自动化系统进行了优化。其应用结果能够大大节省配置和调试费用。 PROFINET 系统集…

_pickle.PicklingError: Can‘t pickle : import of module failed

有问题 没问题的 python - pickle cant import a module that exists? - Stack Overflow

华媒舍:怎样利用旅游业发展媒体套餐宣传推广分析7个经典案例

1.分析经典案例在旅游业发展中,依靠媒体套餐开展宣传推广成为了一种常见的方法。下面将详细介绍7个经典案例,从这当中我们可以得出一些宝贵经验。 案例一:目标市场定位成功宣传推广一定要明确市场定位,针对不同的受众群体制定合理…

【FPGA/verilog -入门学习12】Verilog可配置的PWM设计,参数传递的3种方式

需求: 基于任务(task)的PWM设计仿真验证 需求分析: 1,需求实现可配置PWM输出(频率,占空比) 2,输入,输出端口 input i_clk, //clk 50Mhz input i_rst_n, input i_en, output…

设计模式(三)-结构型模式(1)-适配器模式

一、为何需要适配器模式(Adapter)? 在软件设计中,某个模块里有很多公用的功能接口,其中有些公用接口需要用到不同的类当中时,会出现接口不兼容的问题。因为这些不同的类对这个相同任务的接口,都有各自代码…

DNSLog漏洞探测(七)之SQL注入漏洞实战

DNSLog漏洞探测(七)之SQL注入漏洞实战 在前面的文章之中,我们已经学习了XSS、RCE、XXE、SSRF漏洞中有关于DNSLog平台的使用。这些漏洞本身在执行时就有解析URL地址,发起网络请求的操作,所以只要我们把DNSLog平台获取的子域名地址发送到存在漏…

优化钢铁加工:RFID技术的革新应用

优化钢铁加工:RFID技术的革新应用 RFID是一种无线通信技术,通过将标签上的电子数据以无线电信号的形式传输,实现对物品的远程识别和跟踪。在钢铁加工领域,RFID技术的应用能够提高生产效率、降低成本并优化物流管理。本文将探讨RF…

DevOps 和人工智能 – 天作之合

如今,人工智能和机器学习无处不在,所以它们开始在 DevOps 领域崭露头角也毫不令人意外。人工智能和机器学习正在通过自动化任务改变 DevOps,并使各企业的软件开发生命周期更高效、更深刻和更安全。我们在 DevOps 趋势中简要讨论过这一问题&am…

【Hive】——DDL(DATABASE)

1 概述 2 创建数据库 create database if not exists test_database comment "this is my first db" with dbproperties (createdByAllen);3 描述数据库信息 describe 可以简写为desc extended 可以展示更多信息 describe database test_database; describe databa…