从mysql迁移库,存在非聚集列不在group by 的语句。
这样的sql会被认为是不合法的sql,因为:
1,order by后面的列必须是在select后面存在的
2,select、having或order by后面存在的非聚合列必须全部在group by中存在
通用情况下,mysql可以通过以下三种方式解决报错问题
1,修改sql使其遵守only_full_group_by规则
2,关闭only_full_group_by规则
3,降级数据库版本在5.7以下
从mysql迁移库,存在非聚集列不在group by 的语句。
这样的sql会被认为是不合法的sql,因为:
1,order by后面的列必须是在select后面存在的
2,select、having或order by后面存在的非聚合列必须全部在group by中存在
通用情况下,mysql可以通过以下三种方式解决报错问题
1,修改sql使其遵守only_full_group_by规则
2,关闭only_full_group_by规则
3,降级数据库版本在5.7以下
注:对非gbasedbt或者root用户
注:仅是大致过程
1,访问系统库sysuser的表sysintauthuser。
如果用户名不匹配username,则认为不是内部用户,转使用操作系统验证;如果匹配username,则继续2。
2,访问系统库sysuser的表sysusermap。
如果用户名不匹配username,刚使用默认用户(default user的properties);如果匹配username,则获取surrogate_id。继续3。
3,访问系统库sysuser的表syssurrogates。
如果surrogate_id不匹配,则报错退出; 如果匹配,则获取os_username。继续4。
4,与加载到内存中的allowed.surrogates对比。
如果不匹配,报警告,转使用操作系统验证;如果匹配,完成检验。
分为两个场景
用户验证使用操作系统检验。
将自动与同名操作系统用户绑定代理映射,用户检验时先从内部校验,但找不到代理映射用户(online.log中会的警告),而后将使用操作系统检验。
注:这种情况下,修改allowed.surrogates增加同名代理映射用户,并重新加载到内存。此时,内部用户检验通过,将使用内部检验。
用户检验使用内部检验
用户校验使用内部检验
用户校验使用内部检验
本文基于GBase 8s V8.8 3.6.2_2版本编写, 是对原文档:https://gbasedbt.com/index.php/archives/459/ 的更新。
常用的数据类型如下:
GBase 8s数据库数据类型参考:https://gbasedbt.com/index.php/archives/628/
内置字符类型包括:char, nchar, varchar, nvarchar, lvarchar, varchar2, nvarchar2和clob2
CHARACTER(n) 和 CHARACTER VARYING(n)这样的别名同样支持
启用SQLMODE=Oralce,即Oracle兼容模式
这里是 GBase 8s TRANSLATE() 函数的语法:
TRANSLATE(string, from_string, to_string)
string
必需的。 要翻译的字符串。
from_set
必需的。 一个字符串,它是要翻译的字符的集合。
to_set
必需的。 一个字符串,它是要翻译成的字符集合。
to_set 中的字符和 from_set 中的字符一一对应形成翻译关系。
本文介绍了如何在同一台机器上使用 Docker 容器搭建GBase 8s主备集群环境。
拉取GBase 8s的最新镜像
docker pull liaosnet/gbase8s
或者
docker pull liaosnet/gbase8s:v8.8_3513x25_csdk_x64
注:在tag为v8.8_3513x25_csdk_x64及之后的版本中,可通过参数方式自动创建集群
拉取镜像成功后,可通过docker images查看拉取镜像的版本。
从oracle迁移到GBase 8s数据库的过程中,有类似
select t.*
from t
order by dbms_random.value
进行随机排序查询的写法。
GBase 8s默认不支持dbms_random之类的函数,这些函数存在称为datablade的扩展包中,以下示例在库中注册excompat。
cd $GBASEDBTDIR/extend/excompat.1.0
unset DB_LOCALE
unset CLIENT_LOCALE
blademgr # 进入 blademgr,提示符如: 数据库服务名>
服务名> show databases # 显示可加载模块的库
服务名> list testdb # 假设我们需要在testdb库中注册,先查看该有是否有注册模块
服务名> register excompat.1.0 testdb # 注册模块,要求有二次确认
服务名> quit # 退出注册模块
-- 注意:该写法(order by 函数)并不是所有版本都支持
select t.* from systables t order by dbms_random_random();
-- 该写法均支持
select dbms_random_random(), t.*
from systables t
order by 1;
按实际需要修改写法。
对应版本:3.6.2_2
GBase 8s类型类型 | colType | sql_data_type | java.sql.Types | java类型名称 |
---|---|---|---|---|
SMALLINT | 1 | 1 | 5 | SMALLINT |
INTEGER | 2 | 2 | 4 | INTEGER |
BIGINT | 52 | 17 | -5 | BIGINT |
INT8 | 17 | 17 | -5 | BIGINT |
SMALLFLOAT | 4 | 4 | 7 | REAL |
FLOAT | 3 | 3 | 8 | DOUBLE |
DECIMAL | 5 | 5 | 3 | DECIMAL |
MONEY | 8 | 5 | 3 | DECIMAL |
CHAR | 0 | 0 | 1 | CHAR |
NCHAR | 15 | 0 | 1 | CHAR |
VARCHAR | 13 | 13 | 12 | VARCHAR |
NVARCHAR | 16 | 13 | 12 | VARCHAR |
VARCHAR2 | 63 | 63 | 63 | 未定义 |
NVARCHAR2 | 64 | 64 | 64 | 未定义 |
LVARCHAR | 40 | 43 | -1 | LONGVARCHAR |
BOOLEAN | 41 | 45 | 16 | BOOLEAN |
TEXT | 12 | 101 | -1 | LONGVARCHAR |
BYTE | 11 | 102 | -4 | LONGVARBINARY |
CLOB | 41 | 101 | 2005 | CLOB |
BLOB | 41 | 102 | 2004 | BLOB |
SERIAL | 6 | 2 | 4 | INTEGER |
SERIAL8 | 18 | 17 | -5 | BIGINT |
BIGSERIAL | 53 | 17 | -5 | BIGINT |
DATETIME YEAR TO SECOND | 10 | 10 | 93 | TIMESTAMP |
DATETIME HOUR TO SECOND | 10 | 10 | 92 | TIME |
DATE | 7 | 7 | 91 | DATE |
RAW | 40 | 43 | 2000 | JAVA_OBJECT |
TIMESTAMP WITH TIME ZONE | 65 | 9 | 2014 | TIMESTAMP_WITH_TIMEZONE |
JSON | 40 | 43 | 2000 | JAVA_OBJECT |
BSON | 40 | 43 | 2000 | JAVA_OBJECT |
INTERVAL | 14 | 0 | 1 | CHAR |
LIST | 21 | 49 | 1111 | OTHER |
SET(LVARCHAR) | 19 | 43 | 1111 | OTHER |
MULTISET(SENDRECEIVE) | 20 | 49 | 1111 | OTHER |
CLOB2 | 40 | 43 | -1 | LONGVARCHAR |
NULL | 9 | |||
ROW | 22 | 22 | 2002 | STRUCT |
COLLECTION | 23 | |||
ROWREF | 24 | |||
REFSERIAL8 | 42 |
备注:
1,此文档基于jdbc包3.6.1_2和数据库版本3.6.2_2;
2,coltype为40(可变长)和41(不可变长)的为Opaque数据类型;
3,sql_data_type指的是基于数据类型,与coltype或java.sql.Types类型
Django 是一个由 Python 编写的一个开放源代码的 Web 应用框架。
使用 Django,只要很少的代码,Python 的程序开发人员就可以轻松地完成一个正式网站所需要的大部分内容,并进一步开发出全功能的 Web 服务 Django 本身基于 MVC 模型,即 Model(模型)+ View(视图)+ Controller(控制器)设计模式,MVC 模式使后续对程序的修改和扩展简化,并且使程序某一部分的重复利用成为可能。
系统要求:
1,操作系统使用22.04.3 LTS
2,unixodbc及unixodbc-dev已经安装
3,GBase 8s CSDK 64bit(客户端连接工具)已经安装
4,Python版本是3.10.12(系统自带)
5,Django版本使用4.2.15
6,需要pyodbc
7,使用django_gbasedbtdb 1.11.5版本
近期的客户想实现数据库自重启功能(即故障后自动重启),该功能需要在自动启动的基础上进行改进。
关于systemd方式实现自启动的方法可参考之前的文档:https://gbasedbt.com/index.php/archives/161/
以下仍是通过systemd方式实现GBase 8s数据库的自启动、自重启与关闭。
注意:自启动、自重启仅适用于单机,而不要用于集群环境
适用于操作系统: RHEL7/CENTOS7, 以及基于RHEL7内核的系统。
1,service 文件所在位置 /usr/lib/systemd/system/
2,service 的环境配置文件位置 /etc/sysconfig/