GBase 8s数据库的交互式工具无历史执行语句,但我们知道Linux操作系统本身自带历史执行语句功能(上下翻页和history),我们可以使用调用shell脚本的方式,使用dbaccess加上历史执行语句功能:
脚本内容如下:放置于$GBASEDBTDIR/bin目录下,并加上执行权限
Kettle 8.3 资源库(GBase 8s V8.8)表结构
Kettle默认只支持使用mysql/oracle/sqlserver等数据库为资源库,若要使用GBase 8s为资源库,需要从其它资源库迁移相应的结构及数据。
以下为从mysql资源库迁移为GBase 8s资源库的表结构说明,供参考:
r_cluster(集群信息)
序号 | 字段名称 | 字符类型 | 允许空 | 缺省值 | 字段描述 |
---|---|---|---|---|---|
1 | id_cluster | INT8 | 否 | 集群ID | |
2 | name | VARCHAR(255) | 是 | 集群名称 | |
3 | base_port | VARCHAR(255) | 是 | 端口 | |
4 | sockets_buffer_size | VARCHAR(255) | 是 | 缓冲大小 | |
5 | sockets_flush_interval | VARCHAR(255) | 是 | 刷新间隔 | |
6 | sockets_compressed | SMALLINT | 是 | 是否压缩 | |
7 | dynamic_cluster | SMALLINT | 是 | 是否动态集群 |
Kettle连接到GBase 8s数据库
1,将GBase 8s数据库驱动放到kettle的lib目录下
如下图,在data-integration\lib下添加连接GBase 8s数据库的驱动gbasedbtjdbc.jar(视Server版本,增加匹配的驱动)
Mybatis-Plus之使用LocalDateTime等java8新日期时间类型报错
数据库JDBC版本:GBase 8s JDBC V8.8 3.3.0_3
Mybatis-Plus版本: 3.4.3.2
JDK版本: jdk1.8.0_201
QT5.12.12通过ODBC连接到GBase 8s数据库(CentOS)
本示例使用的环境如下:
- 硬件平台:x86_64(amd64)
- 操作系统:CentOS 7.8 2003
- 数据库版本(含CSDK):GBase 8s V8.8 3.0.0_1
为什么使用QT 5.12.10? - 该版本包含QODBC。
1,GBase 8s数据库的ODBC安装与配置
1.1,确认操作系统已经安装unixODBC及unixODBC-devel
通过apt查找确认unixODBC及unixODBC-devel已经安装
[root@localhost ~]# rpm -qa unixODBC unixODBC-devel
unixODBC-devel-2.3.1-14.el7.x86_64
unixODBC-2.3.1-14.el7.x86_64
QT通过ODBC连接GBase 8s数据库(Windows)示例
示例环境:
- 操作系统:Windows 10 64位
- 数据库及CSDK版本:GBase 8s V8.8_3.0.0_1 64位
- QT:5.12.0 64位
1,CSDK安装及ODBC配置
1.1,免安装版CSDK
下载免安装版的CSDK驱动,地址:https://gbasedbt.com/dl/odbc/GBase8s_3.0.0_1-Win64-ODBC-Driver.zip
解压到不含中文的目录下,如D盘根目录下,生成gbase8s-odbc-driver目录
在mybatis-plus中增加对GBase 8s的支持
在mybatis-plus 3.4.3.2版本之后已经增加了对GBase 8s的支持(使用GBASEDBT类型),在3.5.2版本中变更类型为GBASE8S。如果使用的是其它版本,按照以下进行修改。
mybatis-plus-annotation模块
1, 在 com.baomidou.mybatisplus.annotation.DbType.java 类中增加
GBASEDBT("gbasedbt", "南大通用安全数据库(GBase 8s)"),
注册GBase 8s的数据库类型,名称为GBASEDBT
GBase 8s重建sysuser库的方法
因sysuser库出现异常,需要重建sysuser库,请按以下方式:
1,停止使用USERMAPPING,全使用操作系统验证。
onmode -wf USERMAPPING=OFF
2,去除字符集相关的环境变量
unset DB_LOCALE
unset CLIENT_LOCALE
unset GL_USEGLU
GBase 8s使用C3P0连接池时去除SQLWarning警告
通过C3P0连接池连接到GBase 8s数据库时,可能会碰到这样的SQLWarning:
六月 16, 2023 3:40:55 下午 com.mchange.v2.c3p0.SQLWarnings
信息: Database has transactions
java.sql.SQLWarning: Database has transactions
或者
六月 16, 2023 3:40:55 下午 com.mchange.v2.c3p0.SQLWarnings
信息: Database selected
java.sql.SQLWarning: Database selected
以上警告,虽然不影响操作,但该日志频繁出现,将影响系统性能。
GBase 8s中的start with connect by用法
如果表中存在层次数据,则可以使用层次化查询子句查询出表中行记录之间的层次关系
基本语法:
[ START WITH CONDITION1 ]
CONNECT BY [ NOCYCLE ] CONDITION2
示例:
select id,parentid,partname, level
from tabpart
start with id = 11
connect by nocycle prior id = parentid;