GaussDB 数据库设计规范

1 背景

为了使用数据库的健全与运维的便捷,GaussDB数据库推出数据库设计规范。

2 数据库设计规范内容

**规范1:**使用JDBC客户端连接数据库时必须指明数据库名。

JDBC连接时必须指明数据库名,具体格式为:

复制代码
jdbc:gaussdb://ip:port/database_name

注:JDBC实例一旦创建,无法进行数据库切换。

**规范2:**数据库目前不支持不区分大小写的排序方式。

**规范3:**业务使用前必须由系统管理员为业务创建DATABASE、SCHEMA和USER,然后再赋予相关用户对应对象的权限。

**规范4:**业务使用前必须先创建业务数据库。

注:禁止使用数据库安装后默认创建的postgres数据库存储业务数据,建议根据业务情况创建业务自己的数据库。

**规范5:**创建数据库时必须指定字符集为UTF8,创建数据库时必须选择与客户端统一的编码字符集。

为了满足全球化需求,数据库编码应能够存储与标识绝大多数的字符,因此推荐使用UTF8。UTF8字符集与MySQL的UTF8MB4等价,能够支持emoji表情字符。如果客户端的编码方式与数据库的编码方式不统一,需要转码,会带来性能问题,同时,针对同编码的内核优化无法触发,影响查询效率。客户端的编码字符集需通过以下方式修改:

数据库的编码在CREATE DATABASE时进行设置。

复制代码
CREATE DATABASE tester WITH ENCODING = 'UTF8';
  • 设置客户端连接参数,例如JDBC连接参数可通过在URL中追加characterEncoding和allowEncodingChanges参数。

    复制代码
    jdbc:gaussdb://ip:port/database_name?characterEncoding=utf8&allowEncodingChanges=true
  • 修改数据库GUC参数.

复制代码
  SET client_encoding = 'UTF8';

注:数据库一旦创建无法更改字符集。

**建议1:**从便捷性和资源共享效率上考虑,建议使用SCHEMA进行业务隔离。可以使用DATABASE和SCHEMA两种方式实现业务的隔离。区别在于:

  • DATABASE方式隔离的共享资源极少,可实现连接隔离、权限隔离等,隔离更加彻底。但DATABASE之间无法互相访问,JDBC建立连接时必须指明DATABASE,连接后无法切换DATABASE。

  • SCHEMA方式隔离的共用资源较多,可以通过GRANT与REVOKE语法便捷地控制不同用户对各SCHEMA及其下属对象的权限。

**建议2:**创建数据库时建议指定LC_CTYPE和LC_COLLATE,该参数将影响数据的排序顺序。

示例:

复制代码
CREATE DATABASE SAMPLE_DB WITH LC_CTYPE =  'zh_CN.gbk' LC_COLLATE = 'zh_CN.gbk';

3 批注

合理遵守GaussDB数据库设计规范,会让使用数据库少走弯路,也会使用数据库的更健全与运维的更便捷。

相关推荐
码农小卡拉7 分钟前
深入解析Spring Boot文件加载顺序与加载方式
java·数据库·spring boot
怣5012 分钟前
MySQL多表连接:全外连接、交叉连接与结果集合并详解
数据库·sql
wjhx33 分钟前
QT中对蓝牙权限的申请,整理一下
java·数据库·qt
冰暮流星44 分钟前
javascript之二重循环练习
开发语言·javascript·数据库
万岳科技系统开发1 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
冉冰学姐1 小时前
SSM智慧社区管理系统jby69(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面
数据库·管理系统·智慧社区·ssm 框架
杨超越luckly1 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强
Elastic 中国社区官方博客2 小时前
Elasticsearch:Workflows 介绍 - 9.3
大数据·数据库·人工智能·elasticsearch·ai·全文检索
仍然.2 小时前
MYSQL--- 聚合查询,分组查询和联合查询
数据库
一 乐2 小时前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端