9d7a06c7cb827bfe21505b24770716bed6b6836b
\347\211\210\346\234\254\345\217\221\345\270\203/\345\271\263\345\217\260\346\225\260\346\215\256\345\272\223\345\217\202\350\200\203\346\211\213\345\206\214.md
| ... | ... | @@ -1,2001 +1,272 @@ |
| 1 | -# 数据库参考手册 |
|
| 1 | +# 平台支持的数据库参考手册 |
|
| 2 | 2 | |
| 3 | -## 一 MySQL 参考手册 |
|
| 3 | +平台ORM框架目前支持以下几种数据库,并内置对应的 Provider 实现.以下 Provider 已实现驱动加载、方言解析、分页、事务、批量操作等常用功能,应用层只需切换 `dbcp.properties` 中的 `driverClassName` 与 `url` 即可在各类数据库之间平滑迁移。 |
|
| 4 | 4 | |
| 5 | -#### 数据库配置(文件dbcp.properties)如下 |
|
| 5 | +**支持的数据库类型** |
|
| 6 | 6 | |
| 7 | +| 数据库类型 | Provider 类名 | 兼容性说明 | 参考文档 | |
|
| 8 | +| -------------- | ------------------ | ----------------------------- | ------------------------------------------------------------ | |
|
| 9 | +| Oracle | OracleProvider | 标准 Oracle 数据库 | - | |
|
| 10 | +| MySQL | MySqlProvider | 标准 MySQL 数据库 | - | |
|
| 11 | +| OceanBase | MySqlProvider | 兼容 MySQL 语法 | [OceanBase 数据库使用指南](/iidpwiki/OceanBase%20数据库使用指南.md) | |
|
| 12 | +| PostgreSQL | PostgreSQLProvider | 标准 PostgreSQL 数据库 | [PostgreSQL 参考手册](/iidpwiki/PostgreSQL.md) | |
|
| 13 | +| Dameng(达梦) | DamengProvider | 兼容 Oracle 语法和用法 | [达梦数据库(DM8)适配](/iidpwiki/dameng-guide.md) | |
|
| 14 | +| GaussDB | GaussDBProvider | 兼容 MySQL 和 PostgreSQL | [GaussDB 数据库参考手册](/iidpwiki/gaussdb-guide.md) | |
|
| 15 | +| Vastbase G100 | VastbaseProvider | 兼容 PostgreSQL 和 MySQL 模式 | [Vastbase G100 参考文档](/iidpwiki/Vastbase-guide.md) | |
|
| 7 | 16 | |
| 8 | - ``` |
|
| 9 | - ########DBCP########## |
|
| 10 | - driverClassName=com.mysql.cj.jdbc.Driver |
|
| 11 | - #url |
|
| 12 | - url=jdbc:mysql://127.0.0.1:3306/iidp?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true |
|
| 13 | - username=username |
|
| 14 | - password=password |
|
| 15 | - initialSize=5 |
|
| 16 | - maxActive=30 |
|
| 17 | - minIdle=5 |
|
| 18 | - maxWait=6000 |
|
| 19 | - filters=stat |
|
| 20 | - timeBetweenEvictionRunsMillis=60000 |
|
| 21 | - minEvictableIdleTimeMillis=300000 |
|
| 22 | - validationQuery=select 'x' |
|
| 23 | - testOnBorrow=false |
|
| 24 | - testOnReturn=false |
|
| 25 | - testWhileIdle=true |
|
| 26 | - poolPreparedStatements: true |
|
| 27 | - maxOpenPreparedStatements: 20 |
|
| 28 | 17 | |
| 29 | - ``` |
|
| 30 | 18 | |
| 19 | +## 一、MySQL 参考手册 |
|
| 31 | 20 | |
| 32 | -## 二 Oracle 参考手册 |
|
| 21 | +### 1. 本地 JDBC 配置(文件 `dbcp.properties`) |
|
| 33 | 22 | |
| 34 | -#### 数据库配置(文件dbcp.properties)如下 |
|
| 35 | - |
|
| 36 | - |
|
| 37 | - ``` |
|
| 38 | - ########Oracle######## |
|
| 39 | - driverClassName=oracle.jdbc.OracleDriver |
|
| 40 | - url=jdbc:oracle:thin:@127.0.0.1:1521:SMOMDB |
|
| 41 | - username=username |
|
| 42 | - password=password |
|
| 43 | - validationQuery=SELECT 'x' FROM DUAL |
|
| 44 | - |
|
| 45 | - initialSize=5 |
|
| 46 | - maxActive=30 |
|
| 47 | - minIdle=5 |
|
| 48 | - maxWait=6000 |
|
| 49 | - filters=stat |
|
| 50 | - timeBetweenEvictionRunsMillis=60000 |
|
| 51 | - minEvictableIdleTimeMillis=300000 |
|
| 52 | - validationQuery=select 'x' |
|
| 53 | - testOnBorrow=false |
|
| 54 | - testOnReturn=false |
|
| 55 | - testWhileIdle=true |
|
| 56 | - poolPreparedStatements: true |
|
| 57 | - maxOpenPreparedStatements: 20 |
|
| 58 | - |
|
| 59 | - ``` |
|
| 60 | - |
|
| 61 | - |
|
| 62 | -## 三 PostgreSQL 参考手册 |
|
| 63 | - |
|
| 64 | -**PostgreSQL 版本:** 16.6 |
|
| 65 | - |
|
| 66 | -**下载地址:** [Open-Source, Enterprise Postgres Database Management](https://www.enterprisedb.com/downloads/postgres-postgresql-downloads) |
|
| 67 | - |
|
| 68 | - |
|
| 69 | -### 第一节.本地和Docker安装步骤 |
|
| 70 | -#### 1. 本地安装 PG |
|
| 71 | -以下是在本地 Windows 系统上安装 PostgreSQL 16.6 的流程: |
|
| 72 | - |
|
| 73 | -1. **下载安装包** |
|
| 74 | - |
|
| 75 | - - 访问 [PostgreSQL 官方下载页面](https://www.postgresql.org/download/windows/) |
|
| 76 | - - 选择适合您系统的安装包 |
|
| 77 | - |
|
| 78 | -2. **运行安装程序** |
|
| 79 | - |
|
| 80 | - - 双击下载的安装程序文件,启动安装向导 |
|
| 81 | - - 在安装向导中,选择安装组件,包括 `PostgreSQL Server`、`pgAdmin 4` 和 `Command Line Tools` 等 |
|
| 82 | - |
|
| 83 | -3. **配置安装选项** |
|
| 84 | - |
|
| 85 | - - **选择安装目录**:默认安装目录为 `C:\Program Files\PostgreSQL\16`,可根据需要更改 |
|
| 86 | - - **设置数据目录**:默认数据目录为 `C:\Program Files\PostgreSQL\16\data`,可根据需要更改 |
|
| 87 | - - **设置超级用户密码**:输入并确认超级用户 `postgres` 的密码 |
|
| 88 | - - **设置端口号**:默认端口号为 `5432`,可根据需要更改 |
|
| 89 | - - **配置高级选项**:如需,可配置其他高级选项,如 `locale` 和 `encoding` 等 |
|
| 90 | - |
|
| 91 | -4. **完成安装** |
|
| 92 | - |
|
| 93 | - - 点击 `Install` 按钮开始安装 |
|
| 94 | - - 安装完成后,可选择是否启动 `Stack Builder` 来安装其他工具和驱动程序 |
|
| 95 | - |
|
| 96 | -5. **验证安装** |
|
| 97 | - |
|
| 98 | - - 打开 `Dbeaver`,连接到本地服务器,数据库: `postgres`,默认端口: `5432`,输入超级用户 `postgres` 的密码,验证连接是否成功 |
|
| 99 | - - 打开命令行工具,输入 `psql -U postgres -h localhost -p 5432`,验证是否可以成功登录到数据库 |
|
| 100 | - - PostgreSQL 默认的数据库名字是 `postgres`,默认的模式 `schema` 是: `public`,pg 的模式相当于 MySQL 的数据库,可以创建不同的模式 |
|
| 101 | - |
|
| 102 | -6. **DBCP 配置** |
|
| 103 | - |
|
| 104 | - ```properties |
|
| 105 | - ########postgresql######## |
|
| 106 | - driverClassName=org.postgresql.Driver |
|
| 107 | - url=jdbc:postgresql://localhost:5432/postgres?currentSchema=public |
|
| 108 | - username=postgres |
|
| 109 | - password=****** |
|
| 110 | - ``` |
|
| 111 | - |
|
| 112 | -**参考资料** |
|
| 113 | - |
|
| 114 | -- [PostgreSQL 官方文档](https://www.postgresql.org/docs/) |
|
| 115 | -- [PostgreSQL 16 在 Windows 下安装](https://www.cnblogs.com/lwx11111/p/18375300) |
|
| 116 | -- [Windows 10 上安装 PostgreSQL 16](https://blog.csdn.net/fengbingchun/article/details/141750748) |
|
| 117 | -- [PostgreSQL 在 Windows 上的安装与配置](https://geek-docs.com/postgresql/postgresql-questions/218_tk_1704601434.html) |
|
| 118 | - |
|
| 119 | -#### 2. Docker 安装 PG |
|
| 120 | - |
|
| 121 | -以下是在 `120` 机器上,使用 Docker 安装 PostgreSQL 16.6 的流程: |
|
| 122 | - |
|
| 123 | -1. **拉取镜像** |
|
| 124 | - |
|
| 125 | - 从 Docker Hub 上拉取 PostgreSQL 16.6 的镜像: |
|
| 126 | - |
|
| 127 | - ```bash |
|
| 128 | - docker pull swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/postgres:16.6-alpine3.21 |
|
| 129 | - docker tag swr.cn-north-4.myhuaweicloud.com/ddn-k8s/docker.io/postgres:16.6-alpine3.21 docker.io/postgres:16.6 |
|
| 130 | - ``` |
|
| 131 | - |
|
| 132 | -2. **创建并运行 PostgreSQL 容器** |
|
| 133 | - |
|
| 134 | - 使用以下命令创建并运行一个 PostgreSQL 容器,并配置数据持久化: |
|
| 135 | - |
|
| 136 | - ```bash |
|
| 137 | - docker run --name postgres16 -e POSTGRES_PASSWORD=mysecretpassword -p 5432:5432 -v /opt/postgresql/data:/var/lib/postgresql/data -d docker.io/postgres:16.6 |
|
| 138 | - ``` |
|
| 139 | - |
|
| 140 | - - `--name postgres16`:指定容器名称为 `postgres16` |
|
| 141 | - - `-e POSTGRES_PASSWORD=mysecretpassword`:设置 PostgreSQL 的超级用户密码 |
|
| 142 | - - `-p 5432:5432`:将容器的 5432 端口映射到主机的 5432 端口 |
|
| 143 | - - `-v /opt/postgresql/data:/var/lib/postgresql/data`:将主机的目录(`/opt/postgresql/data`)挂载到容器的数据目录(`/var/lib/postgresql/data`),以实现数据持久化 |
|
| 144 | - |
|
| 145 | -3. **进入容器** |
|
| 146 | - |
|
| 147 | - 如果需要进入容器内部,可以使用以下命令: |
|
| 148 | - |
|
| 149 | - ```bash |
|
| 150 | - docker exec -it postgres16 bash |
|
| 151 | - ``` |
|
| 152 | - |
|
| 153 | -4. **连接到数据库** |
|
| 154 | - |
|
| 155 | - 在容器内部或宿主机上,可以使用 `psql` 命令连接到数据库: |
|
| 156 | - |
|
| 157 | - ```bash |
|
| 158 | - psql -U postgres -h localhost -p 5432 |
|
| 159 | - ``` |
|
| 160 | - |
|
| 161 | - - `-U postgres`:指定用户名为 `postgres` |
|
| 162 | - - `-h localhost`:指定主机名为 `localhost` |
|
| 163 | - - `-p 5432`:指定端口号为 `5432` |
|
| 164 | - |
|
| 165 | -5. **DBCP 配置** |
|
| 166 | - |
|
| 167 | - 已经在 `120` 安装了 PG,测试可以直接使用。PG 默认的模式是:`public`,可以通过设置 `currentSchema` 切换模式。 |
|
| 168 | - |
|
| 169 | - ```properties |
|
| 170 | - ########postgresql######## |
|
| 171 | - driverClassName=org.postgresql.Driver |
|
| 172 | - url=jdbc:postgresql://xxx.xxx.120:5432/postgres?currentSchema=public&encoding=UTF-8&timezone=UTC |
|
| 173 | - username=postgres |
|
| 174 | - password=****** |
|
| 175 | - ``` |
|
| 176 | - |
|
| 177 | -**参考资料** |
|
| 178 | - |
|
| 179 | -- [Docker 安装 PostgreSQL 16.6](https://developer.baidu.com/article/detail.html?id=2812489) |
|
| 180 | -- [Docker+PostgreSQL 数据库](https://blog.csdn.net/shankezh/article/details/143241252) |
|
| 181 | -- [Docker 容器化部署 PostgreSQL](https://www.jianshu.com/p/c2f6759f3e75) |
|
| 182 | - |
|
| 183 | - |
|
| 184 | -### 第二节. PostgreSQL 特性 |
|
| 185 | - |
|
| 186 | -#### 2.0 特别注意:PostgreSQL 和 MySQL 中标识符大小写与引号使用对比 |
|
| 187 | - |
|
| 188 | -##### 1. PostgreSQL 中的处理方式 |
|
| 189 | - |
|
| 190 | -**表名和字段名大小写** |
|
| 191 | - |
|
| 192 | -- **默认行为**:PostgreSQL 在 SQL 查询时会自动将大写标识符转换为小写 |
|
| 193 | - |
|
| 194 | -- **双引号影响**:如果标识符用双引号括起来,则保留原始大小写 |
|
| 195 | - |
|
| 196 | - ```sql |
|
| 197 | - SELECT * FROM MyTable; -- 实际查询的是 mytable |
|
| 198 | - SELECT * FROM "MyTable"; -- 查询的是保留大小写的 MyTable |
|
| 199 | - ``` |
|
| 200 | - |
|
| 201 | -**引号使用** |
|
| 202 | - |
|
| 203 | -- **单引号 ('')**:用于字符串值 |
|
| 204 | -- **双引号 ("")**:用于标识符(表名、列名等) |
|
| 205 | -- **反引号 (``)**:PostgreSQL 不支持使用反引号 |
|
| 206 | - |
|
| 207 | -##### 2. MySQL 中的处理方式 |
|
| 208 | - |
|
| 209 | -**表名大小写敏感性** |
|
| 210 | - |
|
| 211 | -- **Windows 系统**:默认不区分大小写 |
|
| 212 | -- **Linux 系统**:默认区分大小写 |
|
| 213 | -- **控制参数**:`lower_case_table_names` 参数控制此行为 |
|
| 214 | - |
|
| 215 | -**列名大小写** |
|
| 216 | - |
|
| 217 | -- **所有系统**:列名不区分大小写 |
|
| 218 | - |
|
| 219 | - ```sql |
|
| 220 | - SELECT mycolumn FROM mytable; -- 与 SELECT MyColumn FROM MyTable 相同 |
|
| 221 | - ``` |
|
| 222 | - |
|
| 223 | -**引号使用** |
|
| 224 | - |
|
| 225 | -- **单引号 ('')** 和 **双引号 ("")**:都可用于字符串值 |
|
| 226 | - |
|
| 227 | -- **反引号 (``)**:用于标识符(表名、列名等),特别是在标识符与关键字冲突或包含特殊字符时 |
|
| 228 | - |
|
| 229 | - ```sql |
|
| 230 | - SELECT `select` FROM `table`; |
|
| 231 | - ``` |
|
| 232 | - |
|
| 233 | -**标识符大小写敏感性** |
|
| 234 | - |
|
| 235 | -- **未加引号的标识符**:大小写不敏感 |
|
| 236 | - |
|
| 237 | - ```sql |
|
| 238 | - UPDATE MY_TABLE SET A = 5; -- 等价于 uPDaTE my_TabLE SeT a = 5; |
|
| 239 | - ``` |
|
| 240 | - |
|
| 241 | -- **加引号的标识符**:保留大小写 |
|
| 242 | - |
|
| 243 | - ```sql |
|
| 244 | - UPDATE "my_table" SET "a" = 5; -- 必须使用相同大小写引用 |
|
| 245 | - ``` |
|
| 246 | - |
|
| 247 | -**主要差异总结** |
|
| 248 | - |
|
| 249 | -| 特性 | PostgreSQL | MySQL | |
|
| 250 | -| -------------------- | ------------------ | ---------------------- | |
|
| 251 | -| 标识符默认大小写处理 | 大写转小写 | 取决于系统和配置 | |
|
| 252 | -| 保留大小写的方式 | 使用双引号 | 使用反引号 | |
|
| 253 | -| 字符串引号 | 仅单引号 | 单引号或双引号 | |
|
| 254 | -| 标识符引号 | 双引号 | 反引号 | |
|
| 255 | -| 列名大小写敏感性 | 取决于是否加双引号 | 所有系统都不区分大小写 | |
|
| 256 | - |
|
| 257 | - |
|
| 258 | - |
|
| 259 | - |
|
| 260 | -#### 2.1 Boolean 值问题 |
|
| 261 | -PostgreSQL 支持 `boolean` 类型,但我们引擎是使用 `char(1)` 代替 `boolean`。插入到数据的时候我们插入 `char(1)`,查询的时候返回 `boolean` 值。 |
|
| 262 | - |
|
| 263 | -```sql |
|
| 264 | -CREATE TABLE example ( |
|
| 265 | - is_active CHAR(1) |
|
| 266 | -); |
|
| 267 | -``` |
|
| 268 | - |
|
| 269 | -#### 2.2 索引问题 |
|
| 270 | -在 PostgreSQL 里,索引名称的最大长度受标识符最大长度限制,官方规定标识符最大长度为 63 字节。若标识符(如表名、列名、索引名等)长度超 63 字节,会自动截断并发出警告。 |
|
| 271 | - |
|
| 272 | -**1. PostgreSQL 索引命名规则与实践** |
|
| 273 | - |
|
| 274 | -1. **基本规则** |
|
| 275 | - |
|
| 276 | - - **长度**:索引名最长 63 字节,超量自动截断并告警 |
|
| 277 | - - **字符集**:可含字母、数字、下划线和特殊字符,建议只用前三者 |
|
| 278 | - - **大小写**:默认转小写存储,用双引号包裹可保留大小写 |
|
| 279 | - - **唯一性**:在同一个 `schema` 中,索引名称必须唯一,创建同名索引会引发错误 |
|
| 280 | - |
|
| 281 | -2. **命名限制** |
|
| 282 | - |
|
| 283 | - - **长度**:长度超过 63 字节会被截断。 |
|
| 284 | - |
|
| 285 | - ```sql |
|
| 286 | - CREATE INDEX this_is_a_very_long_index_name_that_exceeds_the_maximum_length_of_sixty_three_bytes ON my_table(my_column); |
|
| 287 | - -- PostgreSQL 会将其截断为 |
|
| 288 | - this_is_a_very_long_index_name_that_exceeds_the_maximum_length_of_sixty_three |
|
| 289 | - ``` |
|
| 290 | - |
|
| 291 | - - **大小写**:默认转小写,用 `"MyIndex"` 可保留 |
|
| 292 | - |
|
| 293 | - - **特殊字符**:可含特殊字符,但可能有兼容性问题,如 `"my_index$1"` |
|
| 294 | - |
|
| 295 | - - **唯一性**:同一 `schema` 内重名报错,如 `CREATE INDEX my_index ON my_table(my_column);` 后再创建同名索引会冲突。 |
|
| 296 | - |
|
| 297 | - ```sql |
|
| 298 | - CREATE INDEX my_index ON my_table(my_column); |
|
| 299 | - CREATE INDEX my_index ON my_table(another_column); -- 错误:索引名称冲突 |
|
| 300 | - ``` |
|
| 301 | - |
|
| 302 | -3. **最佳实践** |
|
| 303 | - |
|
| 304 | - - **索引名称应反映其用途**:如 `idx_table_column` 表示普通索引,`uk_table_column` 表示唯一约束索引。例如: |
|
| 305 | - |
|
| 306 | - - `idx_table_column`:表示在 `table` 表的 `column` 列上创建的索引 |
|
| 307 | - - `uk_table_column`:表示在 `table` 表的 `column` 列上创建的唯一约束索引 |
|
| 308 | - |
|
| 309 | - - **避保留字**:不用 `SELECT`、`INSERT` 等保留字命名 |
|
| 310 | - |
|
| 311 | - - **使用一致的命名规则**: |
|
| 312 | - |
|
| 313 | - - 前缀:使用 `idx_` 表示普通索引,`uk_` 表示唯一索引,`pk_` 表示主键索引 |
|
| 314 | - - 表名和列名:在索引名称中包含表名和列名 |
|
| 315 | - |
|
| 316 | - 例如: |
|
| 317 | - |
|
| 318 | - ```sql |
|
| 319 | - CREATE INDEX idx_users_email ON users(email); |
|
| 320 | - CREATE UNIQUE INDEX uk_users_username ON users(username); |
|
| 321 | - ``` |
|
| 322 | - |
|
| 323 | - - **长度限制**:避免超过 63 字节 |
|
| 324 | - |
|
| 325 | -4. **修改索引名** |
|
| 326 | - |
|
| 327 | - 使用 `ALTER INDEX old_index_name RENAME TO new_index_name;` 修改 |
|
| 328 | - |
|
| 329 | -5. **查看索引名** |
|
| 330 | - |
|
| 331 | - 用以下 SQL 查询: |
|
| 332 | - |
|
| 333 | - ```sql |
|
| 334 | - SELECT schemaname, tablename, indexname |
|
| 335 | - FROM pg_indexes |
|
| 336 | - WHERE schemaname NOT LIKE 'pg_%' |
|
| 337 | - ORDER BY schemaname, tablename, indexname; |
|
| 338 | - ``` |
|
| 339 | - |
|
| 340 | - |
|
| 341 | - |
|
| 342 | -#### 2.3 支持Transactional DDL |
|
| 343 | - |
|
| 344 | -**1. 参考资料** |
|
| 345 | - |
|
| 346 | -- [PostgreSQL 中的事务性 DDL: 数据库对比](https://www.rockdata.net/zh-cn/blog/transactional-ddl/) |
|
| 347 | -- [Transactional DDL in PostgreSQL: A Competitive Analysis](https://wiki.postgresql.org/wiki/Transactional_DDL_in_PostgreSQL:_A_Competitive_Analysis) |
|
| 348 | - |
|
| 349 | -**2. 什么是 Transactional DDL?** |
|
| 350 | - |
|
| 351 | -Transactional(事务)在关系型数据库是指一组 SQL 语句,要么提交,要么全部回滚。事务中包含的语句通常是 DML 语句,如 `INSERT`、`UPDATE`、`DELETE` 等。但对于 DDL 语句呢?是否可以在事务中包含诸如 `CREATE`、`ALTER`、`DROP` 等 DDL 命令? |
|
| 352 | - |
|
| 353 | -所谓 Transactional DDL 就是我们可以把 DDL 放到事务中,做到事务中的 DDL 语句要么全部提交,要么全部回滚。 |
|
| 354 | - |
|
| 355 | -**看个 PG 的例子** |
|
| 356 | - |
|
| 357 | -```sql |
|
| 358 | -postgres=# begin; |
|
| 359 | -BEGIN |
|
| 360 | -postgres=*# create table a_test(id int); |
|
| 361 | -CREATE TABLE |
|
| 362 | -postgres=*# insert into a_test values(1); |
|
| 363 | -INSERT 0 1 |
|
| 364 | -postgres=*# rollback; |
|
| 365 | -ROLLBACK |
|
| 366 | -postgres=# select * from a_test; |
|
| 367 | -ERROR: relation "a_test" does not exist |
|
| 368 | -LINE 1: select * from a_test; |
|
| 369 | - ^ |
|
| 370 | -postgres=# |
|
| 371 | -``` |
|
| 372 | - |
|
| 373 | -可见,在 PostgreSQL 中,是支持 Transactional DDL 的,在上例中,`create table` 语句被回滚掉了。 |
|
| 374 | - |
|
| 375 | -并不是所有数据库都支持 Transactional DDL,比如 MySQL。 |
|
| 376 | - |
|
| 377 | -**看个 MySQL 的例子** |
|
| 378 | - |
|
| 379 | -```sql |
|
| 380 | -mysql> begin; |
|
| 381 | -Query OK, 0 rows affected (0.00 sec) |
|
| 382 | - |
|
| 383 | -mysql> create table a_test (id int); |
|
| 384 | -Query OK, 0 rows affected (0.04 sec) |
|
| 385 | - |
|
| 386 | -mysql> insert into a_test values(1); |
|
| 387 | -Query OK, 1 row affected (0.01 sec) |
|
| 388 | - |
|
| 389 | -mysql> rollback; |
|
| 390 | -Query OK, 0 rows affected (0.00 sec) |
|
| 391 | - |
|
| 392 | -mysql> select * from a_test; |
|
| 393 | -+------+ |
|
| 394 | -| id | |
|
| 395 | -+------+ |
|
| 396 | -| 1 | |
|
| 397 | -+------+ |
|
| 398 | -1 row in set (0.00 sec) |
|
| 399 | -``` |
|
| 400 | - |
|
| 401 | -可以看到 MySQL 这个例子里,不仅 `create` 语句没有回滚掉,`insert` 语句也没有回滚掉。这是因为:在 MySQL 中,当执行 DDL 语句时,会隐式地将当前会话的事务进行一次提交操作。所以我们应该严格地将 DDL 和 DML 完全分开,不能混合在一起执行。 |
|
| 402 | - |
|
| 403 | -**一些特例** |
|
| 404 | - |
|
| 405 | -需要注意的是在 PG 中并不是所有的 DDL 都支持 Transactional DDL。比如 `CREATE INDEX CONCURRENTLY`、`CREATE DATABASE`、`CREATE TABLESPACE` 等等。 |
|
| 406 | - |
|
| 407 | -```sql |
|
| 408 | -postgres=# begin; |
|
| 409 | -BEGIN |
|
| 410 | -postgres=*# CREATE INDEX CONCURRENTLY idx_id ON a_test (id); |
|
| 411 | -ERROR: CREATE INDEX CONCURRENTLY cannot run inside a transaction block |
|
| 412 | -``` |
|
| 413 | - |
|
| 414 | -**3. Transactional DDL 的好处** |
|
| 415 | - |
|
| 416 | -在进行一些模式升级等复杂工作时,可以利用此功能保护数据库。我们可以将所有更改都放入事务块中,确保它们都以原子方式应用,或者根本不应用。这大大降低了数据库因模式更改中的输入错误或其他此类错误而损坏数据库的可能性。 |
|
| 417 | - |
|
| 418 | -**4. PG 中的事务性 DDL: 数据库对比** |
|
| 419 | - |
|
| 420 | -**事务性 DDL** |
|
| 421 | - |
|
| 422 | -与一些商业数据库一样,PostgreSQL 中有一个比较高级的功能,它能够通过其 [预写式日志](https://www.rockdata.net/zh-cn/docs/14/wal.html) 的设计执行事务性 DDL。该设计支持回退 DDL 产生的重大更改,例如表创建。您无法恢复添加和删除数据库或表空间的操作,但所有其他的对象操作都是可逆的。 |
|
| 423 | - |
|
| 424 | -**PostgreSQL** |
|
| 425 | - |
|
| 426 | -下面是一个示例,显示了 PostgreSQL 的设计在这方面的处理能力: |
|
| 427 | - |
|
| 428 | -```sql |
|
| 429 | -DROP TABLE IF EXISTS foo; |
|
| 430 | -NOTICE: table "foo" does not exist |
|
| 431 | - |
|
| 432 | -BEGIN; |
|
| 433 | -CREATE TABLE foo (bar int); |
|
| 434 | -INSERT INTO foo VALUES (1); |
|
| 435 | -ROLLBACK; |
|
| 436 | - |
|
| 437 | -SELECT * FROM foo; |
|
| 438 | -ERROR: relation "foo" does not exist |
|
| 439 | -``` |
|
| 440 | - |
|
| 441 | -有经验的 PostgreSQL DBA 知道,在执行表结构升级等复杂工作时,可利用此功能来保护自己。如果你把所有这些变更都放到一个事务块中,你可以确保它们都以原子方式进行应用,或者完全不应用。这大大降低了数据库因架构变更中的拼写错误或其他此类错误而损坏的可能性,这在修改多个相关表时尤为重要,因为错误可能会破坏关系键。 |
|
| 442 | - |
|
| 443 | -**MySQL** |
|
| 444 | - |
|
| 445 | -如果您在使用 MySQL,则无法以这种方式撤消 DDL 和一些类似的更改。如果您使用的是 MyISAM 存储引擎,那它根本不支持事务。对于 InnoDB 存储引擎,服务端有一种 [隐式提交](https://dev.mysql.com/doc/refman/8.4/en/implicit-commit.html),即使关闭了正常的自动提交行为,DDL 命令也会导致当前事务发生隐式提交。 |
|
| 446 | - |
|
| 447 | -```sql |
|
| 448 | -set autocommit = 0; |
|
| 449 | - |
|
| 450 | -drop table foo; |
|
| 451 | - |
|
| 452 | -create table foo (bar int) engine=InnoDB; |
|
| 453 | - |
|
| 454 | -insert into foo values (1); |
|
| 455 | - |
|
| 456 | -rollback; |
|
| 457 | - |
|
| 458 | -select * from foo; |
|
| 459 | -Empty set (0.00 sec) |
|
| 460 | -``` |
|
| 461 | - |
|
| 462 | -**Oracle** |
|
| 463 | - |
|
| 464 | -一个事务从第一个可执行的 SQL 语句开始。事务在提交或回滚时结束,无论是显式使用 `COMMIT` 或 `ROLLBACK` 语句,还是在发出 DDL 语句时隐式提交。 |
|
| 465 | - |
|
| 466 | -Oracle 数据库在以下情况下会发生隐式 `COMMIT`: |
|
| 467 | - |
|
| 468 | -- 在任何语法上有效的数据定义语言(DDL)的语句之前,即使该语句发生了错误 |
|
| 469 | -- 在任何没有发生错误执行完成的数据定义语言(DDL)语句之后 |
|
| 470 | - |
|
| 471 | -让我们在 Oracle 中创建一个表,并插入一行: |
|
| 472 | - |
|
| 473 | -```sql |
|
| 474 | --- Create a table and insert a row |
|
| 475 | -CREATE TABLE states |
|
| 476 | -( |
|
| 477 | - abbr CHAR(2), |
|
| 478 | - name VARCHAR2(90) |
|
| 479 | -); |
|
| 480 | - |
|
| 481 | --- Transaction will be in progress after this insert |
|
| 482 | -INSERT INTO states VALUES ('CA', 'California'); |
|
| 483 | -``` |
|
| 484 | - |
|
| 485 | -现在,让我们创建另一个表,并执行 `ROLLBACK` 操作: |
|
| 486 | - |
|
| 487 | -```sql |
|
| 488 | --- Create another table table and insert a row |
|
| 489 | -CREATE TABLE cities |
|
| 490 | -( |
|
| 491 | - name VARCHAR2(90), |
|
| 492 | - state CHAR(2) |
|
| 493 | -); |
|
| 494 | - |
|
| 495 | -INSERT INTO cities VALUES ('San Francisco', 'CA'); |
|
| 496 | - |
|
| 497 | -ROLLBACK; |
|
| 498 | -``` |
|
| 499 | - |
|
| 500 | -您可以看到,即使在 `ROLLBACK` 之后,表 `states` 和表中的行仍然存在,因为 `CREATE TABLE cities` 语句提交了事务。 |
|
| 501 | - |
|
| 502 | -表 `cities` 也存在,但插入的行已回滚: |
|
| 503 | - |
|
| 504 | -```sql |
|
| 505 | --- Table states exists and contains 1 row |
|
| 506 | -SELECT COUNT(*) FROM states; |
|
| 507 | --- Result: 1 |
|
| 508 | - |
|
| 509 | --- Table cities also exists, but the inserted row was rolled back |
|
| 510 | -SELECT COUNT(*) FROM cities; |
|
| 511 | --- Result: 0 |
|
| 512 | -``` |
|
| 513 | - |
|
| 514 | - |
|
| 515 | - |
|
| 516 | -#### 2.4 数据类型转换规则 |
|
| 517 | - |
|
| 518 | -PostgreSQL 的自动类型转换规则是比较严格的,尤其是从字符串到其他类型的转换,通常需要显式指定 PostgreSQL 要求显式的数据类型转换。 |
|
| 519 | - |
|
| 520 | -**1. 示例:数据类型转换错误** |
|
| 521 | - |
|
| 522 | -```sql |
|
| 523 | -INSERT INTO a_test (age) VALUES ('123'); -- 错误:字段 "age" 的类型为 integer, 但表达式的类型为 character varying |
|
| 524 | -``` |
|
| 525 | - |
|
| 526 | -**2. 解决方法** |
|
| 527 | - |
|
| 528 | -在插入或更新数据时,确保数据类型匹配,或使用显式类型转换: |
|
| 529 | - |
|
| 530 | -```sql |
|
| 531 | -INSERT INTO a_test (age) VALUES (CAST('123' AS INTEGER)); |
|
| 532 | -``` |
|
| 533 | - |
|
| 534 | -**3. 自动类型转换(Implicit Casting)** |
|
| 535 | - |
|
| 536 | -PostgreSQL 会在某些情况下自动进行数据类型转换,以确保操作的正确性。这些情况主要是为了匹配操作符或函数的参数类型。 |
|
| 537 | - |
|
| 538 | -1. **字符串到数字的隐式转换(受限)**: |
|
| 539 | - |
|
| 540 | - - PostgreSQL 不会自动将字符串转换为数字类型(如 `integer` 或 `numeric`)。例如: |
|
| 541 | - |
|
| 542 | - ```sql |
|
| 543 | - SELECT '123' + 456; -- 报错:类型不匹配 |
|
| 544 | - ``` |
|
| 545 | - |
|
| 546 | - 如果要进行这种操作,必须显式转换类型。 |
|
| 547 | - |
|
| 548 | -2. **字符串与字符串的连接**: |
|
| 549 | - |
|
| 550 | - - 如果两个操作数都是字符串类型,可以自动进行连接操作: |
|
| 551 | - |
|
| 552 | - ```sql |
|
| 553 | - SELECT 'Hello' || 'World'; -- 结果为 'HelloWorld' |
|
| 554 | - ``` |
|
| 555 | - |
|
| 556 | -3. **字符串与其他类型的隐式转字符串**: |
|
| 557 | - |
|
| 558 | - - 如果一个操作符或函数期望一个字符串类型的参数,而提供的是一个非字符串类型,PostgreSQL 会尝试将其隐式转换为字符串: |
|
| 559 | - |
|
| 560 | - ```sql |
|
| 561 | - SELECT 42 || ' apples'; -- 结果为 '42 apples' |
|
| 562 | - ``` |
|
| 563 | - |
|
| 564 | -4. **显式类型转换(Explicit Casting)** |
|
| 565 | - |
|
| 566 | -显式类型转换是 PostgreSQL 中推荐的做法,用于明确地将数据从一种类型转换为另一种类型。以下是几种常用的显式类型转换方法: |
|
| 567 | - |
|
| 568 | -1. **使用 `CAST` 函数**: |
|
| 569 | - |
|
| 570 | - - `CAST` 是标准 SQL 提供的类型转换函数。例如: |
|
| 571 | - |
|
| 572 | - ```sql |
|
| 573 | - SELECT CAST('123' AS INTEGER); -- 结果为 123 |
|
| 574 | - ``` |
|
| 575 | - |
|
| 576 | - 你也可以指定其他目标类型,如 `DOUBLE PRECISION`、`DATE` 等: |
|
| 577 | - |
|
| 578 | - ```sql |
|
| 579 | - SELECT CAST('3.1415' AS NUMERIC(5,2)); -- 结果为 3.14 |
|
| 580 | - ``` |
|
| 581 | - |
|
| 582 | -2. **使用列定义语法**: |
|
| 583 | - |
|
| 584 | - - 使用列定义语法也可以进行类型转换。例如: |
|
| 585 | - |
|
| 586 | - ```sql |
|
| 587 | - SELECT '2024-01-01'::DATE; -- 结果为 2024-01-01 |
|
| 588 | - ``` |
|
| 589 | - |
|
| 590 | - 这种方法与 `CAST` 功能相同,但语法更简洁。 |
|
| 591 | - |
|
| 592 | -3. **使用 `::` 运算符**: |
|
| 593 | - |
|
| 594 | - - `::` 是 PostgreSQL 提供的快捷方式,用于类型转换。例如: |
|
| 595 | - |
|
| 596 | - ```sql |
|
| 597 | - SELECT '25'::integer; -- 结果为 25 |
|
| 598 | - ``` |
|
| 599 | - |
|
| 600 | -5. **类型转换的注意事项** |
|
| 601 | - |
|
| 602 | -1. **避免非显式转换**: |
|
| 603 | - |
|
| 604 | - - 尽量避免依赖隐式类型转换,因为它可能导致意外的错误。例如: |
|
| 605 | - |
|
| 606 | - ```sql |
|
| 607 | - INSERT INTO users (age) VALUES ('25'); -- 报错,除非 `age` 是 `VARCHAR` 类型 |
|
| 608 | - ``` |
|
| 609 | - |
|
| 610 | - 如果 `age` 是 `BOOLEAN` 类型,而你尝试插入 `TRUE`,必须显式转换为布尔值: |
|
| 611 | - |
|
| 612 | - ```sql |
|
| 613 | - INSERT INTO users (age) VALUES (TRUE::BOOLEAN); |
|
| 614 | - ``` |
|
| 615 | - |
|
| 616 | -2. **处理文本与日期/时间**: |
|
| 617 | - |
|
| 618 | - - 当将字符串转换为日期或时间类型时,必须遵循正确的格式。例如: |
|
| 619 | - |
|
| 620 | - ```sql |
|
| 621 | - SELECT CAST('2023-10-05' AS DATE); -- 正确 |
|
| 622 | - SELECT CAST('10/05/2023' AS DATE); -- 抛出错误,因为格式不匹配 |
|
| 623 | - ``` |
|
| 624 | - |
|
| 625 | - 如果需要将日期以特定格式存储或解析,可以使用 `TO_DATE` 函数: |
|
| 626 | - |
|
| 627 | - ```sql |
|
| 628 | - SELECT TO_DATE('05-OCT-2023', 'DD-MON-YYYY'); -- 结果为 2023-10-05 |
|
| 629 | - ``` |
|
| 630 | - |
|
| 631 | -3. **数组类型的转换**: |
|
| 632 | - |
|
| 633 | - - 数组之间的类型转换通常比标量类型更复杂。例如,将 `{1,2,3}` 转换为 `int[]` 是可以直接的: |
|
| 634 | - |
|
| 635 | - ```sql |
|
| 636 | - SELECT '{1,2,3}'::int[]; -- 正确 |
|
| 637 | - ``` |
|
| 638 | - |
|
| 639 | - 但是,将字符串数组转换为其他类型数组可能需要额外的处理。 |
|
| 640 | - |
|
| 641 | -4. **类型转换失败**: |
|
| 642 | - |
|
| 643 | - - 如果转换无法完成,PostgreSQL 会抛出错误。例如: |
|
| 644 | - |
|
| 645 | - ```sql |
|
| 646 | - SELECT CAST('text' AS INTEGER); -- 抛出错误:invalid input syntax for type integer |
|
| 647 | - ``` |
|
| 648 | - |
|
| 649 | -6. **示例** |
|
| 650 | - |
|
| 651 | -以下是一些常见的类型转换示例: |
|
| 652 | - |
|
| 653 | -1. **将字符串转换为整数**: |
|
| 654 | - |
|
| 655 | - ```sql |
|
| 656 | - SELECT CAST('42' AS INTEGER); -- 结果为 42 |
|
| 657 | - SELECT '42'::integer; -- 同上 |
|
| 658 | - ``` |
|
| 659 | - |
|
| 660 | -2. **将数字转换为字符串**: |
|
| 661 | - |
|
| 662 | - ```sql |
|
| 663 | - SELECT CAST(42 AS VARCHAR); -- 结果为 '42' |
|
| 664 | - ``` |
|
| 665 | - |
|
| 666 | -3. **将布尔值转换为整数(逻辑上不推荐,但支持)**: |
|
| 667 | - |
|
| 668 | - ```sql |
|
| 669 | - SELECT CAST(TRUE AS INTEGER); -- 结果为 1 |
|
| 670 | - SELECT CAST(FALSE AS INTEGER); -- 结果为 0 |
|
| 671 | - ``` |
|
| 672 | - |
|
| 673 | -4. **将字符串转换为布尔值**: |
|
| 674 | - |
|
| 675 | - ```sql |
|
| 676 | - SELECT CAST('t' AS BOOLEAN); -- 结果为 TRUE |
|
| 677 | - SELECT CAST('false' AS BOOLEAN); -- 结果为 FALSE |
|
| 678 | - ``` |
|
| 679 | - |
|
| 680 | - |
|
| 681 | - |
|
| 682 | -#### 2.5 PostgreSQL 错误:current transaction is aborted, commands ignored until end of transaction block |
|
| 683 | - |
|
| 684 | -**1. 错误概述** |
|
| 685 | - |
|
| 686 | -当 PostgreSQL 事务中的某条 SQL 语句执行失败时,整个事务会进入 **中止状态**(Aborted)。所有后续的 SQL 命令都会被忽略,直到事务被回滚或关闭。此时任何后续操作都会触发以下错误:`current transaction is aborted, commands ignored until end of transaction block`。 |
|
| 687 | -**核心问题**:事务未正确终止(未提交或回滚),导致数据库连接处于不可用状态。 |
|
| 688 | - |
|
| 689 | -**错误信息**: |
|
| 690 | - |
|
| 691 | -```java |
|
| 692 | -caused by: org.postgresql.util.PSQLException: 错误: 当前事务被终止, 事务块结束之前的查询被忽略 |
|
| 693 | -current transaction is aborted, commands ignored until end of transaction block |
|
| 694 | -``` |
|
| 695 | - |
|
| 696 | - |
|
| 697 | -**2. 事务块中语句错误的回滚行为:数据库对比** |
|
| 698 | - |
|
| 699 | -**摘要**:在本文中,我们将学习事务块中语句错误的回滚行为,以及 PostgreSQL 和 Oracle 之间的区别。 |
|
| 700 | - |
|
| 701 | -**参考文章** |
|
| 702 | - |
|
| 703 | -- [PostgreSQL - ERROR: current transaction is aborted](https://www.rockdata.net/zh-cn/blog/rollback-on-statement-error/#postgresql---error-current-transaction-is-aborted) |
|
| 704 | -- [Oracle 语句级回滚](https://www.rockdata.net/zh-cn/blog/rollback-on-statement-error/#oracle-语句级回滚) |
|
| 705 | - |
|
| 706 | -通常,您制造的任何错误都会引发异常,并导致当前事务被标记为中止。这是理智和预期的行为,但如果它发生在您运行大型事务并输入了错误内容时,这可能会非常的烦人!此时,您唯一能做的就是回滚事务并丢弃所有工作。 |
|
| 707 | - |
|
| 708 | -当您在 PostgreSQL 中遇到错误时,事务是无法继续的。例如: |
|
| 709 | - |
|
| 710 | -```sql |
|
| 711 | -DROP TABLE IF EXISTS demo; |
|
| 712 | - |
|
| 713 | -START TRANSACTION; |
|
| 714 | -CREATE TABLE demo(n, t) AS SELECT 1 n, current_timestamp t; |
|
| 715 | -ALTER TABLE demo ADD UNIQUE(n); |
|
| 716 | - |
|
| 717 | -SELECT * FROM demo; |
|
| 718 | - n | t |
|
| 719 | ----+------------------------------- |
|
| 720 | - 1 | 2021-06-26 18:15:07.207671+08 |
|
| 721 | -(1 row) |
|
| 722 | - |
|
| 723 | -INSERT INTO demo VALUES (2, current_timestamp); |
|
| 724 | -SELECT * FROM demo; |
|
| 725 | - n | t |
|
| 726 | ----+------------------------------- |
|
| 727 | - 1 | 2021-06-26 18:15:07.207671+08 |
|
| 728 | - 2 | 2021-06-26 18:15:07.207671+08 |
|
| 729 | -(2 rows) |
|
| 730 | - |
|
| 731 | -INSERT INTO demo VALUES (1, current_timestamp); |
|
| 732 | -ERROR: duplicate key value violates unique constraint "demo_n_key" |
|
| 733 | -DETAIL: Key (n)=(1) already exists. |
|
| 734 | - |
|
| 735 | -SELECT * FROM demo; |
|
| 736 | -ERROR: current transaction is aborted, commands ignored until end of transaction block |
|
| 737 | - |
|
| 738 | -ROLLBACK; |
|
| 739 | - |
|
| 740 | -SELECT * FROM demo; |
|
| 741 | -ERROR: relation "demo" does not exist |
|
| 742 | -LINE 1: SELECT * FROM demo; |
|
| 743 | -``` |
|
| 744 | - |
|
| 745 | -在这里我们进行了回滚。但其实也可以提交来终止事务,但它无论如何都会回滚: |
|
| 746 | - |
|
| 747 | -```sql |
|
| 748 | -COMMIT; |
|
| 749 | - |
|
| 750 | -SELECT * FROM demo; |
|
| 751 | -ERROR: relation "demo" does not exist |
|
| 752 | -LINE 1: SELECT * FROM demo; |
|
| 753 | -``` |
|
| 754 | - |
|
| 755 | -**Oracle 语句级回滚** |
|
| 756 | - |
|
| 757 | -如果在执行过程中的任何时候,SQL 语句发生错误,则该语句的所有更改都将回滚。回滚的效果就好像该语句从未执行过一样。这是一种语句级的回滚。 |
|
| 758 | - |
|
| 759 | -在 SQL 语句执行过程中发生的错误会导致语句级回滚。(此类错误的一个示例是,尝试在主键中插入重复值。在 SQL 语句解析过程中发生的错误(如语法错误)尚未执行,因此不会导致语句级回滚。涉及死锁(争用相同数据)的单个 SQL 语句也可能导致语句级回滚。 |
|
| 760 | - |
|
| 761 | -失败的 SQL 语句只会导致丢失它自己执行的任何工作;它不会导致在当前事务中丢失之前的任何工作。如果该语句是 DDL 语句,则不会撤消紧接在它前面的隐式提交。 |
|
| 762 | - |
|
| 763 | -在 Oracle 中,在一次用户调用中有一个语句失败时,将会回滚该用户调用所做的修改,但不会回滚之前的修改。事务还可以继续(如重试,或执行替代的更改),例如: |
|
| 764 | - |
|
| 765 | -```sql |
|
| 766 | -CREATE TABLE DEMO AS SELECT 1 n, current_timestamp t FROM dual; |
|
| 767 | -ALTER TABLE DEMO ADD UNIQUE(n); |
|
| 768 | - |
|
| 769 | -SELECT * FROM DEMO; |
|
| 770 | - N T |
|
| 771 | ----------- ----------------------------------- |
|
| 772 | - 1 02-AUG-21 11.04.16.507292 PM +00:00 |
|
| 773 | - |
|
| 774 | -INSERT INTO DEMO VALUES (2, current_timestamp); |
|
| 775 | - |
|
| 776 | -SELECT * FROM DEMO; |
|
| 777 | - N T |
|
| 778 | ----------- ----------------------------------- |
|
| 779 | - 1 02-AUG-21 11.04.16.507292 PM +00:00 |
|
| 780 | - 2 02-AUG-21 11.04.16.601105 PM +00:00 |
|
| 781 | - |
|
| 782 | -INSERT INTO DEMO VALUES (1, current_timestamp); |
|
| 783 | -ERROR at line 1: |
|
| 784 | -ORA-00001: unique constraint (DEMO.SYS_C007847) violated |
|
| 785 | - |
|
| 786 | -SELECT * FROM DEMO; |
|
| 787 | - N T |
|
| 788 | ----------- ----------------------------------- |
|
| 789 | - 1 02-AUG-21 11.04.16.507292 PM +00:00 |
|
| 790 | - 2 02-AUG-21 11.04.16.601105 PM +00:00 |
|
| 791 | -``` |
|
| 792 | - |
|
| 793 | -**3. 错误原因** |
|
| 794 | - |
|
| 795 | -**3.1 直接原因** |
|
| 796 | - |
|
| 797 | -- **事务中的 SQL 语句执行失败**:如违反唯一约束、主键冲突、语法错误、权限不足等 |
|
| 798 | -- **事务未显式终止**:失败后未执行 `ROLLBACK` 或 `COMMIT`,事务块未关闭 |
|
| 799 | - |
|
| 800 | -**3.2 常见触发场景** |
|
| 801 | - |
|
| 802 | -| 场景 | 示例 | |
|
| 803 | -| ---------------------- | ------------------------------------------------------------ | |
|
| 804 | -| 插入重复的主键或唯一键 | `INSERT INTO users (id) VALUES (1);`(若 `id=1` 已存在) | |
|
| 805 | -| 语法错误 | `INSERT INTO table (invalid_column) VALUES (1);`(列名错误) | |
|
| 806 | -| 权限不足 | 普通用户尝试执行 `DROP TABLE` | |
|
| 807 | -| 隐式事务未处理 | ORM 框架或客户端工具默认开启事务,但未捕获异常并回滚 | |
|
| 808 | - |
|
| 809 | -**4. 解决方法** |
|
| 810 | - |
|
| 811 | -**1. 立即终止事务** |
|
| 812 | - |
|
| 813 | -通过 `ROLLBACK` 显式回滚事务,恢复数据库连接的可用状态: |
|
| 814 | - |
|
| 815 | -```sql |
|
| 816 | -ROLLBACK; -- 终止当前事务,清除错误状态 |
|
| 817 | -``` |
|
| 818 | - |
|
| 819 | -**2. 定位错误原因** |
|
| 820 | - |
|
| 821 | -1. **查看客户端返回的错误信息** |
|
| 822 | - |
|
| 823 | - 例如:`duplicate key value violates unique constraint "users_pkey"` |
|
| 824 | - |
|
| 825 | -2. **查询 PostgreSQL 日志** |
|
| 826 | - |
|
| 827 | - - 日志默认路径:`/var/log/postgresql/postgresql-<版本>-main.log` |
|
| 828 | - - 搜索关键词:`ERROR`, `ROLLBACK`, 或事务 ID(如 `process 12345`) |
|
| 829 | - |
|
| 830 | -3. **通过 SQL 获取最近错误** |
|
| 831 | - |
|
| 832 | - ```sql |
|
| 833 | - SELECT pg_last_error(); -- 部分客户端支持(如 psql) |
|
| 834 | - ``` |
|
| 835 | - |
|
| 836 | -**3. 修复并重试事务** |
|
| 837 | - |
|
| 838 | -根据错误原因调整 SQL 逻辑: |
|
| 839 | - |
|
| 840 | -- **主键冲突**:检查重复数据,或使用 `ON CONFLICT` 处理冲突。 |
|
| 841 | - |
|
| 842 | - ```sql |
|
| 843 | - INSERT INTO users (id) VALUES (1) |
|
| 844 | - ON CONFLICT (id) DO NOTHING; |
|
| 845 | - ``` |
|
| 846 | - |
|
| 847 | -- **权限问题**:授予用户权限。 |
|
| 848 | - |
|
| 849 | - ```sql |
|
| 850 | - GRANT INSERT, UPDATE ON table_name TO user_name; |
|
| 851 | - ``` |
|
| 852 | - |
|
| 853 | -**5. 高级场景与优化** |
|
| 854 | - |
|
| 855 | -**1. 使用保存点(SAVEPOINT)** |
|
| 856 | - |
|
| 857 | -在长事务中分割操作,允许部分回滚: |
|
| 858 | - |
|
| 859 | -```sql |
|
| 860 | -BEGIN; |
|
| 861 | -INSERT INTO table1 VALUES (1); |
|
| 862 | -SAVEPOINT my_savepoint; -- 设置保存点 |
|
| 863 | -INSERT INTO table2 VALUES (1); -- 假设此处失败 |
|
| 864 | -ROLLBACK TO my_savepoint; -- 回滚到保存点,继续后续操作 |
|
| 865 | -INSERT INTO table3 VALUES (1); |
|
| 866 | -COMMIT; |
|
| 867 | -``` |
|
| 868 | - |
|
| 869 | -**6. 预防措施** |
|
| 870 | - |
|
| 871 | -| 措施 | 说明 | |
|
| 872 | -| ------------------ | ----------------------------------------------------------- | |
|
| 873 | -| **短事务原则** | 减少事务执行时间,避免长事务占用锁资源。 | |
|
| 874 | -| **自动提交模式** | 在客户端工具中开启自动提交(`SET AUTOCOMMIT = ON`)。 | |
|
| 875 | -| **异常捕获与回滚** | 在所有数据库操作中强制捕获异常并回滚。 | |
|
| 876 | -| **测试与监控** | 定期模拟错误场景(如主键冲突),验证回滚逻辑是否生效。 | |
|
| 877 | -| **日志分析** | 使用工具(如 pgBadger)分析 PostgreSQL 日志,识别高频错误。 | |
|
| 878 | - |
|
| 879 | - |
|
| 880 | -#### 2.6 PostgreSQL JSON数据类型 |
|
| 881 | - |
|
| 882 | -PostgreSQL 提供了强大的 JSON 支持,能够灵活地存储和处理 JSON 数据,同时结合了关系型数据库的可靠性和 JSON 数据的灵活性。 |
|
| 883 | - |
|
| 884 | -[[JSON 数据类型](https://www.rockdata.net/zh-cn/tutorial/type-json/)] |
|
| 885 | - |
|
| 886 | -**1. JSON 数据类型** |
|
| 887 | - |
|
| 888 | -PostgreSQL提供了两种主要的JSON数据类型: |
|
| 889 | - |
|
| 890 | -- **`JSON`**:以文本格式存储JSON数据,保留输入时的所有细节(如空格和重复键)。适合需要保留原始文档格式的情况。 |
|
| 891 | -- **`JSONB`**:将JSON数据解析并以二进制格式存储,不保留格式信息(如空格)和重复键。尽管在插入时可能稍慢,但读取和查询性能通常优于`JSON`类型,因此推荐用于大多数场景。 |
|
| 892 | - |
|
| 893 | -**2. 查询JSON数据** |
|
| 894 | - |
|
| 895 | -PostgreSQL为JSON数据提供了丰富的操作符和函数,使得查询变得简单而强大。以下是一些常用的查询方法: |
|
| 896 | - |
|
| 897 | - |
|
| 898 | - |
|
| 899 | -- **提取数据**: |
|
| 900 | - |
|
| 901 | - - `->`:从JSON对象中获取指定键的值(返回JSON类型)。 |
|
| 902 | - |
|
| 903 | - - `->>`:类似`->`,但返回的是文本类型。 |
|
| 904 | - |
|
| 905 | - - `#>` 和 `#>>`:用于根据提供的路径数组提取嵌套的JSON数据。 |
|
| 906 | - |
|
| 907 | - 由于`->`运算符返回 JSON 对象,因此您可以将其与运算符`->>`串接起来以检索特定节点。例如,以下语句返回所有已售出的产品: |
|
| 908 | - |
|
| 909 | - ```sql |
|
| 910 | - SELECT info -> 'items' ->> 'product' as product |
|
| 911 | - FROM orders |
|
| 912 | - ORDER BY product; |
|
| 913 | - ``` |
|
| 914 | - |
|
| 915 | -- **检查包含关系**: |
|
| 916 | - |
|
| 917 | - - `@>`:检查左侧的JSON是否包含右侧的JSON。 |
|
| 918 | - - `<@`:与`@>`相反,检查左侧的JSON是否被右侧的JSON所包含。 |
|
| 919 | - |
|
| 920 | -- **键存在性检查**: |
|
| 921 | - |
|
| 922 | - - `?`:检查JSON对象中是否存在某个键。 |
|
| 923 | - |
|
| 924 | - - `?|` 和 `?&`:分别用于检查一组键中是否有任意一个或全部存在于JSON对象中。 |
|
| 925 | - |
|
| 926 | - |
|
| 927 | - |
|
| 928 | -**3. 创建索引提高性能** |
|
| 929 | - |
|
| 930 | -为了优化JSON数据的查询性能,特别是对于复杂查询条件,PostgreSQL允许为JSONB字段创建GIN(Generalized Inverted Indexes)索引。GIN索引特别适用于处理复杂的查询,例如查找包含特定键值对的记录。 |
|
| 931 | - |
|
| 932 | -- 创建GIN索引的例子: |
|
| 933 | - |
|
| 934 | - ```sql |
|
| 935 | - CREATE INDEX idx_jsonb_data ON your_table USING GIN (jsonb_column); |
|
| 936 | - ``` |
|
| 937 | - |
|
| 938 | -使用GIN索引可以显著加快涉及`@>`、`?`等操作符的查询速度,这对于需要频繁进行这类查询的应用来说是非常重要的。 |
|
| 939 | - |
|
| 940 | - |
|
| 941 | -#### 2.7 PostgreSQL UPDATE 语句中,更新列名时不能带别名 |
|
| 942 | - |
|
| 943 | -请注意,在 PostgreSQL 中,虽然可以在 UPDATE 语句中为表指定别名,但在实际使用这些列名时,并不需要(也不应该)通过别名来引用它们. |
|
| 944 | -条件可以带别名,但是列名不能带别名. |
|
| 945 | - |
|
| 946 | -```sql |
|
| 947 | -UPDATE tenant_user_instance t |
|
| 948 | -SET t."update_date" = TO_TIMESTAMP('2025-02-18 11:00:27.296', 'YYYY-MM-DD HH24:MI:SS.FF') |
|
| 949 | -WHERE t."action_dimension_id" = '04me8wsxbgrqt' |
|
| 950 | -AND t."user_id" = '04me9sszlk54b' |
|
| 951 | -AND t."instance_id" = '04me86gy87lxe' |
|
| 952 | -AND t."source" IN ('USER', 'BUSINESS_APP'); |
|
| 953 | -``` |
|
| 954 | - |
|
| 955 | -错误 [42703]: ERROR: column "t" of relation "tenant_user_instance" does not exist 表示在 tenant_user_instance 表中找不到名为 "t" 的列。实际上,这个错误通常是由表别名的误用引起的。在 PostgreSQL 中,更新语句可以使用表别名,但不需要像在 SELECT 语句中那样引用别名作为表名的一部分。 |
|
| 956 | - |
|
| 957 | -以下是修正后的 SQL 语句,移除了对别名 "t" 的不正确引用: |
|
| 958 | - |
|
| 959 | -```sql |
|
| 960 | - |
|
| 961 | -UPDATE tenant_user_instance t |
|
| 962 | -SET update_date = TO_TIMESTAMP('2025-02-18 11:00:27.296', 'YYYY-MM-DD HH24:MI:SS.FF') |
|
| 963 | -WHERE t.action_dimension_id = '04me8wsxbgrqt' |
|
| 964 | -AND t.user_id = '04me9sszlk54b' |
|
| 965 | -AND t.instance_id = '04me86gy87lxe' |
|
| 966 | -AND t.source IN ('USER', 'BUSINESS_APP'); |
|
| 967 | -``` |
|
| 968 | -#### 2.8 select as 别名问题,如果别名不带标识符``或者"",PostgreSQL/gaussdb会将别名转成小写 |
|
| 969 | - |
|
| 970 | -请注意,在 PostgreSQL/GaussDB 中,关键词和不被引号修饰的标识符是大小写不敏感的。因此,如果字段不带修饰符双引号,会转换成小写. |
|
| 971 | - |
|
| 972 | -如果自定义SQL列别名不带修饰符,这样就会导致代码获取displayName值为NULL, get("displayName")=NULL.就会导致数据库迁移的时候,不兼容. |
|
| 973 | - |
|
| 974 | -**正确的SQL写法,列别名如果是驼峰或者包含大小写的,一定要用 ""引起来.** |
|
| 975 | - |
|
| 976 | -参考 [4.1.1. 标识符和关键词](http://www.postgres.cn/docs/current/sql-syntax-lexical.html#SQL-SYNTAX-IDENTIFIERS) |
|
| 977 | - |
|
| 978 | -```sql |
|
| 979 | -select display_name as displayName from meta_app; |
|
| 980 | - |
|
| 981 | ---MySQL |
|
| 982 | -displayName | |
|
| 983 | ------------------+ |
|
| 984 | -基础模块 | |
|
| 985 | - |
|
| 986 | - |
|
| 987 | - |
|
| 988 | ---PostgreSQL/GaussDB |
|
| 989 | -displayname | |
|
| 990 | ------------------+ |
|
| 991 | -基础模块 |
|
| 992 | - |
|
| 993 | - |
|
| 994 | -正确的SQL写法,列别名如果是驼峰或者包含大小写的 |
|
| 995 | -MYSQL: select display_name as `displayName` from meta_app; |
|
| 996 | -PG/GAUSSDB/ORACLE: select display_name as "displayName" from meta_app; |
|
| 997 | - |
|
| 998 | -项目自定义SQL错误的示范: |
|
| 999 | -SELECT param_name paramName, param_value paramValue FROM base_process_spec bps; |
|
| 1000 | - |
|
| 1001 | -标准的SQL语法: |
|
| 1002 | -SELECT param_name "paramName", param_value "paramValue" FROM base_process_spec bps |
|
| 1003 | -``` |
|
| 1004 | - |
|
| 1005 | -#### 2.9 PostgreSQL 的 schema |
|
| 1006 | - |
|
| 1007 | -PostgreSQL和MySQL比较大的区别是引入了schema的概念,使用的时候需要切换schema. |
|
| 1008 | -默认 schema,新建库自带 public;search_path 控制查找顺序。 |
|
| 1009 | - |
|
| 1010 | - |
|
| 1011 | - |
|
| 1012 | -| 维度 | PostgreSQL | MySQL | 一句话差异 | |
|
| 1013 | -| ----------------------- | ------------------------------------------------------------ | ------------------------------------------------------------ | ------------------------------------------------------------ | |
|
| 1014 | -| **1. 层级结构** | 集群 → 数据库 → **schema** → 表/函数/序列… | 实例 → **database** → 表… | PG 比 MySQL 多一层真正的 “schema” 命名空间。 | |
|
| 1015 | -| **2. schema≈database?** | ❌ 不是一回事;一个db里可建N个schema。 | ✅ `CREATE DATABASE` 与 `CREATE SCHEMA` 几乎等价;一个 db 就是一个 schema 空间。 | MySQL 里换 db 就是换 schema;PG 里换 schema 仍在同一个 db 内。 | |
|
| 1016 | -| **3. 默认 schema** | 新建库自带 `public`;`search_path` 控制查找顺序。 | 每个 db 自带 `sys`/`mysql`/`information_schema`,但用户表都在 db 根下;无 “默认 schema” 概念。 | PG 靠 `search_path` 实现“跨 schema 透明访问”,MySQL 靠 `USE db`。 | |
|
| 1017 | -| **4. 命名空间隔离** | 同一db内不同schema可存在同名对象(`hr.emp`, `sales.emp`)。 | 同一实例内不同 db 对象名可重复;**一个 db 内部**表名必须唯一。 | PG 的细粒度隔离粒度是 schema,MySQL 是 database。 | |
|
| 1018 | -| **5. 跨空间访问** | 只要 `GRANT` 就可以 `hr.emp` 访问 `sales` 的表,仍在**一个连接**里。 | 跨库访问需 `db.table` 语法,但**事务/外键/临时表**不能跨库;往往要开多个连接。 | PG 一个连接即可跨 schema;MySQL 跨 db 容易,跨库逻辑隔离重。 | |
|
| 1019 | -| 6. 代码/ORM 差异 | 需写 `SET search_path = tenant1, public;` 或在连接串里配 ` | | | |
|
| 1020 | - |
|
| 1021 | -**一句话概括:** |
|
| 1022 | -在 PostgreSQL 里,schema 只是“数据库内部的一个文件夹”,拿来把表/函数/序列等对象分门别类;而在 MySQL 里并没有这层中间结构,它的“数据库”概念同时扮演了 PostgreSQL 的 database + schema 两个角色。 |
|
| 1023 | - |
|
| 1024 | - |
|
| 1025 | - |
|
| 1026 | -### 第三节. PostgreSQL 基础教程 |
|
| 1027 | - |
|
| 1028 | -**来源:** [PostgreSQL 教程](https://www.rockdata.net/zh-cn/tutorial/toc/) |
|
| 1029 | - |
|
| 1030 | -本 **PostgreSQL 教程**可帮助您快速了解 PostgreSQL。您将通过许多实际示例快速掌握 PostgreSQL,并将这些知识应用于使用 PostgreSQL 开发应用程序。 |
|
| 1031 | - |
|
| 1032 | -如果你是 … |
|
| 1033 | - |
|
| 1034 | -- 寻求快速学习 PostgreSQL。 |
|
| 1035 | -- 使用 PostgreSQL 作为后端数据库管理系统开发应用程序。 |
|
| 1036 | -- 从其他数据库管理系统(例如 MySQL、Oracle 和 Microsoft SQL Server)迁移到 PostgreSQL。 |
|
| 1037 | - |
|
| 1038 | -您将在此网站上找到快速有效地开始使用 PostgreSQL 所需的所有信息。 |
|
| 1039 | - |
|
| 1040 | -PostgreSQL 教程演示了 PostgreSQL 的许多独特功能,这些功能使其成为最先进的开源数据库管理系统。 |
|
| 1041 | - |
|
| 1042 | -#### [PostgreSQL 入门](https://www.rockdata.net/zh-cn/tutorial/getting-started/) |
|
| 1043 | - |
|
| 1044 | -本部分向您展示如何在 Windows、Linux 和 macOS 上安装 PostgreSQL,帮助您开始使用 PostgreSQL。您还将学习如何使用 psql 工具连接到 PostgreSQL,以及如何将示例数据库加载到 PostgreSQL 中进行练习。 |
|
| 1045 | - |
|
| 1046 | -#### PostgreSQL 基础教程 |
|
| 1047 | - |
|
| 1048 | -首先,您将学习如何使用基本数据查询技术从单个表中查询数据,包括查询数据、对结果集进行排序和过滤行。然后,您将了解高级查询,例如连接多个表、使用集合操作以及构造子查询。最后,您将学习如何管理数据库表,例如创建新表或修改现有表的结构。 |
|
| 1049 | - |
|
| 1050 | -#### 第 1 节. 查询数据 |
|
| 1051 | - |
|
| 1052 | -- [简单查询](https://www.rockdata.net/zh-cn/tutorial/dml-select/) – 向您展示如何从单个表中查询数据。 |
|
| 1053 | -- [列别名](https://www.rockdata.net/zh-cn/tutorial/dml-column-alias/) – 了解如何为查询中的列或表达式分配临时名称。 |
|
| 1054 | -- [排序](https://www.rockdata.net/zh-cn/tutorial/dml-order-by/) – 指导您如何对查询返回的结果集进行排序。 |
|
| 1055 | -- [去重查询](https://www.rockdata.net/zh-cn/tutorial/dml-select-distinct/) – 为您提供一个删除结果集中重复行的子句。 |
|
| 1056 | -- [分页查询](https://www.rockdata.net/zh-cn/tutorial/dml-paginate/) – 指导您如何对查询返回的结果集进行分页。 |
|
| 1057 | - |
|
| 1058 | -#### 第 2 节. 过滤数据 |
|
| 1059 | - |
|
| 1060 | -- [WHERE](https://www.rockdata.net/zh-cn/tutorial/dml-where/) – 根据指定条件过滤行。 |
|
| 1061 | -- [LIMIT](https://www.rockdata.net/zh-cn/tutorial/dml-limit/) – 获取查询生成的行的子集。 |
|
| 1062 | -- [FETCH](https://www.rockdata.net/zh-cn/tutorial/dml-fetch/) – 限制查询返回的行数。 |
|
| 1063 | -- [IN](https://www.rockdata.net/zh-cn/tutorial/dml-in/) – 选择与值列表中的任何值匹配的数据。 |
|
| 1064 | -- [BETWEEN](https://www.rockdata.net/zh-cn/tutorial/dml-between/) – 选择值范围内的数据。 |
|
| 1065 | -- [LIKE](https://www.rockdata.net/zh-cn/tutorial/dml-like/) – 基于模式匹配过滤数据。 |
|
| 1066 | -- [IS NULL](https://www.rockdata.net/zh-cn/tutorial/dml-is-null/) – 检查值是否为空。 |
|
| 1067 | - |
|
| 1068 | -#### 第 3 节. 连接多个表 |
|
| 1069 | - |
|
| 1070 | -- [连接](https://www.rockdata.net/zh-cn/tutorial/dml-joins/) – 向您展示 PostgreSQL 中连接的简要概述。 |
|
| 1071 | -- [表别名](https://www.rockdata.net/zh-cn/tutorial/dml-table-alias/) – 描述如何在查询中使用表别名。 |
|
| 1072 | -- [内连接](https://www.rockdata.net/zh-cn/tutorial/dml-inner-join/) – 从一个表中选择在其他表中具有相应行的行。 |
|
| 1073 | -- [左连接](https://www.rockdata.net/zh-cn/tutorial/dml-left-join/) – 从一个表中选择行,这些行在其他表中可能有也可能没有对应的行。 |
|
| 1074 | -- [自连接](https://www.rockdata.net/zh-cn/tutorial/dml-self-join/) – 通过将表与自身进行比较来将表与其自身连接。 |
|
| 1075 | -- [完全外连接](https://www.rockdata.net/zh-cn/tutorial/dml-full-outer-join/) – 使用完全连接查找一个表中在另一个表中没有匹配行的行。 |
|
| 1076 | -- [交叉连接](https://www.rockdata.net/zh-cn/tutorial/dml-cross-join/) – 生成两个或多个表中的行的笛卡尔积。 |
|
| 1077 | -- [自然连接](https://www.rockdata.net/zh-cn/tutorial/dml-natural-join/) – 根据连接表中的公共列名称,使用隐式连接条件连接两个或多个表。 |
|
| 1078 | -- [横向连接](https://www.rockdata.net/zh-cn/tutorial/dml-lateral-join/) – 通过连接交叉引用子查询中的行,和构建复合结果集。 |
|
| 1079 | - |
|
| 1080 | -#### 第 4 节. 数据分组 |
|
| 1081 | - |
|
| 1082 | -- [GROUP BY](https://www.rockdata.net/zh-cn/tutorial/dml-group-by/) – 将行分成组并对每个组应用聚合函数。 |
|
| 1083 | -- [HAVING](https://www.rockdata.net/zh-cn/tutorial/dml-having/) – 对组应用条件。 |
|
| 1084 | -- [PARTITION BY](https://www.rockdata.net/zh-cn/tutorial/dml-partition-by/) – 将行分成组并对每个组应用窗口函数。 |
|
| 1085 | - |
|
| 1086 | -#### 第 5 节. 集合运算 |
|
| 1087 | - |
|
| 1088 | -- [UNION](https://www.rockdata.net/zh-cn/tutorial/dml-union/) – 将多个查询的结果集合并为一个结果集。 |
|
| 1089 | -- [INTERSECT](https://www.rockdata.net/zh-cn/tutorial/dml-intersect/) – 组合两个或多个查询的结果集并返回一个结果集,该结果集的行都出现在两个结果集中。 |
|
| 1090 | -- [EXCEPT](https://www.rockdata.net/zh-cn/tutorial/dml-except/) – 返回第一个查询中未出现在第二个查询的输出中的行。 |
|
| 1091 | - |
|
| 1092 | -#### 第 6 节. 分组集、多维分组和汇总 |
|
| 1093 | - |
|
| 1094 | -- [分组集](https://www.rockdata.net/zh-cn/tutorial/dml-grouping-sets/) – 在报告中生成多个分组集。 |
|
| 1095 | -- [CUBE](https://www.rockdata.net/zh-cn/tutorial/dml-cube/) – 定义多个分组集,其中包括所有可能的维度组合。 |
|
| 1096 | -- [ROLLUP](https://www.rockdata.net/zh-cn/tutorial/dml-rollup/) – 生成包含总计和小计的报告。 |
|
| 1097 | - |
|
| 1098 | -#### 第 7 节. 子查询 |
|
| 1099 | - |
|
| 1100 | -- [子查询](https://www.rockdata.net/zh-cn/tutorial/dml-subquery/) – 编写一个嵌套在另一个查询中的查询。 |
|
| 1101 | -- [相关子查询](https://www.rockdata.net/zh-cn/tutorial/dml-correlated-subquery/) – 向您展示如何使用相关子查询,来执行依赖于正在处理的当前行的值的查询。 |
|
| 1102 | -- [ANY](https://www.rockdata.net/zh-cn/tutorial/dml-any/) – 通过将某个值与子查询返回的一组值进行比较来检索数据。 |
|
| 1103 | -- [ALL](https://www.rockdata.net/zh-cn/tutorial/dml-all/) – 通过将值与子查询返回的值列表进行比较来查询数据。 |
|
| 1104 | -- [EXISTS](https://www.rockdata.net/zh-cn/tutorial/dml-exists/) – 检查子查询返回的行是否存在。 |
|
| 1105 | - |
|
| 1106 | -#### 第 8 节. 公共表表达式 |
|
| 1107 | - |
|
| 1108 | -- [PostgreSQL CTE](https://www.rockdata.net/zh-cn/tutorial/dml-cte/) – 向您介绍 PostgreSQL 公共表表达式或 CTE。 |
|
| 1109 | -- [使用 CTE 的递归查询](https://www.rockdata.net/zh-cn/tutorial/dml-recursive-query/) – 讨论递归查询并学习如何在各种上下文中应用它。 |
|
| 1110 | - |
|
| 1111 | -#### 第 9 节. 修改数据 |
|
| 1112 | - |
|
| 1113 | -在本节中,您将学习如何使用`INSERT`语句向表中插入数据、使用`UPDATE`语句修改现有数据以及使用`DELETE`语句删除数据。此外,您还将学习如何使用 UPSERT 语句来合并数据。 |
|
| 1114 | - |
|
| 1115 | -- [插入](https://www.rockdata.net/zh-cn/tutorial/dml-insert/) – 指导您如何将单行插入表中。 |
|
| 1116 | -- [插入多行](https://www.rockdata.net/zh-cn/tutorial/dml-insert-multiple-rows/) – 向您展示如何在表中插入多行。 |
|
| 1117 | -- [更新](https://www.rockdata.net/zh-cn/tutorial/dml-update/) – 更新表中的现有数据。 |
|
| 1118 | -- [连接更新](https://www.rockdata.net/zh-cn/tutorial/dml-update-join/) – 根据另一个表中的值更新表中的值。 |
|
| 1119 | -- [删除](https://www.rockdata.net/zh-cn/tutorial/dml-delete/) – 删除表中的数据。 |
|
| 1120 | -- [连接删除](https://www.rockdata.net/zh-cn/tutorial/dml-delete-join/) – 根据另一个表中的值删除表中的行。 |
|
| 1121 | -- [级联删除](https://www.rockdata.net/zh-cn/tutorial/dml-delete-cascade/) – 在删除父表中的行时级联删除子表中的相关行。 |
|
| 1122 | -- [UPSERT](https://www.rockdata.net/zh-cn/tutorial/dml-upsert/) – 如果新行已存在于表中,则插入或更新数据。 |
|
| 1123 | -- [合并](https://www.rockdata.net/zh-cn/tutorial/dml-merge/) – 有条件地插入、更新和删除一个表中的行。 |
|
| 1124 | - |
|
| 1125 | -#### 第 10 节. 事务 |
|
| 1126 | - |
|
| 1127 | -- [PostgreSQL 事务](https://www.rockdata.net/zh-cn/tutorial/dml-transaction/) – 向您展示如何使用`BEGIN`、`COMMIT`和`ROLLBACK`语句,来处理 PostgreSQL 中的事务。 |
|
| 1128 | -- [PostgreSQL 子事务](https://www.rockdata.net/zh-cn/tutorial/dml-subtransaction/) – 向您展示如何使用`SAVEPOINT`、`ROLLBACK TO SAVEPOINT`和`RELEASE SAVEPOINT`语句,来处理 PostgreSQL 子事务。 |
|
| 1129 | -- [并发锁定和组合事务](https://www.rockdata.net/zh-cn/tutorial/dml-multixacts/) – 向您介绍什么是组合事务,它为什么会存在,以及会在什么情况下出现。 |
|
| 1130 | -- [SKIP LOCKED 跳过锁定](https://www.rockdata.net/zh-cn/tutorial/dml-skip-locked/) – 向您介绍如何在 PostgreSQL 中使用`SKIP LOCKED`,以避免和解决死锁的问题。 |
|
| 1131 | - |
|
| 1132 | -#### 第 11 节. 导入和导出数据 |
|
| 1133 | - |
|
| 1134 | -您将学习如何使用`COPY`命令、DBeaver 工具,以 CSV、SQL 文件格式对 PostgreSQL 数据进行导入和导出。 |
|
| 1135 | - |
|
| 1136 | -- [将 CSV 文件导入表中](https://www.rockdata.net/zh-cn/tutorial/admin-import-table-csv/) – 向您展示如何将 CSV 文件导入表中。 |
|
| 1137 | -- [导出表到 CSV 文件](https://www.rockdata.net/zh-cn/tutorial/admin-export-table-csv/) – 向您展示如何将表导出到 CSV 文件。 |
|
| 1138 | -- [使用 DBeaver 导入数据](https://www.rockdata.net/zh-cn/tutorial/dbeaver-import-data/) – 向您展示如何使用 DBeaver 将数据从文件导入到表中。 |
|
| 1139 | -- [使用 DBeaver 导出表](https://www.rockdata.net/zh-cn/tutorial/dbeaver-export-data/) – 向您展示如何使用 DBeaver 将表导出到不同类型和格式的文件。 |
|
| 1140 | -- [使用 DBeaver 合并数据](https://www.rockdata.net/zh-cn/tutorial/dbeaver-merge-data/) – 向您展示如何使用 DBeaver 将文件中的数据合并到表中。 |
|
| 1141 | - |
|
| 1142 | -#### 第 12 节. 管理表 |
|
| 1143 | - |
|
| 1144 | -在本节中,您将开始探索 PostgreSQL 数据类型,并向您展示如何创建新表和修改现有表的结构。 |
|
| 1145 | - |
|
| 1146 | -- [数据类型](https://www.rockdata.net/zh-cn/tutorial/data-types/) – 涵盖最常用的 PostgreSQL 数据类型。 |
|
| 1147 | -- [创建表](https://www.rockdata.net/zh-cn/tutorial/ddl-create-table/) – 指导您如何在数据库中创建新表。 |
|
| 1148 | -- [SELECT INTO](https://www.rockdata.net/zh-cn/tutorial/dml-select-into/) 和 [CREATE TABLE AS](https://www.rockdata.net/zh-cn/tutorial/ddl-create-table-as/) – 向您展示如何从查询的结果集创建新表。 |
|
| 1149 | -- 使用 [SERIAL 自增列](https://www.rockdata.net/zh-cn/tutorial/type-serial/) – 使用 SERIAL 将自动增量列添加到表中。 |
|
| 1150 | -- [序列](https://www.rockdata.net/zh-cn/tutorial/ddl-sequences/) – 向您介绍序列并描述如何使用序列生成数字序列。 |
|
| 1151 | -- [标识列](https://www.rockdata.net/zh-cn/tutorial/ddl-identity-column/) – 向您展示如何使用标识列。 |
|
| 1152 | -- [生成列](https://www.rockdata.net/zh-cn/tutorial/ddl-generated-columns/) – 向您展示如何使用生成列。 |
|
| 1153 | -- [更改表](https://www.rockdata.net/zh-cn/tutorial/ddl-alter-table/) – 修改现有表的结构。 |
|
| 1154 | -- [重命名表](https://www.rockdata.net/zh-cn/tutorial/ddl-rename-table/) – 将表的名称更改为新名称。 |
|
| 1155 | -- [添加列](https://www.rockdata.net/zh-cn/tutorial/ddl-add-column/) – 向您展示如何向现有表添加一列或多列。 |
|
| 1156 | -- [删除列](https://www.rockdata.net/zh-cn/tutorial/ddl-drop-column/) – 演示如何删除表的列。 |
|
| 1157 | -- [更改列数据类型](https://www.rockdata.net/zh-cn/tutorial/ddl-change-column-type/) – 向您展示如何更改列的数据。 |
|
| 1158 | -- [重命名列](https://www.rockdata.net/zh-cn/tutorial/ddl-rename-column/) – 说明如何重命名表中的一列或多列。 |
|
| 1159 | -- [删除表](https://www.rockdata.net/zh-cn/tutorial/ddl-drop-table/) – 删除现有表及其所有依赖对象。 |
|
| 1160 | -- [截断表](https://www.rockdata.net/zh-cn/tutorial/ddl-truncate-table/) – 快速有效地删除大表中的所有数据。 |
|
| 1161 | -- [临时表](https://www.rockdata.net/zh-cn/tutorial/ddl-temporary-table/) – 向您展示如何使用临时表。 |
|
| 1162 | -- [复制表](https://www.rockdata.net/zh-cn/tutorial/admin-copy-table/) – 向您展示如何将表格复制到新表格。 |
|
| 1163 | -- [表分区](https://www.rockdata.net/zh-cn/tutorial/ddl-table-partitioning/) – 向您展示如何使用表分区。 |
|
| 1164 | -- [管理分区表](https://www.rockdata.net/zh-cn/tutorial/ddl-manage-partitions/) – 向您展示如何管理分区表。 |
|
| 1165 | -- [引发表重写的 DDL 命令](https://www.rockdata.net/zh-cn/tutorial/ddl-table-rewrite/) – 向您介绍哪些 DDL 命令会导致表的重写。 |
|
| 1166 | -- [以最短的停机时间更改列](https://www.rockdata.net/zh-cn/tutorial/admin-alter-column-online/) – 向您介绍如何以最短的停机时间更改列。 |
|
| 1167 | - |
|
| 1168 | -#### 第 13 节. 了解 PostgreSQL 约束 |
|
| 1169 | - |
|
| 1170 | -- [主键](https://www.rockdata.net/zh-cn/tutorial/constraint-primary-key/) – 说明在创建表或向现有表添加主键时如何定义主键。 |
|
| 1171 | -- [外键](https://www.rockdata.net/zh-cn/tutorial/constraint-foreign-key/) – 展示如何在创建新表时定义外键约束或为现有表添加外键约束。 |
|
| 1172 | -- [检查约束](https://www.rockdata.net/zh-cn/tutorial/constraint-check/) – 添加逻辑以基于布尔表达式检查值。 |
|
| 1173 | -- [唯一约束](https://www.rockdata.net/zh-cn/tutorial/constraint-unique/) – 确保一列或一组列中的值在整个表中是唯一的。 |
|
| 1174 | -- [非空约束](https://www.rockdata.net/zh-cn/tutorial/constraint-not-null/) – 确保列中的值不是`NULL`。 |
|
| 1175 | - |
|
| 1176 | -#### 第 14 节. 深入了解 PostgreSQL 数据类型 |
|
| 1177 | - |
|
| 1178 | -- [布尔型](https://www.rockdata.net/zh-cn/tutorial/type-boolean/) – 使用布尔数据类型存储`TRUE`和`FALSE`值。 |
|
| 1179 | -- [字符型](https://www.rockdata.net/zh-cn/tutorial/character-types/) – 了解如何使用各种字符类型,包括`char`、`varchar`和`text`。 |
|
| 1180 | -- [numeric](https://www.rockdata.net/zh-cn/tutorial/type-numeric/) – 向您展示如何使用`numeric`类型来存储需要精度的值。 |
|
| 1181 | -- [double precision](https://www.rockdata.net/zh-cn/tutorial/type-double-precision/) – 了解如何在数据库中存储不准确的可变精度数字。double precision 类型也称为 float 类型。 |
|
| 1182 | -- [real](https://www.rockdata.net/zh-cn/tutorial/type-real/) – 指导您如何在数据库中使用单精度浮点数。 |
|
| 1183 | -- [整型](https://www.rockdata.net/zh-cn/tutorial/type-integer/) – 向您介绍 PostgreSQL 中的各种整数类型,包括`smallint`、`int`和`bigint`。 |
|
| 1184 | -- [date](https://www.rockdata.net/zh-cn/tutorial/type-date/) – 引入`date`用于存储日期值的数据类型。 |
|
| 1185 | -- [时间戳](https://www.rockdata.net/zh-cn/tutorial/type-timestamp/) – 快速了解时间戳数据类型。 |
|
| 1186 | -- [间隔](https://www.rockdata.net/zh-cn/tutorial/type-interval/) – 向您展示如何使用间隔数据类型有效地处理一段时间。 |
|
| 1187 | -- [time](https://www.rockdata.net/zh-cn/tutorial/type-time/) – 使用`time`数据类型来管理一天中的时间值。 |
|
| 1188 | -- [UUID](https://www.rockdata.net/zh-cn/tutorial/type-uuid/) – 指导您如何使用`UUID`数据类型以及如何使用提供的模块生成`UUID`值。 |
|
| 1189 | -- [数组](https://www.rockdata.net/zh-cn/tutorial/type-array/) – 向您展示如何使用数组,并向您介绍一些用于数组操作的方便函数。 |
|
| 1190 | -- [hstore](https://www.rockdata.net/zh-cn/tutorial/type-hstore/) – 向您介绍数据类型,它是存储在 PostgreSQL 中单个值中的一组键/值对。 |
|
| 1191 | -- [JSON](https://www.rockdata.net/zh-cn/tutorial/type-json/) – 说明如何使用 JSON 数据类型,并向您展示如何使用一些最重要的 JSON 运算符和函数。 |
|
| 1192 | -- [用户定义的数据类型](https://www.rockdata.net/zh-cn/tutorial/user-defined-data-types/) – 向您展示如何使用`CREATE DOMAIN`和`CREATE TYPE`语句创建用户定义的数据类型。 |
|
| 1193 | -- [bytea](https://www.rockdata.net/zh-cn/tutorial/type-bytea/) – 了解如何在数据库中存储二进制字节串。 |
|
| 1194 | - |
|
| 1195 | -#### 第 15 节. 条件表达式和运算符 |
|
| 1196 | - |
|
| 1197 | -- [CASE](https://www.rockdata.net/zh-cn/tutorial/dml-case/) – 向您展示如何使用`CASE`表达式构成条件查询。 |
|
| 1198 | -- [COALESCE](https://www.rockdata.net/zh-cn/tutorial/dml-coalesce/) – 返回第一个非空参数。您可以使用它将`NULL`替换为一个默认值。 |
|
| 1199 | -- [NULLIF](https://www.rockdata.net/zh-cn/tutorial/dml-nullif/) – 如果第一个参数等于第二个参数则返回`NULL`。 |
|
| 1200 | -- [CAST](https://www.rockdata.net/zh-cn/tutorial/type-cast/) – 从一种数据类型转换为另一种数据类型,例如,从字符串转换为整数,从字符串转换为日期。 |
|
| 1201 | - |
|
| 1202 | -#### 第 16 节. PostgreSQL 实用程序 |
|
| 1203 | - |
|
| 1204 | -- [psql 命令](https://www.rockdata.net/zh-cn/tutorial/admin-psql-commands/) – 向您展示最常见的 psql 命令,帮助您更快、更有效地与 psql 交互。 |
|
| 1205 | - |
|
| 1206 | -#### 第 17 节. 故障处理 |
|
| 1207 | - |
|
| 1208 | -- [应对死锁](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-deadlocks/) – 指导您如何在 PostgreSQL 中处理死锁的问题。 |
|
| 1209 | -- [处理数据块损坏](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-corrupted-blocks/) – 指导您如何处理 PostgreSQL 中损坏的数据块。 |
|
| 1210 | -- [处理 TOAST 数据损坏](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-corrupted-toast/) – 指导您如何处理 PostgreSQL 中损坏的 TOAST 数据。 |
|
| 1211 | -- [处理统计信息损坏](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-statistics-corruption/) – 指导您如何处理 PostgreSQL 中的统计信息损坏。 |
|
| 1212 | -- [处理 PL/pgSQL 运行时错误](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-plpgsql-runtime-errors/) – 指导您如何对 PostgreSQL 中的 PL/pgSQL 运行时错误进行处理。 |
|
| 1213 | -- [页面缓存如何影响查询性能?](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-page-caches/) – 指导您如何分析页面缓存对 PostgreSQL 性能的影响。 |
|
| 1214 | -- [处理事务 ID 回卷的故障](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-txn-wraparound/) – 指导您如何处理 PostgreSQL 中事务 ID 回卷的故障。 |
|
| 1215 | -- [检查后端进程的内存使用情况](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-memory-usage/) – 指导您如何检查 PostgreSQL 中后端进程的内存使用情况,和进行故障处理。 |
|
| 1216 | -- [记录函数内错误的调用栈](https://www.rockdata.net/zh-cn/tutorial/logging-error-backtraces/) – 指导您如何记录在指定函数内发生错误时的调用栈。 |
|
| 1217 | -- [分区剪枝不起作用的原因](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-partition-pruning/) – 向您介绍在 PostgreSQL 中分区剪枝不起作用的主要原因。 |
|
| 1218 | -- [处理 pg_wal 目录中的 WAL 积压](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-wal-accumulation/) – 指导您如何在 PostgreSQL 中排查 pg_wal 目录中的 WAL 积压问题。 |
|
| 1219 | -- [处理服务器可用内存不足的问题](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-server-low-free-memory/) – 指导您如何在 PostgreSQL 服务器上处理可用内存不足的问题。 |
|
| 1220 | -- [处理缓存命中率低的问题](https://www.rockdata.net/zh-cn/tutorial/troubleshooting-low-cache-hit-ratio/) – 指导您如何在 PostgreSQL 中处理缓存命中率低的问题。 |
|
| 1221 | - |
|
| 1222 | -#### 第 18 节. PostgreSQL 技巧 |
|
| 1223 | - |
|
| 1224 | -- [如何比较两个表](https://www.rockdata.net/zh-cn/tutorial/admin-compare-tables/) – 描述如何比较数据库中两个表中的数据。 |
|
| 1225 | -- [使用 pgAdmin 4 对比数据架构](https://www.rockdata.net/zh-cn/tutorial/pgadmin-compare-schema/) – 指导您如何使用 pgAdmin 4 提供的架构差异功能,比较两个数据库或两个模式之间的对象。 |
|
| 1226 | -- [使用 DBeaver 迁移表数据](https://www.rockdata.net/zh-cn/tutorial/dbeaver-migrate-data/) – 向您介绍使用 DBeaver 工具,在不同数据库之间或同一数据库内的表之间传输数据。 |
|
| 1227 | -- [如何在 PostgreSQL 中删除重复行](https://www.rockdata.net/zh-cn/tutorial/admin-delete-duplicate-rows/) – 向您展示从表中删除重复行的各种方法。 |
|
| 1228 | -- [如何生成某个范围内的随机数](https://www.rockdata.net/zh-cn/tutorial/function-random-range/) – 说明如何生成特定范围内的随机数。 |
|
| 1229 | -- [查询 JSON 列中内嵌的数组](https://www.rockdata.net/zh-cn/tutorial/query-json-arrays/) – 描述如何在 PostgreSQL 中查询 JSON 列中内嵌的数组。 |
|
| 1230 | -- [更改 JSON 列中内嵌的数组](https://www.rockdata.net/zh-cn/tutorial/update-json-arrays/) – 描述如何在 PostgreSQL 中修改 JSON 列中内嵌的数组。 |
|
| 1231 | -- [PostGIS 基础用法](https://www.rockdata.net/zh-cn/tutorial/postgis-basics/) – 向您介绍 PostGIS 的一些基础用法。 |
|
| 1232 | -- [使用 PostGIS 进行基础的地理空间数据查询](https://www.rockdata.net/zh-cn/tutorial/postgis-basic-queries/) – 向您演示用于处理地理空间数据的基础 PostGIS 查询。 |
|
| 1233 | - |
|
| 1234 | - |
|
| 1235 | - |
|
| 1236 | -### 第四节. PostgreSQL 高级教程 |
|
| 1237 | - |
|
| 1238 | -这个 PostgreSQL 高级教程涵盖了高级概念,包括存储过程、索引、视图、触发器和数据库管理。 |
|
| 1239 | - |
|
| 1240 | -#### [PostgreSQL 函数](https://www.rockdata.net/zh-cn/tutorial/postgres-functions/) |
|
| 1241 | - |
|
| 1242 | -PostgreSQL 为内置数据类型提供了大量的函数。本节向您展示如何使用一些最常用的 PostgreSQL 函数。 |
|
| 1243 | - |
|
| 1244 | -#### [PostgreSQL PL/pgSQL](https://www.rockdata.net/zh-cn/tutorial/postgres-plpgsql/) |
|
| 1245 | - |
|
| 1246 | -此 PostgreSQL 存储过程部分将逐步向您展示如何使用 PL/pgSQL 过程语言开发 PostgreSQL 用户定义函数。 |
|
| 1247 | - |
|
| 1248 | -#### [PostgreSQL 触发器](https://www.rockdata.net/zh-cn/tutorial/ddl-triggers/) |
|
| 1249 | - |
|
| 1250 | -本节向您介绍 PostgreSQL 触发器概念,并展示如何在 PostgreSQL 中管理触发器。 |
|
| 1251 | - |
|
| 1252 | -#### [PostgreSQL 视图](https://www.rockdata.net/zh-cn/tutorial/ddl-views/) |
|
| 1253 | - |
|
| 1254 | -我们将向您介绍数据库视图概念,并向您展示如何管理视图,例如在数据库中创建、更改和删除视图。 |
|
| 1255 | - |
|
| 1256 | -#### [PostgreSQL 索引](https://www.rockdata.net/zh-cn/tutorial/indexes/) |
|
| 1257 | - |
|
| 1258 | -PostgreSQL 索引是增强数据库性能的有效工具。索引可以帮助数据库服务器比没有索引时更快地找到特定行。 |
|
| 1259 | - |
|
| 1260 | -#### [PostgreSQL 优化](https://www.rockdata.net/zh-cn/tutorial/postgres-optimization/) |
|
| 1261 | - |
|
| 1262 | -本节向您介绍 PostgreSQL 性能优化,并展示如何在 PostgreSQL 中优化各种场景的性能问题。 |
|
| 1263 | - |
|
| 1264 | -#### [PostgreSQL 管理](https://www.rockdata.net/zh-cn/tutorial/postgres-admin/) |
|
| 1265 | - |
|
| 1266 | -PostgreSQL 管理涵盖 PostgreSQL 数据库服务器最重要的活动,包括角色和数据库管理、备份和恢复。 |
|
| 1267 | - |
|
| 1268 | -#### [PostgreSQL 监控](https://www.rockdata.net/zh-cn/tutorial/postgres-monitoring/) |
|
| 1269 | - |
|
| 1270 | -PostgreSQL 监控涵盖 PostgreSQL 数据库服务器最重要的监控和运维活动。 |
|
| 1271 | - |
|
| 1272 | -#### [应用程序编程接口](https://www.rockdata.net/zh-cn/docs/14/client-interfaces.html) |
|
| 1273 | - |
|
| 1274 | -本节向您展示,如何从使用流行编程语言(例如 Java、Python 和 PHP)的应用程序,与 PostgreSQL 数据库进行交互。 |
|
| 1275 | - |
|
| 1276 | -- [PostgreSQL Java 教程](https://www.rockdata.net/zh-cn/tutorial/postgres-java/) – 此 PostgreSQL JDBC 部分向您展示,如何使用 Java JDBC 驱动程序与 PostgreSQL 数据库进行交互。 |
|
| 1277 | -- [PostgreSQL Python 教程](https://www.rockdata.net/zh-cn/tutorial/postgres-python/) – 此 PostgreSQL Python 部分向您展示,如何使用 Python 编程语言与 PostgreSQL 数据库进行交互。 |
|
| 1278 | -- [使用 Golang 连接到 PostgreSQL](https://www.rockdata.net/zh-cn/tutorial/golang-setup/) – 向您介绍如何使用 Go 编程语言与 PostgreSQL 数据库进行交互。 |
|
| 1279 | - |
|
| 1280 | -## 四 OceanBase 参考手册 |
|
| 1281 | - |
|
| 1282 | -### 1. OceanBase 与 MySQL 兼容性总结及 JDBC 配置指南 |
|
| 1283 | - |
|
| 1284 | -#### 1.1 兼容性概述 |
|
| 1285 | - |
|
| 1286 | -OceanBase 数据库在以下方面高度兼容 MySQL(接近 100%): |
|
| 1287 | - |
|
| 1288 | -- SQL 语法 |
|
| 1289 | -- 数据读取和写入 |
|
| 1290 | -- 事务处理机制 |
|
| 1291 | -- 系统表结构 |
|
| 1292 | - |
|
| 1293 | -#### 1.2 JDBC 连接配置调整 |
|
| 1294 | - |
|
| 1295 | -从 MySQL 迁移到 OceanBase 时,需要修改 `dbcp.properties` 的 JDBC 连接 URL,添加以下两个关键参数: |
|
| 1296 | - |
|
| 1297 | -- `rewriteBatchedStatements=TRUE` |
|
| 1298 | -- `allowMultiQueries=TRUE` |
|
| 1299 | - |
|
| 1300 | -**MySQL 模式下的 JDBC 参数配置建议:** |
|
| 1301 | - |
|
| 1302 | -```plaintext |
|
| 1303 | -url=jdbc:mysql://xxx.xxx.xxx.xxx:2881/test?rewriteBatchedStatements=TRUE&allowMultiQueries=TRUE&useLocalSessionState=TRUE&useUnicode=TRUE&characterEncoding=utf-8&socketTimeout=3000000&connectTimeout=60000&zeroDateTimeBehavior=convertToNull&allowPublicKeyRetrieval=true |
|
| 1304 | -``` |
|
| 1305 | - |
|
| 1306 | -- **allowMultiQueries**:默认为 `FALSE`,必须设置为 `TRUE`,以允许使用分号连接的多语句文本格式。对使用文本协议的场景,只需开启此配置即可实现批量优化。 |
|
| 1307 | -- **rewriteBatchedStatements**:默认为 `FALSE`,若使用 PS 协议,则必须设置为 `TRUE`,以在执行 `executeBatch()` 时将多条语句改写为分号连接的多语句格式。 |
|
| 1308 | - |
|
| 1309 | -**特例说明**:开启 `rewriteBatchedStatements` 后,对于多条 multi queries 插入语句(无论使用文本协议或 PS 协议),JDBC 驱动会将其改写为一条 Multi Values Insert 语句。 |
|
| 1310 | - |
|
| 1311 | -**参考文档**: |
|
| 1312 | - |
|
| 1313 | -- [JDBC 配置示例](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013674) |
|
| 1314 | -- [数据库 URL-V2.4.13-OceanBase JDBC 驱动程序文档](https://www.oceanbase.com/docs/common-oceanbase-connector-j-cn-1000000001506761) |
|
| 1315 | -- [配置 JDBC 和 OBServer 实现 Batch DML 最佳性能的最佳实践](https://www.oceanbase.com/docs/common-best-practices-1000000001489651) |
|
| 1316 | - |
|
| 1317 | ---- |
|
| 1318 | - |
|
| 1319 | -### 2. OceanBase 概述 |
|
| 1320 | - |
|
| 1321 | -OceanBase 数据库是一款完全自研的企业级原生分布式数据库,具有以下特性: |
|
| 1322 | - |
|
| 1323 | -- 在普通硬件上实现金融级高可用 |
|
| 1324 | -- 首创“三地五中心”城市级故障自动无损容灾新标准 |
|
| 1325 | -- 单集群规模超过 1500 节点 |
|
| 1326 | -- 支持云原生、强一致性、高度兼容 Oracle/MySQL |
|
| 1327 | - |
|
| 1328 | -**官方文档**:[OceanBase 概述](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002012646) |
|
| 1329 | - |
|
| 1330 | ---- |
|
| 1331 | - |
|
| 1332 | -### 3. 与 MySQL 兼容性对比 |
|
| 1333 | - |
|
| 1334 | -OceanBase 数据库的 MySQL 模式兼容 MySQL 5.7/8.0 的绝大部分功能和语法。由于产品架构不同,或者客户需求不大,有些功能并没有被支持。以下是 OceanBase 数据库的 MySQL 模式与原生 MySQL 数据库的不同之处: |
|
| 1335 | - |
|
| 1336 | -- 数据类型 |
|
| 1337 | -- SQL 语法 |
|
| 1338 | -- 过程性语言 |
|
| 1339 | -- 系统视图 |
|
| 1340 | -- 字符集 |
|
| 1341 | -- 字符序 |
|
| 1342 | -- 函数与表达式 |
|
| 1343 | -- 分区支持 |
|
| 1344 | -- 备份恢复 |
|
| 1345 | -- 存储引擎 |
|
| 1346 | -- 优化器 |
|
| 1347 | - |
|
| 1348 | -**数据类型**: |
|
| 1349 | - |
|
| 1350 | -- 数值类型:`BOOL`/`BOOLEAN`/`TINYINT`、`SMALLINT`、`MEDIUMINT`、`INT`/`INTEGER`、`BIGINT`、`DECIMAL`、`NUMERIC`、`FLOAT`、`DOUBLE`、`BIT` |
|
| 1351 | -- 日期时间类型:`DATETIME`、`TIMESTAMP`、`DATE`、`TIME`、`YEAR` |
|
| 1352 | -- 字符类型:`CHAR`、`VARCHAR`、`BINARY`、`VARBINARY` |
|
| 1353 | -- 大对象类型:`TINYBLOB`、`BLOB`、`MEDIUMBLOB`、`LONGBLOB` |
|
| 1354 | -- 文本类型:`TINYTEXT`、`TEXT`、`MEDIUMTEXT`、`LONGTEXT`、`STRING` |
|
| 1355 | - |
|
| 1356 | ---- |
|
| 1357 | - |
|
| 1358 | -### 4. MySQL 模式使用限制 |
|
| 1359 | - |
|
| 1360 | -#### 4.1 集群名长度限制 |
|
| 1361 | - |
|
| 1362 | -| 数据项 | 最大长度 | |
|
| 1363 | -| ------ | -------- | |
|
| 1364 | -| 集群名 | 128 字节 | |
|
| 1365 | - |
|
| 1366 | -#### 4.2 标识符长度限制 |
|
| 1367 | - |
|
| 1368 | -| 数据项 | 最大长度 | |
|
| 1369 | -| -------- | -------- | |
|
| 1370 | -| 用户名 | 64 字节 | |
|
| 1371 | -| 租户名 | 63 字节 | |
|
| 1372 | -| 数据库名 | 128 字节 | |
|
| 1373 | -| 表名 | 64 字符 | |
|
| 1374 | -| 列名 | 128 字节 | |
|
| 1375 | -| 索引名 | 64 字节 | |
|
| 1376 | -| 视图名 | 64 字节 | |
|
| 1377 | -| 别名 | 255 字节 | |
|
| 1378 | -| 表组名 | 127 字节 | |
|
| 1379 | - |
|
| 1380 | -#### 4.3 单个表的限制 |
|
| 1381 | - |
|
| 1382 | -| 类型 | 最大限制 | |
|
| 1383 | -| ---------- | ------------------------------------------------------------ | |
|
| 1384 | -| 行长度 | 1.5M 字节 | |
|
| 1385 | -| 列数 | 4096 列 | |
|
| 1386 | -| 索引个数 | 128 个 | |
|
| 1387 | -| 索引总列数 | 512 列 | |
|
| 1388 | -| 索引长度 | 16K | |
|
| 1389 | -| 主键总列数 | 64 列 | |
|
| 1390 | -| 主键长度 | 16K | |
|
| 1391 | -| 分区个数 | Oracle 模式:65536 个,MySQL 模式:8192 个(从 V4.2.1 BP3 版本开始,MySQL 模式下单个表允许的最大分区数由租户级配置项 `max_partition_num` 控制,默认为 8192 个) | |
|
| 1392 | - |
|
| 1393 | -#### 4.4 单列的限制 |
|
| 1394 | - |
|
| 1395 | -| 类型 | 最大限制 | |
|
| 1396 | -| -------------- | -------- | |
|
| 1397 | -| 索引单个列长度 | 16K | |
|
| 1398 | - |
|
| 1399 | -#### 4.5 字符串类型限制 |
|
| 1400 | - |
|
| 1401 | -| 类型 | 最大长度 | |
|
| 1402 | -| ------------ | -------------- | |
|
| 1403 | -| `CHAR` | 256 字符 | |
|
| 1404 | -| `VARCHAR` | 262144 字符 | |
|
| 1405 | -| `BINARY` | 256 字节 | |
|
| 1406 | -| `VARBINARY` | 1048576 字节 | |
|
| 1407 | -| `TINYBLOB` | 255 字节 | |
|
| 1408 | -| `BLOB` | 65535 字节 | |
|
| 1409 | -| `MEDIUMBLOB` | 16777215 字节 | |
|
| 1410 | -| `LONGBLOB` | 536870910 字节 | |
|
| 1411 | -| `TINYTEXT` | 255 字节 | |
|
| 1412 | -| `TEXT` | 65535 字节 | |
|
| 1413 | -| `MEDIUMTEXT` | 16777215 字节 | |
|
| 1414 | -| `LONGTEXT` | 536870910 字节 | |
|
| 1415 | - |
|
| 1416 | ---- |
|
| 1417 | - |
|
| 1418 | -### 5. 创建索引 |
|
| 1419 | - |
|
| 1420 | -**参考文档**:[创建索引](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013233) |
|
| 1421 | - |
|
| 1422 | -#### 5.1 创建索引的限制 |
|
| 1423 | - |
|
| 1424 | -- 索引名称必须在数据库范围内唯一,长度不能超过 64 字节。 |
|
| 1425 | -- 唯一索引的列值必须保持唯一,局部唯一索引必须包含表的分区函数中的所有列。 |
|
| 1426 | -- 全局索引的分区规则不一定需要与表的分区规则完全相同。 |
|
| 1427 | - |
|
| 1428 | ---- |
|
| 1429 | - |
|
| 1430 | -### 6. 数据写入 |
|
| 1431 | - |
|
| 1432 | -**参考文档**: |
|
| 1433 | - |
|
| 1434 | -- [插入数据](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013243) |
|
| 1435 | -- [更新数据](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013240) |
|
| 1436 | -- [删除数据](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013244) |
|
| 1437 | -- [替换数据](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013241) |
|
| 1438 | - |
|
| 1439 | ---- |
|
| 1440 | - |
|
| 1441 | -### 7. 数据读取 |
|
| 1442 | - |
|
| 1443 | -**参考文档**: |
|
| 1444 | - |
|
| 1445 | -- [单表查询](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013225) |
|
| 1446 | -- [多表关联查询](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013650) |
|
| 1447 | -- [在查询中使用操作符和函数](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013225) |
|
| 1448 | - |
|
| 1449 | ---- |
|
| 1450 | - |
|
| 1451 | -### 8. 事务 |
|
| 1452 | - |
|
| 1453 | -事务机制和 MySQL 一样,完全兼容 MySQL。 |
|
| 1454 | - |
|
| 1455 | -**事务控制语句**: |
|
| 1456 | - |
|
| 1457 | -- [BEGIN](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013247):显式开启一个事务。 |
|
| 1458 | -- [SAVEPOINT](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013673):在事务过程中标记一个“保存点”。 |
|
| 1459 | -- [COMMIT](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013246):提交并结束当前事务。 |
|
| 1460 | -- [ROLLBACK](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013245):回滚整个事务或回滚到某个保存点。 |
|
| 1461 | - |
|
| 1462 | -**相关文档**: |
|
| 1463 | - |
|
| 1464 | -- [开启事务](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013247) |
|
| 1465 | -- [事务保存点](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013673) |
|
| 1466 | -- [提交事务](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013246) |
|
| 1467 | -- [回滚事务](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013245) |
|
| 1468 | - |
|
| 1469 | ---- |
|
| 1470 | - |
|
| 1471 | -### 9. 租户管理 |
|
| 1472 | - |
|
| 1473 | -OceanBase 数据库采用了多租户架构。集群是 Zone 和节点的集合,租户则是资源层面的逻辑概念,通过资源池与资源关联。 |
|
| 1474 | - |
|
| 1475 | -**相关文档**: |
|
| 1476 | - |
|
| 1477 | -- [租户介绍](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002012845) |
|
| 1478 | -- [租户容量](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002012845) |
|
| 1479 | -- [租户类型](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002012845) |
|
| 1480 | -- [用户租户介绍](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002012842) |
|
| 1481 | -- [租户系统变量](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002012845) |
|
| 1482 | -- [租户常见操作](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013128) |
|
| 1483 | - |
|
| 1484 | ---- |
|
| 1485 | - |
|
| 1486 | -### 10. 批量操作配置 |
|
| 1487 | - |
|
| 1488 | -**异常 SQL 示例**: |
|
| 1489 | - |
|
| 1490 | -```sql |
|
| 1491 | -SQL出错:DELETE FROM ui_file_seed WHERE id = 'mbm-mdm.master.mbm_mdm_wip_resource_template',异常信息:Not supported feature or function |
|
| 1492 | -2025-03-27 14:52:05.083 [main] ERROR c.s.snest.engine.db.relationdb.RelationDBAccessor -数据源:main,批量执行SQL出错:DELETE FROM ui_file_seed WHERE id = 'mbm-mdm.master.whm_storage_location_template',异常信息:批量执行SQL出错 |
|
| 1493 | -``` |
|
| 1494 | - |
|
| 1495 | -遇到批量执行 SQL 出错时,需要添加参数到 JDBC URL:`rewriteBatchedStatements=TRUE&allowMultiQueries=TRUE` |
|
| 1496 | - |
|
| 1497 | -**参考文档**:[JDBC 配置示例](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013674) |
|
| 1498 | - |
|
| 1499 | -**JDBC 连接示例**: |
|
| 1500 | - |
|
| 1501 | -```plaintext |
|
| 1502 | -url=jdbc:oceanbase://xxx.xxx.xxx.xxx:3306/test?rewriteBatchedStatements=TRUE&allowMultiQueries=TRUE&useLocalSessionState=TRUE&useUnicode=TRUE&characterEncoding=utf-8&socketTimeout=10000&connectTimeout=30000 |
|
| 1503 | -``` |
|
| 1504 | - |
|
| 1505 | -**相关参数说明**: |
|
| 1506 | - |
|
| 1507 | -- `rewriteBatchedStatements`:建议设置为 `TRUE`,以提高批量插入的性能。 |
|
| 1508 | -- `allowMultiQueries`:建议设置为 `TRUE`,允许使用分号连接的多语句文本格式。 |
|
| 1509 | -- `useLocalSessionState`:建议设置为 `TRUE`,避免频繁向 OB 数据库发送 session 变量查询 SQL。 |
|
| 1510 | -- `socketTimeout`:执行 SQL 时,socket 等待 SQL 返回的时间。 |
|
| 1511 | -- `connectTimeout`:建立连接时,等待连接的时间。 |
|
| 1512 | -- `useCursorFetch`:建议设置为 `TRUE`,适用于大数据量查询。 |
|
| 1513 | -- `useServerPrepStms`:控制是否使用 PS 协议发送 SQL。 |
|
| 1514 | -- `cachePrepStmts`:控制是否开启 PS cache,避免重复执行 prepare。 |
|
| 1515 | -- `prepStmtCacheSQLLimit`:可放入 PS cache 的 SQL 长度限制。 |
|
| 1516 | -- `prepStmtCacheSize`:PS cache 可保存的 SQL 数量。 |
|
| 1517 | -- `maxBatchTotalParamsNum`:针对 batch 操作,一条 SQL 最多支持的参数个数。 |
|
| 1518 | - |
|
| 1519 | ---- |
|
| 1520 | - |
|
| 1521 | -### 11. 数据类型转换规则 |
|
| 1522 | - |
|
| 1523 | -数据类型转换和 MySQL 一致。 |
|
| 1524 | - |
|
| 1525 | ---- |
|
| 1526 | - |
|
| 1527 | -### 12. Docker 部署 OceanBase |
|
| 1528 | - |
|
| 1529 | -**安装参考文档**:[Docker 部署 OceanBase](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013494) |
|
| 1530 | - |
|
| 1531 | -**部署步骤**: |
|
| 1532 | - |
|
| 1533 | -```shell |
|
| 1534 | -sudo docker pull quay.io/oceanbase/oceanbase-ce |
|
| 1535 | -sudo docker run -p 2881:2881 --name oceanbase -e MODE=MINI -e OB_TENANT_PASSWORD=****** -d quay.io/oceanbase/oceanbase-ce |
|
| 1536 | -sudo docker logs oceanbase | tail -1 |
|
| 1537 | -sudo docker exec -it oceanbase bash |
|
| 1538 | -docker logs oceanbase | tail -1 |
|
| 1539 | - |
|
| 1540 | -obclient -uroot@sys -h127.0.0.1 -P2881 -p |
|
| 1541 | --- 默认密码为空,直接回车 |
|
| 1542 | - |
|
| 1543 | --- 修改密码 |
|
| 1544 | -ALTER USER 'root' IDENTIFIED BY 'your_password'; |
|
| 1545 | - |
|
| 1546 | -obclient -uroot@sys -h127.0.0.1 -P2881 -p your_password |
|
| 1547 | - |
|
| 1548 | -CREATE DATABASE snest_changwen DEFAULT CHARACTER SET utf8mb4 READ WRITE; |
|
| 1549 | - |
|
| 1550 | -show databases; |
|
| 1551 | -``` |
|
| 1552 | - |
|
| 1553 | -### 13. 本地 JDBC连接 OceanBase |
|
| 1554 | -dbcp.properties添加oceanbase配置 |
|
| 1555 | - |
|
| 1556 | -```shell |
|
| 1557 | -########OceanBase######## |
|
| 23 | +```properties |
|
| 24 | +########DBCP########## |
|
| 1558 | 25 | driverClassName=com.mysql.cj.jdbc.Driver |
| 1559 | -url=jdbc:mysql://xxx.xxx.xxx.xxx:2881/snest?rewriteBatchedStatements=TRUE&allowMultiQueries=TRUE&useLocalSessionState=TRUE&useUnicode=TRUE&characterEncoding=utf-8&socketTimeout=10000&connectTimeout=30000&zeroDateTimeBehavior=convertToNull&allowPublicKeyRetrieval=true |
|
| 1560 | -username=root |
|
| 1561 | -password=****** |
|
| 1562 | -validationQuery=SELECT 1 |
|
| 1563 | -``` |
|
| 1564 | - |
|
| 1565 | -## 五 GaussDB 参考手册 |
|
| 1566 | - |
|
| 1567 | -### 1. 产品概述 |
|
| 1568 | - |
|
| 1569 | -GaussDB 是华为云推出的一款高性能、高可用、可扩展的云数据库产品,支持分布式和集中式两种部署模式。它适用于多种应用场景,包括企业级应用、数据分析和物联网等。 |
|
| 1570 | - |
|
| 1571 | -更多版本信息请参考:[GaussDB 文档中心](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/productdesc/gaussdb_01_059.html) |
|
| 1572 | - |
|
| 1573 | -**高斯数据库支持的版本**: |
|
| 1574 | - |
|
| 1575 | -``` |
|
| 1576 | -SELECT VERSION(); |
|
| 1577 | -gaussdb (GaussDB Kernel 505.2.0 build 5a40f15c) compiled at 2024-09-20 00:15:19 commit 9967 last mr 19883 release |
|
| 1578 | -``` |
|
| 1579 | - |
|
| 1580 | -**引擎版本**: v2.8.1-RELEASE |
|
| 1581 | - |
|
| 1582 | -引擎支持的高斯数据库默认是使用的 MySQL 兼容模式,所以应用程序的SQL语法和MySQL基本兼容. |
|
| 1583 | - |
|
| 1584 | -**IIDP目前支持高斯数据库的MySQL数据库兼容MySQL模式** |
|
| 1585 | - |
|
| 1586 | -```xml |
|
| 1587 | -<dependency> |
|
| 1588 | - <groupId>com.sie.meta</groupId> |
|
| 1589 | - <artifactId>sie-snest-engine</artifactId> |
|
| 1590 | - <version>v2.8.1-RELEASE</version> |
|
| 1591 | -</dependency> |
|
| 1592 | -``` |
|
| 1593 | - |
|
| 1594 | - |
|
| 1595 | - |
|
| 1596 | -**SqlProvider实现:** com.sie.snest.engine.db.relationdb.provider.GaussDBProvider |
|
| 1597 | - |
|
| 1598 | -返回数据库类型DBType: GaussDB |
|
| 1599 | - |
|
| 1600 | -```java |
|
| 1601 | - com.sie.snest.engine.db.relationdb.provider.GaussDBProvider |
|
| 1602 | - /** |
|
| 1603 | - * return GaussDB |
|
| 1604 | - */ |
|
| 1605 | - @Override |
|
| 1606 | - public String getDBType() { |
|
| 1607 | - return DBType.GaussDB.getName(); |
|
| 1608 | - } |
|
| 1609 | -``` |
|
| 1610 | - |
|
| 1611 | - |
|
| 1612 | - |
|
| 1613 | - |
|
| 1614 | - |
|
| 1615 | -### 2. 部署方案 |
|
| 1616 | - |
|
| 1617 | -- [分布式版部署方案](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/productdesc/gaussdb_01_060.html) |
|
| 1618 | - |
|
| 1619 | -- [集中式版部署方案](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/productdesc/gaussdb_01_061.html) |
|
| 1620 | - |
|
| 1621 | - |
|
| 1622 | - |
|
| 1623 | -### 3. GaussDB 数据库兼容性说明 |
|
| 1624 | - |
|
| 1625 | -GaussDB 支持多种兼容性模式,具体如下: |
|
| 1626 | - |
|
| 1627 | -- **集中式部署**: |
|
| 1628 | - - `A`:兼容 Oracle。 |
|
| 1629 | - - `B`:兼容 MySQL。 |
|
| 1630 | - - `PG`:兼容 PostgreSQL。 |
|
| 1631 | -- **分布式部署**: |
|
| 1632 | - - `ORA`:兼容 Oracle。 |
|
| 1633 | - - `MYSQL`:兼容 MySQL。 |
|
| 1634 | - - `PG`:兼容 PostgreSQL。 |
|
| 1635 | - |
|
| 1636 | -执行以下 SQL 命令,可以查看所有数据库的兼容性模式: |
|
| 1637 | - |
|
| 1638 | -```sql |
|
| 1639 | -SELECT datname, datcompatibility FROM pg_database; |
|
| 1640 | - |
|
| 1641 | -datname |datcompatibility| |
|
| 1642 | ------------+----------------+ |
|
| 1643 | -templatea |ORA | |
|
| 1644 | -snest_test3|MySQL | |
|
| 1645 | -test |MYSQL | |
|
| 1646 | -template1 |MYSQL | |
|
| 1647 | -template0 |MYSQL | |
|
| 1648 | -templatem |M | |
|
| 1649 | -postgres |MYSQL | |
|
| 1650 | -tpcc |MYSQL | |
|
| 26 | +url=jdbc:mysql://127.0.0.1:3306/iidp?useUnicode=true&characterEncoding=UTF-8&zeroDateTimeBehavior=convertToNull&useSSL=false&allowPublicKeyRetrieval=true |
|
| 27 | +username=username |
|
| 28 | +password=password |
|
| 29 | +initialSize=5 |
|
| 30 | +maxActive=500 |
|
| 31 | +minIdle=5 |
|
| 32 | +maxWait=6000 |
|
| 33 | +filters=stat |
|
| 34 | +timeBetweenEvictionRunsMillis=60000 |
|
| 35 | +minEvictableIdleTimeMillis=300000 |
|
| 36 | +validationQuery=select 'x' |
|
| 37 | +testOnBorrow=false |
|
| 38 | +testOnReturn=false |
|
| 39 | +testWhileIdle=true |
|
| 40 | +poolPreparedStatements=true |
|
| 41 | +maxOpenPreparedStatements=20 |
|
| 1651 | 42 | ``` |
| 1652 | 43 | |
| 1653 | -#### 1. MySQL 兼容模式 |
|
| 1654 | - |
|
| 1655 | -**IIDP只支持高斯数据库的MySQL数据库兼容MySQL模式** |
|
| 1656 | - |
|
| 1657 | -GaussDB 提供了对 MySQL 5.7 的兼容模式,通过设置特定的参数,可以实现与 MySQL 5.7 数据库的高度兼容。以下是具体的兼容性说明: |
|
| 1658 | - |
|
| 1659 | -由于GaussDB数据库与MySQL数据库底层框架实现存在差异,GaussDB数据库与MySQL数据库仍存在部分差异。 |
|
| 1660 | - |
|
| 1661 | -分布式版MySQL兼容性说明 |
|
| 1662 | - |
|
| 1663 | -- **[概述](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/compatibility-description/gaussdb-20-0031.html)** |
|
| 1664 | -- **[MySQL数据库兼容MySQL模式](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/compatibility-description/gaussdb-20-0001.html)** |
|
| 1665 | -- **[MySQL数据库兼容性M-Compatibility模式](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/compatibility-description/gaussdb-20-0032.html)** |
|
| 1666 | - |
|
| 1667 | -**参考文档:** https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.7.30.10/compatibility-description/gaussdb-20-0002.html |
|
| 1668 | - |
|
| 1669 | - |
|
| 1670 | - |
|
| 1671 | -##### 1.1 参数设置 |
|
| 1672 | - |
|
| 1673 | -为了启用 MySQL 兼容模式,需要在 GaussDB 数据库中设置以下参数: |
|
| 1674 | - |
|
| 1675 | -- **`sql_compatibility`**:设置为 `'MYSQL'`,以启用 MySQL 兼容模式。 |
|
| 1676 | - |
|
| 1677 | -- **`b_format_version`**:设置为 `'5.7'`,以指定 MySQL 的版本兼容性。 |
|
| 1678 | - |
|
| 1679 | -- **`b_format_dev_version`**:设置为 `'s1'`,以指定开发版本的兼容性。 |
|
| 44 | +--- |
|
| 1680 | 45 | |
| 1681 | - ``` |
|
| 1682 | - SHOW enable_gtm_free; |
|
| 1683 | - SHOW gtm_option; |
|
| 1684 | - show b_format_version; |
|
| 1685 | - show b_format_dev_version; |
|
| 1686 | - ``` |
|
| 46 | +## 二、Oracle 参考手册 |
|
| 1687 | 47 | |
| 1688 | -##### 1.2 数据类型兼容性 |
|
| 48 | +### 1. 本地 JDBC 配置 |
|
| 1689 | 49 | |
| 1690 | -- GaussDB 支持 MySQL 5.7 中定义的大多数数据类型,包括但不限于: |
|
| 1691 | - - **数值类型**:`TINYINT`、`SMALLINT`、`MEDIUMINT`、`INT`、`BIGINT`、`DECIMAL`、`FLOAT`、`DOUBLE` 等。 |
|
| 1692 | - - **字符串类型**:`CHAR`、`VARCHAR`、`TEXT`、`BLOB` 等。 |
|
| 1693 | - - **日期和时间类型**:`DATE`、`TIME`、`DATETIME`、`TIMESTAMP` 等。 |
|
| 1694 | -- 在某些情况下,GaussDB 可能对某些数据类型的行为或限制进行了优化或调整,以适应其自身的架构和性能要求。 |
|
| 50 | +```properties |
|
| 51 | +########Oracle######## |
|
| 52 | +driverClassName=oracle.jdbc.OracleDriver |
|
| 53 | +url=jdbc:oracle:thin:@127.0.0.1:1521:SMOMDB |
|
| 54 | +username=username |
|
| 55 | +password=password |
|
| 56 | +validationQuery=SELECT 'x' FROM DUAL |
|
| 57 | +initialSize=5 |
|
| 58 | +maxActive=500 |
|
| 59 | +minIdle=5 |
|
| 60 | +maxWait=6000 |
|
| 61 | +filters=stat |
|
| 62 | +timeBetweenEvictionRunsMillis=60000 |
|
| 63 | +minEvictableIdleTimeMillis=300000 |
|
| 64 | +validationQuery=select 'x' |
|
| 65 | +testOnBorrow=false |
|
| 66 | +testOnReturn=false |
|
| 67 | +testWhileIdle=true |
|
| 68 | +poolPreparedStatements=true |
|
| 69 | +maxOpenPreparedStatements=20 |
|
| 70 | +``` |
|
| 1695 | 71 | |
| 1696 | -##### 1.3 SQL 功能兼容性 |
|
| 72 | +--- |
|
| 1697 | 73 | |
| 1698 | -- **SQL 语法**:GaussDB 支持 MySQL 5.7 的大多数 SQL 语法,包括: |
|
| 1699 | - - 数据定义语言(DDL):如 `CREATE TABLE`、`ALTER TABLE`、`DROP TABLE` 等。 |
|
| 1700 | - - 数据操纵语言(DML):如 `INSERT`、`UPDATE`、`DELETE`、`SELECT` 等。 |
|
| 1701 | - - 数据控制语言(DCL):如 `GRANT`、`REVOKE` 等。 |
|
| 1702 | -- **存储过程和函数**:支持 MySQL 5.7 的存储过程和函数语法,用户可以创建和使用存储过程来实现复杂的业务逻辑。 |
|
| 1703 | -- **视图和索引**:支持视图和索引的创建和使用,用户可以通过视图简化复杂的查询操作,并利用索引提高查询性能。 |
|
| 1704 | -- **事务支持**:支持事务操作,确保数据的一致性和完整性。 |
|
| 74 | +## 三、PostgreSQL 参考手册 |
|
| 1705 | 75 | |
| 1706 | -##### 1.4 数据库对象兼容性 |
|
| 76 | +**PostgreSQL 版本:** 16.6 |
|
| 77 | +**下载地址:** [PostgreSQL 官方下载](https://www.enterprisedb.com/downloads/postgres-postgresql-downloads) |
|
| 1707 | 78 | |
| 1708 | -- **表和表空间**:支持 MySQL 5.7 中的表和表空间概念,用户可以创建、修改和删除表,以及管理表空间。 |
|
| 1709 | -- **用户和权限管理**:支持 MySQL 5.7 的用户和权限管理机制,用户可以创建和管理用户账户,并授予或撤销用户权限。 |
|
| 1710 | -- **字符集和校对规则**:支持 MySQL 5.7 的字符集和校对规则,用户可以根据需要选择合适的字符集和校对规则。 |
|
| 79 | +### 1. 本地 JDBC 配置 |
|
| 1711 | 80 | |
| 1712 | -##### 1.5 特殊兼容性说明 |
|
| 81 | +```properties |
|
| 82 | +########DBCP########## |
|
| 83 | +driverClassName=org.postgresql.Driver |
|
| 84 | +url=jdbc:postgresql://127.0.0.1:5432/snest?currentSchema=public&encoding=UTF-8&timezone=UTC |
|
| 85 | +username=username |
|
| 86 | +password=password |
|
| 87 | +initialSize=5 |
|
| 88 | +maxActive=500 |
|
| 89 | +minIdle=20 |
|
| 90 | +filters=stat |
|
| 91 | +maxWait=6000 |
|
| 92 | +timeBetweenEvictionRunsMillis=60000 |
|
| 93 | +minEvictableIdleTimeMillis=300000 |
|
| 94 | +testOnBorrow=false |
|
| 95 | +testOnReturn=false |
|
| 96 | +testWhileIdle=true |
|
| 97 | +poolPreparedStatements=true |
|
| 98 | +maxOpenPreparedStatements=50 |
|
| 99 | +connectionProperties=druid.stat.sql.MaxSize=100; |
|
| 100 | +keepAlive=true |
|
| 101 | +``` |
|
| 1713 | 102 | |
| 1714 | -- **语法差异**:尽管 GaussDB 努力实现与 MySQL 5.7 的高度兼容,但在某些复杂的 SQL 语法或特定功能上可能存在差异。例如,某些特定的 MySQL 函数或存储过程可能在 GaussDB 中表现略有不同。 |
|
| 1715 | -- **性能优化**:GaussDB 在某些场景下可能需要额外的性能优化配置,以充分发挥其性能优势。 |
|
| 1716 | -- **功能限制**:某些 MySQL 特性可能在 GaussDB 中不完全支持,或者需要通过其他方式实现。 |
|
| 103 | +### 2. PostgreSQL 特性 |
|
| 1717 | 104 | |
| 1718 | -#### 2. **其他兼容模式** |
|
| 105 | +#### 2.0 标识符大小写与引号使用对比 |
|
| 1719 | 106 | |
| 1720 | -GaussDB 还支持其他数据库的兼容模式,例如 Oracle、PostgreSQL 和 Teradata 等。以下是简要说明: |
|
| 107 | +| 特性 | PostgreSQL | MySQL | |
|
| 108 | +| ---------------- | ---------------- | -------------- | |
|
| 109 | +| 默认大小写处理 | 大写转小写 | 依赖系统与配置 | |
|
| 110 | +| 保留大小写方式 | 双引号 `"` | 反引号 `` ` `` | |
|
| 111 | +| 字符串引号 | 单引号 `'` | 单/双引号 | |
|
| 112 | +| 标识符引号 | 双引号 `"` | 反引号 `` ` `` | |
|
| 113 | +| 列名大小写敏感性 | 依赖是否加双引号 | 所有系统不区分 | |
|
| 1721 | 114 | |
| 1722 | -##### 2.1 Oracle 兼容模式 |
|
| 115 | +#### 2.1 Boolean 值问题 |
|
| 1723 | 116 | |
| 1724 | -- **参数设置**:使用参数 `c='A'` 或 `dbcompatibility='ORA'` 创建兼容 Oracle 的数据库。 |
|
| 1725 | -- **功能支持**:支持 Oracle 的数据类型、SQL 语法、系统函数、日期时间类型等。 |
|
| 117 | +引擎使用 `CHAR(1)` 代替 `BOOLEAN`,插入 `CHAR(1)`,查询返回 `BOOLEAN`。 |
|
| 1726 | 118 | |
| 1727 | -##### 2.2 PostgreSQL 兼容模式 |
|
| 119 | +#### 2.2 索引名称长度限制 |
|
| 1728 | 120 | |
| 1729 | -- **参数设置**:使用参数 `dbcompatibility='PG'` 创建兼容 PostgreSQL 的数据库。 |
|
| 1730 | -- **功能支持**:支持 PostgreSQL 的数据类型、SQL 语法和对象定义。 |
|
| 121 | +- 最大 63 字节,超长自动截断并警告 |
|
| 122 | +- 同一 schema 内唯一 |
|
| 123 | +- 推荐命名:`idx_表_列`、`uk_表_列` |
|
| 1731 | 124 | |
| 1732 | -更多详细信息和完整兼容性说明,请参考 GaussDB 官方文档: |
|
| 125 | +#### 2.3 Transactional DDL |
|
| 1733 | 126 | |
| 1734 | -- [GaussDB 文档中心 - MySQL 兼容性概述](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/compatibility-description/gaussdb-20-0002.html) |
|
| 127 | +PostgreSQL 支持在事务中回滚 DDL(`CREATE`、`ALTER`、`DROP` 等)。 |
|
| 128 | +MySQL / Oracle 执行 DDL 会隐式提交当前事务。 |
|
| 1735 | 129 | |
| 130 | +#### 2.4 数据类型转换规则 |
|
| 1736 | 131 | |
| 132 | +- 字符串 → 数字必须显式 `CAST` |
|
| 133 | +- 示例:`INSERT INTO t(age) VALUES (CAST('123' AS INTEGER));` |
|
| 1737 | 134 | |
| 1738 | -### 4. 高斯数据库不兼容项 |
|
| 135 | +#### 2.5 事务中止错误 |
|
| 1739 | 136 | |
| 1740 | -#### 1. 不支持唯一索引,不支持复合唯一索引 |
|
| 137 | +**错误:** |
|
| 138 | +`current transaction is aborted, commands ignored until end of transaction block` |
|
| 1741 | 139 | |
| 1742 | -在华为GaussDB中,当出现“Cannot create index whose evaluation cannot be enforced to remote nodes”错误时,通常是因为在分布式数据库系统中创建索引时,没有包含分布列(即决定数据如何在各个节点间分布的列)。 **之前的MySQL唯一索引就失效了**. |
|
| 140 | +**解决:** |
|
| 141 | +执行 `ROLLBACK;` 后重新开启事务。 |
|
| 1743 | 142 | |
| 1744 | -主键约束的本质就是一个非空约束加一个唯一约束,重点关注这个唯一约束(通过一个唯一索引实现)。 |
|
| 143 | +#### 2.6 JSON 数据类型 |
|
| 1745 | 144 | |
| 1746 | -对于hash分布表,分布列决定了这条数据将在CN(CoordinateNode协调节点)被hash分布到哪个DN(DataNode数据节点)上,所以唯一约束本质上是确保分布到这个DN的数据的唯一性。如果允许唯一约束不包含分布列,那么就会出现在不同DN上查询到相同唯一键的情况,这肯定不是期望内的。 |
|
| 145 | +- `JSON`:保留原始文本格式 |
|
| 1747 | 146 | |
| 1748 | -对于复制表(replicated table), 由于每个数据在每个DN上都被存有一份,所以不存在这个问题。 |
|
| 147 | +- `JSONB`:二进制,推荐生产使用 |
|
| 1749 | 148 | |
| 1750 | -所以出现这个报错的时候要么使主键的定义包含分布列,要么改用复制表,要么使用复合唯一索引,要么使用全局二级索引。 |
|
| 149 | +- 创建 GIN 索引: |
|
| 1751 | 150 | |
| 151 | + ```sql |
|
| 152 | + CREATE INDEX idx_jsonb ON tbl USING GIN (jsonb_col); |
|
| 153 | + ``` |
|
| 1752 | 154 | |
| 155 | +#### 2.7 UPDATE 列名不能带别名 |
|
| 1753 | 156 | |
| 1754 | -**不支持原因:** |
|
| 157 | +```sql |
|
| 158 | +-- 错误 |
|
| 159 | +UPDATE tenant_user_instance t |
|
| 160 | +SET t."update_date" = ... |
|
| 1755 | 161 | |
| 1756 | -1. 使用唯一索引时: 唯一列必须包含分布式列,导致复合唯一索引失效了,因为必须带ID字段加唯一字段,就违背了复合唯一索引的定义. |
|
| 162 | +-- 正确 |
|
| 163 | +UPDATE tenant_user_instance t |
|
| 164 | +SET update_date = ... |
|
| 165 | +WHERE t.action_dimension_id = ... |
|
| 166 | +``` |
|
| 1757 | 167 | |
| 1758 | -2. 使用全局二级索引:遇到下面3个错误: |
|
| 168 | +#### 2.8 SELECT AS 别名大小写 |
|
| 1759 | 169 | |
| 1760 | - ```sql |
|
| 1761 | - ERROR: INSERT/UPDATE/DELETE/MERGE contains multiple remote queries under GTM-free mode |
|
| 1762 | - |
|
| 1763 | - 解决方式:开启GTM-free 模式 |
|
| 1764 | - ``` |
|
| 170 | +未加双引号的别名会被转为小写。 |
|
| 171 | +**正确:** |
|
| 1765 | 172 | |
| 1766 | - |
|
| 173 | +```sql |
|
| 174 | +SELECT display_name AS "displayName" FROM meta_app; |
|
| 175 | +``` |
|
| 1767 | 176 | |
| 1768 | - 解决完第一个错误后,然后又遇到下面的错误: |
|
| 177 | +#### 2.9 Schema 概念 |
|
| 1769 | 178 | |
| 1770 | - ```sql |
|
| 1771 | - INSERT ... SELECT ... WHERE NOT EXISTS 不支持, INSERT INTO IGNORE不支持, 改为INSERT INTO " + sql +" ON DUPLICATE KEY UPDATE NOTHING |
|
| 1772 | - 解决方式:使用流算子或 Hint |
|
| 1773 | - SET enable_stream_operator=on; |
|
| 1774 | - 或者在 SQL 语句中添加 `/*+ multinode */` Hint: |
|
| 1775 | - ``` |
|
| 179 | +| 维度 | PostgreSQL | MySQL | |
|
| 180 | +| ----------- | --------------------- | -------------- | |
|
| 181 | +| 层级 | 库 → schema → 表 | 实例 → 库 → 表 | |
|
| 182 | +| 默认 schema | `public` | 无 | |
|
| 183 | +| 跨空间访问 | 同一连接内可跨 schema | 跨库需多连接 | |
|
| 1776 | 184 | |
| 1777 | - |
|
| 185 | +--- |
|
| 1778 | 186 | |
| 1779 | - 修复完上面的2个错误后,又遇到往数据库插入或更新数据时报错,提示分布键不能被更新,错误信息如下所示: |
|
| 187 | +### 3. PostgreSQL 基础教程(目录) |
|
| 1780 | 188 | |
| 1781 | - ``` |
|
| 1782 | - ERROR: Distributed key column can't be updated in current version |
|
| 1783 | - ``` |
|
| 189 | +已整理为独立页面,请参见 [PostgreSQL 教程](https://www.rockdata.net/zh-cn/tutorial/toc/)。 |
|
| 1784 | 190 | |
| 1785 | -这个错误的意思是,如果列是分布式列,就不能更新该字段,这种就会导致应用程序更新失败.咨询了华为的同事.没有参数可以跳过. |
|
| 191 | +--- |
|
| 1786 | 192 | |
| 1787 | -3. 因为引擎插入和更新的时候会做唯一校验,如果不支持唯一校验,不影响业务的插入和更新时的唯一校验. |
|
| 193 | +### 4. PostgreSQL 高级教程(目录) |
|
| 1788 | 194 | |
| 195 | +已整理为独立页面,请参见 [PostgreSQL 高级教程](https://www.rockdata.net/zh-cn/tutorial/postgres-advanced/)。 |
|
| 1789 | 196 | |
| 197 | +--- |
|
| 1790 | 198 | |
| 1791 | -#### 2. SELECT AS 别名问题,如果别名不带标识符``或者"",PostgreSQL/GaussDB会将别名转成小写 |
|
| 199 | +## 四、OceanBase 参考手册 |
|
| 1792 | 200 | |
| 1793 | -请注意,在 PostgreSQL/GaussDB 中,关键词和不被引号修饰的标识符是大小写不敏感的。因此,如果字段不带修饰符双引号,会转换成小写. |
|
| 201 | +### 1. 与 MySQL 兼容性总结及 JDBC 配置 |
|
| 1794 | 202 | |
| 1795 | -如果自定义SQL列别名不带修饰符,这样就会导致代码获取displayName值为NULL, get("displayName")=NULL.就会导致数据库迁移的时候,不兼容. |
|
| 203 | +- 高度兼容 MySQL 5.7/8.0 SQL 语法、事务、系统表 |
|
| 204 | +- JDBC 必须追加参数: |
|
| 205 | + `rewriteBatchedStatements=TRUE&allowMultiQueries=TRUE` |
|
| 1796 | 206 | |
| 1797 | -**正确的SQL写法,列别名如果是驼峰或者包含大小写的,一定要用 ``或者 ""引起来.** |
|
| 207 | +示例: |
|
| 1798 | 208 | |
| 209 | +```properties |
|
| 210 | +url=jdbc:mysql://xxx.xxx.xxx.xxx:2881/test?rewriteBatchedStatements=TRUE&allowMultiQueries=TRUE&useLocalSessionState=TRUE&characterEncoding=utf-8&socketTimeout=3000000&connectTimeout=60000&zeroDateTimeBehavior=convertToNull&allowPublicKeyRetrieval=true |
|
| 1799 | 211 | ``` |
| 1800 | -select display_name as displayName from meta_app; |
|
| 1801 | - |
|
| 1802 | ---MySQL |
|
| 1803 | -displayName | |
|
| 1804 | ------------------+ |
|
| 1805 | -基础模块 | |
|
| 1806 | - |
|
| 1807 | - |
|
| 1808 | ---PostgreSQL/GaussDB |
|
| 1809 | -displayname | |
|
| 1810 | ------------------+ |
|
| 1811 | -基础模块 |
|
| 1812 | 212 | |
| 213 | +### 2. 批量操作配置 |
|
| 1813 | 214 | |
| 1814 | -正确的SQL写法,列别名如果是驼峰或者包含大小写的 |
|
| 1815 | -MYSQL: select display_name as `displayName` from meta_app; |
|
| 1816 | -GAUSSDB select display_name as `displayName` from meta_app; |
|
| 1817 | -PostgreSQL: select display_name as "displayName" from meta_app; |
|
| 215 | +出错时检查是否缺失上述两项参数,参考 [JDBC 配置示例](https://www.oceanbase.com/docs/common-oceanbase-database-cn-1000000002013674)。 |
|
| 1818 | 216 | |
| 1819 | -项目自定义SQL错误的示范: |
|
| 1820 | -SELECT param_name paramName, param_value paramValue FROM base_process_spec bps; |
|
| 217 | +### 3. Docker 部署 |
|
| 1821 | 218 | |
| 1822 | -标准的SQL语法: |
|
| 1823 | -SELECT param_name "paramName", param_value `paramValue` FROM base_process_spec bps |
|
| 1824 | -SELECT param_name "paramName", param_value "paramValue" FROM base_process_spec bps |
|
| 219 | +```bash |
|
| 220 | +docker pull quay.io/oceanbase/oceanbase-ce |
|
| 221 | +docker run -p 2881:2881 --name oceanbase \ |
|
| 222 | + -e MODE=MINI -e OB_TENANT_PASSWORD=****** \ |
|
| 223 | + -d quay.io/oceanbase/oceanbase-ce |
|
| 1825 | 224 | ``` |
| 1826 | 225 | |
| 226 | +连接: |
|
| 227 | +`obclient -uroot@sys -h127.0.0.1 -P2881 -p` |
|
| 1827 | 228 | |
| 229 | +### 4. 本地 JDBC 配置(OceanBase) |
|
| 1828 | 230 | |
| 1829 | -#### 3. ERROR: INSERT/UPDATE/DELETE/MERGE contains multiple remote queries under GTM-free mode |
|
| 1830 | - |
|
| 1831 | -``` |
|
| 1832 | --数据源:main,执行SQL失败:INSERT INTO ui_file_seed (`bucket`, `path`, `file_archive_path`, `name`, `attachment_id` , `download_path`, `id`, `create_user`, `create_date`, `app_id` , `url`, `md5`) SELECT 'apps' , '/file/document/doc/定制权限-导入模板.xlsx' , 'BOOT-INF/classes/com/sie/app/tenant/file/document/doc/定制权限-导入模板.xlsx', '下载定制权限导入模板', '04pebasn0auvo' , '/apps/2025-03-20/619344493502774957.xlsx' , 'sie-snest-tenant.master.custom_permission_import_template', 'rbac_user_superuser' , '2025-03-20 17:40:54.917', '04peack6huebq' , '/fileSystem/apps/2025-03-20/619344493502774957.xlsx' , '38ea78b3e59ef8cfbfa77ada296a71a0' FROM dual WHERE NOT EXISTS ( SELECT 1 FROM ui_file_seed WHERE id = 'sie-snest-tenant.master.custom_permission_import_template' ),异常信息:[2.0.0.1:55959/192.168.96.11:8000] ERROR: INSERT/UPDATE/DELETE/MERGE contains multiple remote queries under GTM-free mode |
|
| 1833 | - 建议:modify your SQL to generate light-proxy or fast-query-shipping plan |
|
| 1834 | - |
|
| 231 | +```properties |
|
| 232 | +########OceanBase######## |
|
| 233 | +driverClassName=com.mysql.cj.jdbc.Driver |
|
| 234 | +url=jdbc:mysql://xxx.xxx.xxx.xxx:2881/snest?rewriteBatchedStatements=TRUE&allowMultiQueries=TRUE&useLocalSessionState=TRUE&characterEncoding=utf-8&socketTimeout=10000&connectTimeout=30000&zeroDateTimeBehavior=convertToNull&allowPublicKeyRetrieval=true |
|
| 235 | +username=root |
|
| 236 | +password=****** |
|
| 237 | +validationQuery=SELECT 1 |
|
| 1835 | 238 | ``` |
| 1836 | 239 | |
| 1837 | -**问题分析** |
|
| 1838 | - |
|
| 1839 | -- **GTM-free 模式**:在这种模式下,GaussDB 对分布式事务的管理方式有所限制,尤其是对涉及多个远程节点(如跨节点的子查询)的复杂查询支持较弱。 |
|
| 1840 | -- **错误原因**:你的 SQL 语句中使用了 `INSERT ... SELECT ... WHERE NOT EXISTS`,这种结构会被解析为多个远程查询,导致 GTM-free 模式下无法执行。 |
|
| 1841 | -- **参考**: https://support.huaweicloud.com/distributed-devg-v2-gaussdb/gaussdb-12-1095.html |
|
| 1842 | - |
|
| 1843 | -解决方案 |
|
| 1844 | - |
|
| 1845 | -根据错误信息中的建议,你需要修改 SQL,使其生成 **light-proxy** 或 **fast-query-shipping** 计划。 |
|
| 1846 | - |
|
| 1847 | - |
|
| 1848 | - |
|
| 1849 | -#### 4. INSERT ... SELECT ... WHERE NOT EXISTS 不支持, INSERT INTO IGNORE不支持, 改为INSERT INTO " + sql +" ON DUPLICATE KEY UPDATE NOTHING |
|
| 1850 | - |
|
| 1851 | -#### 5. 不支持修改分布式列的字段,比如修改主键的长度. |
|
| 1852 | - |
|
| 1853 | -#### 6. 事物回滚机制和MySQL不同,事物机制和PostgreSQL一致. |
|
| 1854 | - |
|
| 1855 | - |
|
| 1856 | - |
|
| 1857 | -### 4. 用户指南 |
|
| 1858 | - |
|
| 1859 | -数据库管理员应具备以下能力:拥有极强的数据库技术理解能力;能够安装数据库、执行相关操作并排除故障;能够进行云数据库GaussDB管理平台(TPOPS)的日常维护。 |
|
| 1860 | - |
|
| 1861 | -工程师应具备以下能力:了解数据库技术常识;能够执行数据库相关的操作并排除故障。 |
|
| 1862 | - |
|
| 1863 | -请参考:https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.7.30.10/usermanual/qlh_02_0001.html |
|
| 1864 | - |
|
| 1865 | - |
|
| 1866 | - |
|
| 1867 | -### 5. 数据库基本概念 |
|
| 1868 | - |
|
| 1869 | -**数据库(Database)** |
|
| 1870 | - |
|
| 1871 | -数据库是存储在一起的相关数据的集合,这些数据可以被访问,管理以及更新。 |
|
| 1872 | - |
|
| 1873 | -数据库用于管理各类数据对象,与其他数据库隔离。创建数据对象时可以指定对应的表空间,如果不指定相应的表空间,相关的对象会默认保存在PG_DEFAULT空间中。数据库管理的对象可分布在多个表空间上。 |
|
| 1874 | - |
|
| 1875 | -**数据块(Block)** |
|
| 1876 | - |
|
| 1877 | -数据块是数据库管理的基本单位,默认大小为8KB。 |
|
| 1878 | - |
|
| 1879 | -**行(Row)** |
|
| 1880 | - |
|
| 1881 | -一行(元组,或记录)是一组相关的数据,例如一条用户订阅的数据。 |
|
| 1882 | - |
|
| 1883 | -**列(Cloumn)** |
|
| 1884 | - |
|
| 1885 | -每一列被当作是一个字段。每个字段中的值代表一种类型的数据。例如,一个表可能有3个字段,姓名、城市和国家。这个表就会有3列,一列代表姓名,一列代表城市,一列代表国家。表中的每一行包含3个字段的内容,姓名字段包含姓名,城市字段包含城市,国家字段包含国家。 |
|
| 1886 | - |
|
| 1887 | -**表(Table)** |
|
| 1888 | - |
|
| 1889 | -表是由行与列组合成的,是数据库中用来存储数据的对象,是整个数据库系统的基础。 |
|
| 1890 | - |
|
| 1891 | -每张表只能属于一个数据库,也只能对应到一个表空间。每张表对应的数据文件必须在同一个表空间中。 |
|
| 1892 | - |
|
| 1893 | -**数据文件(Datafile Segment)** |
|
| 1894 | - |
|
| 1895 | -通常每张表只对应一个数据文件。如果某张表的数据大于1GB,则会分为多个数据文件存储。 |
|
| 1896 | - |
|
| 1897 | -**表空间(Tablespace)** |
|
| 1898 | - |
|
| 1899 | -在Gauss中,表空间是一个目录,在物理数据和逻辑数据间提供了抽象的一层,为所有的数据库对象分配存储空间,里面存储的是它所包含的数据库的各种物理文件。由于表空间是一个目录,仅是起到了物理隔离的作用,其管理功能依赖于文件系统。 |
|
| 1900 | - |
|
| 1901 | -表空间可以存在多个,创建好之后,创建数据库对象时可以指定该对象所属的表空间。 |
|
| 1902 | - |
|
| 1903 | -**模式(Schema)** |
|
| 1904 | - |
|
| 1905 | -**数据库对象集,包括逻辑结构,例如表、视图、序、存储过程、同义名、索引及数据库链接。** |
|
| 1906 | - |
|
| 1907 | -**事务(Transaction)** |
|
| 1908 | - |
|
| 1909 | -数据库管理系统执行过程中的一个逻辑单位,由一个有限的数据库操作序列构成。在关系数据库中,一个事务可以是一条SQL语句,一组SQL语句或整个程序。 |
|
| 1910 | - |
|
| 1911 | -同时,事务也是恢复和并发控制的基本单位,必须具备ACID特性,即: |
|
| 1912 | - |
|
| 1913 | -- 原子性(Atomicity):一个事务是一个不可分割的工作单位,事务中包括的操作要么都做,要么都不做。 |
|
| 1914 | -- 一致性(Consistency):事务必须是使数据库从一个一致性状态变到另一个一致性状态。一致性与原子性是密切相关的。 |
|
| 1915 | -- 隔离性(Isolation):一个事务的执行不能被其他事务干扰。即一个事务内部的操作及使用的数据对并发的其他事务是隔离的,并发执行的各个事务之间不能互相干扰。 |
|
| 1916 | -- 持久性(Durability):持久性也称永久性(Permanence),指一个事务一旦提交,它对数据库中数据的改变就应该是永久性的。接下来的其他操作或故障不应该对其有任何影响。 |
|
| 1917 | - |
|
| 1918 | -请参考: https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.7.30.10/devg-dist/gaussdb-12-0002.html |
|
| 1919 | - |
|
| 1920 | - |
|
| 1921 | - |
|
| 1922 | -### 6. 分布式开发指南 |
|
| 1923 | - |
|
| 1924 | -请参考文档:https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0078.html |
|
| 1925 | - |
|
| 1926 | -##### 6.1 数据库系统概述 |
|
| 1927 | - |
|
| 1928 | -- **[数据库逻辑结构图](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0012.html)** |
|
| 1929 | -- **[数据查询请求处理过程](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0013.html)** |
|
| 1930 | -- **[管理事务](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0014.html)** |
|
| 1931 | - |
|
| 1932 | - |
|
| 1933 | - |
|
| 1934 | -##### 6.2 数据库安全 |
|
| 1935 | - |
|
| 1936 | -- **[用户及权限](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0017.html)** |
|
| 1937 | -- **[数据库审计](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0026.html)** |
|
| 1938 | - |
|
| 1939 | - |
|
| 1940 | - |
|
| 1941 | -##### 6.3 操作数据库 |
|
| 1942 | - |
|
| 1943 | -本节描述使用数据库的基本操作。通过此节您可以完成创建数据库用户、创建数据库、创建表及向表中插入数据和查询表中数据等操作。 |
|
| 1944 | - |
|
| 1945 | -- **[创建数据库用户](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0032.html)** |
|
| 1946 | -- **[管理数据库](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0033.html)** |
|
| 1947 | -- **[管理表空间](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0034.html)** |
|
| 1948 | -- **[管理表](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0035.html)** |
|
| 1949 | -- **[查看系统表](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0041.html)** |
|
| 1950 | -- **[其他操作](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0042.html)** |
|
| 1951 | - |
|
| 1952 | - |
|
| 240 | +--- |
|
| 1953 | 241 | |
| 1954 | -##### 6.5 数据库设计规范 |
|
| 242 | +## 五、GaussDB 参考手册 |
|
| 1955 | 243 | |
| 1956 | -- **[基本规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0052.html)** |
|
| 1957 | -- **[部署规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0053.html)** |
|
| 1958 | -- **[数据库对象命名规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0054.html)** |
|
| 1959 | -- **[Database和Schema设计规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0055.html)** |
|
| 1960 | -- **[权限设计规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0056.html)** |
|
| 1961 | -- **[字符集设计规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0057.html)** |
|
| 1962 | -- **[表设计规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0058.html)** |
|
| 1963 | -- **[字段设计规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0059.html)** |
|
| 1964 | -- **[索引设计规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0060.html)** |
|
| 1965 | -- **[函数/存储过程设计规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0061.html)** |
|
| 1966 | -- **[约束设计](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0062.html)** |
|
| 1967 | -- **[视图和关联表设计](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0063.html)** |
|
| 244 | +### 1. 产品概述 |
|
| 1968 | 245 | |
| 246 | +- 华为云企业级分布式数据库,支持集中式与分布式两种部署 |
|
| 247 | +- IIDP 仅支持 **MySQL 兼容模式**(`dbcompatibility=MYSQL`) |
|
| 1969 | 248 | |
| 249 | +### 2. 部署方案 |
|
| 1970 | 250 | |
| 1971 | -##### 6.6 应用程序开发教程 |
|
| 251 | +- [分布式版](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/productdesc/gaussdb_01_060.html) |
|
| 252 | +- [集中式版](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/productdesc/gaussdb_01_061.html) |
|
| 1972 | 253 | |
| 1973 | -- **[GaussDB应用程序开发教程概述](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0079.html)** |
|
| 1974 | -- **[开发规范](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0080.html)** |
|
| 1975 | -- **[基于JDBC开发](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0081.html)** |
|
| 254 | +### 3. 兼容性说明 |
|
| 1976 | 255 | |
| 1977 | -**本地JDBC配置:** |
|
| 256 | +| 部署方式 | 兼容模式 | |
|
| 257 | +| -------- | -------------------------------------- | |
|
| 258 | +| 集中式 | A=Oracle,B=MySQL,PG=PostgreSQL | |
|
| 259 | +| 分布式 | ORA=Oracle,MYSQL=MySQL,PG=PostgreSQL | |
|
| 1978 | 260 | |
| 1979 | -**1. dbcp.properties 示例:** |
|
| 261 | +查看兼容性: |
|
| 1980 | 262 | |
| 263 | +```sql |
|
| 264 | +SELECT datname, datcompatibility FROM pg_database; |
|
| 1981 | 265 | ``` |
| 1982 | -########DBCP########## |
|
| 1983 | -initialSize=5 |
|
| 1984 | -maxActive=2000 |
|
| 1985 | -minIdle=5 |
|
| 1986 | -filters=stat |
|
| 1987 | -maxWait=6000 |
|
| 1988 | -timeBetweenEvictionRunsMillis=60000 |
|
| 1989 | -minEvictableIdleTimeMillis=1800000 |
|
| 1990 | -testOnBorrow=false |
|
| 1991 | -testOnReturn=false |
|
| 1992 | -testWhileIdle=true |
|
| 1993 | -poolPreparedStatements: true |
|
| 1994 | -maxOpenPreparedStatements: 20 |
|
| 1995 | -connectionProperties:druid.stat.sql.MaxSize=100; |
|
| 1996 | -keepAlive=true |
|
| 1997 | 266 | |
| 267 | +### 4. 本地 JDBC 配置 |
|
| 1998 | 268 | |
| 269 | +```properties |
|
| 1999 | 270 | ########gaussdb######## |
| 2000 | 271 | driverClassName=com.huawei.gaussdb.jdbc.Driver |
| 2001 | 272 | url=jdbc:gaussdb://127.0.0.1:8000,127.0.0.1:8000,127.0.0.1:8000/tpcc?currentSchema=snest_jichen&autoBalance=true&refreshCNIpListTime=3&prepareThreshold=1&batchMode=on&fetchsize=10&loggerLevel=OFF |
| ... | ... | @@ -2005,325 +276,91 @@ validationQuery=SELECT 1 |
| 2005 | 276 | gaussdbDeployment=Distributed |
| 2006 | 277 | ``` |
| 2007 | 278 | |
| 2008 | -**2. spring配置文件添加参数适配高斯自定义SQL列字段别名转换** |
|
| 2009 | - |
|
| 2010 | -正常不需要添加这个配置,除非项目特殊需要. |
|
| 2011 | - |
|
| 2012 | -application-dev.properties添加: |
|
| 2013 | - |
|
| 2014 | -``` |
|
| 2015 | -orm.sql.wrap_camelcase_alias=true |
|
| 2016 | -``` |
|
| 2017 | - |
|
| 2018 | - |
|
| 2019 | - |
|
| 2020 | - |
|
| 2021 | - |
|
| 2022 | -##### 6.7 SQL调优指南 |
|
| 2023 | - |
|
| 2024 | -SQL调优的唯一目的是“资源利用最大化”,即CPU、内存、磁盘I/O、网络IO四种资源利用最大化。所有调优手段都是围绕资源使用开展的。所谓资源利用最大化是指SQL语句尽量高效,节省资源开销,以最小的代价实现最大的效益。比如做典型点查询的时候,可以用seqscan+filter(即读取每一条元组和点查询条件进行匹配)实现,也可以通过indexscan实现,显然indexscan可以以更小的代价实现相同的效果。 |
|
| 2025 | - |
|
| 2026 | -- **[Query执行流程](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0320.html)** |
|
| 2027 | -- **[SQL执行计划介绍](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0321.html)** |
|
| 2028 | -- **[调优流程](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0327.html)** |
|
| 2029 | -- **[更新统计信息](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0328.html)** |
|
| 2030 | -- **[审视和修改表定义](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0329.html)** |
|
| 2031 | -- **[典型SQL调优点](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0335.html)** |
|
| 2032 | -- **[经验总结:SQL语句改写规则](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0343.html)** |
|
| 2033 | -- **[SQL调优关键参数调整](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0344.html)** |
|
| 2034 | -- **[使用Plan Hint进行调优](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0345.html)** |
|
| 2035 | -- **[检查隐式转换的性能问题](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0377.html)** |
|
| 2036 | -- **[使用向量化执行引擎进行调优](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0378.html)** |
|
| 2037 | -- **[使用SQL PATCH进行调优](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0379.html)** |
|
| 2038 | -- **[实际调优案例](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0380.html)** |
|
| 2039 | - |
|
| 2040 | - |
|
| 2041 | - |
|
| 2042 | -##### 6.8 SQL参考 |
|
| 2043 | - |
|
| 2044 | -- **[GaussDB SQL](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0394.html)** |
|
| 2045 | -- **[关键字](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0395.html)** |
|
| 2046 | -- **[数据类型](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0396.html)** |
|
| 2047 | -- **[字符集与字符序](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0420.html)** |
|
| 2048 | -- **[常量与宏](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0428.html)** |
|
| 2049 | -- **[函数和操作符](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0429.html)** |
|
| 2050 | -- **[表达式](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0505.html)** |
|
| 2051 | -- **[伪列](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0512.html)** |
|
| 2052 | -- **[类型转换](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0513.html)** |
|
| 2053 | -- **[系统操作](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0519.html)** |
|
| 2054 | -- **[事务控制](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0520.html)** |
|
| 2055 | -- **[全文检索](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0521.html)** |
|
| 2056 | -- **[SQL语法](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0556.html)** |
|
| 2057 | -- **[附录](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0791.html)** |
|
| 2058 | - |
|
| 2059 | - |
|
| 2060 | - |
|
| 2061 | -##### 6.9 最佳实践 |
|
| 2062 | - |
|
| 2063 | -- **[SQL查询最佳实践](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0798.html)** |
|
| 2064 | -- **[权限配置最佳实践](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0799.html)** |
|
| 2065 | -- **[数据倾斜查询最佳实践](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0800.html)** |
|
| 2066 | -- **[存储过程最佳实践](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/25.1.30/devg-dist/gaussdb-12-0835.html)** |
|
| 2067 | - |
|
| 2068 | - |
|
| 2069 | - |
|
| 2070 | -##### 6.10 工具指南 |
|
| 2071 | - |
|
| 2072 | -[用DBeaver客户端连接高斯数据库](http://192.168.175.198:10001/iidpwiki/%E7%94%A8DBeaver%E5%AE%A2%E6%88%B7%E7%AB%AF%E8%BF%9E%E6%8E%A5%E9%AB%98%E6%96%AF%E6%95%B0%E6%8D%AE%E5%BA%93.md) |
|
| 2073 | - |
|
| 2074 | - |
|
| 2075 | -**分布式工具指南** |
|
| 2076 | - |
|
| 2077 | -1. **工具介绍**:GaussDB 提供了多种工具支持分布式开发,如 GaussDB 数据库管理工具、备份工具等。 |
|
| 2078 | -2. **使用方法**:参考 [GaussDB 分布式工具指南](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/toolguide/gaussdb_03_0100.html) 获取工具的使用方法和示例。 |
|
| 2079 | - |
|
| 2080 | -**集中式工具指南** |
|
| 2081 | - |
|
| 2082 | -1. **工具介绍**:GaussDB 提供了多种工具支持集中式开发,如 GaussDB 数据库管理工具、性能监控工具等。 |
|
| 2083 | -2. **使用方法**:参考 [GaussDB 集中式工具指南](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/toolguide/gaussdb_03_0200.html) 获取工具的使用方法和示例。 |
|
| 2084 | - |
|
| 2085 | - |
|
| 2086 | - |
|
| 2087 | -### 7. 特性描述 |
|
| 2088 | - |
|
| 2089 | -#### 7.1 分布式特性描述 |
|
| 2090 | - |
|
| 2091 | -- **弹性扩展**:支持水平扩展,可根据业务需求动态调整实例数量。 |
|
| 2092 | -- **高可用性**:支持多副本存储和自动故障切换,确保数据的高可用性。 |
|
| 2093 | -- **高性能**:采用分布式架构,提供高性能处理能力。 |
|
| 2094 | - |
|
| 2095 | -#### 7.2 集中式特性描述 |
|
| 2096 | - |
|
| 2097 | -- **性能优化**:针对集中式场景进行优化,提供高性能处理能力。 |
|
| 2098 | -- **数据安全**:支持数据加密、访问控制等安全功能。 |
|
| 2099 | -- **易用性**:提供简单的管理界面和操作方式。 |
|
| 2100 | - |
|
| 2101 | - |
|
| 2102 | - |
|
| 2103 | -### 8. 常见问题 |
|
| 2104 | - |
|
| 2105 | -#### 8.1 性能问题 |
|
| 2106 | - |
|
| 2107 | -- **Q:如何优化 GaussDB 的性能?** |
|
| 2108 | - - A:可以通过调整数据库参数、优化 SQL 查询、增加实例规格等方式提升性能。具体优化方法请参考 [性能优化指南](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/bestpractice/gaussdb_04_0100.html)。 |
|
| 2109 | - |
|
| 2110 | -#### 8.2 安全问题 |
|
| 2111 | - |
|
| 2112 | -- **Q:如何确保 GaussDB 的数据安全?** |
|
| 2113 | - |
|
| 2114 | - - A:可以通过设置访问控制、数据加密、备份与恢复等方式确保数据安全。具体安全措施请参考 [安全指南](https://doc.hcs.huawei.com/db/zh-cn/gaussdb/24.7.30.10/security/gaussdb_05_0100.html)。 |
|
| 2115 | - |
|
| 2116 | - |
|
| 2117 | - |
|
| 2118 | -### 9. 资源链接 |
|
| 2119 | - |
|
| 2120 | -- [官方文档中心](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.7.30.10/productdesc/qlh_03_0001.html) |
|
| 2121 | - |
|
| 2122 | -- [分布式版MySQL兼容性说明](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.7.30.10/compatibility-description/gaussdb_01_0003.html) |
|
| 2123 | - |
|
| 2124 | -- [SQL参考](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.7.30.10/devg-dist/gaussdb-12-0320.html) |
|
| 2125 | - |
|
| 2126 | -- [M-Compatibility数据库系统概述](https://doc.hcs.huawei.com/db/zh-cn/gaussdbqlh/24.7.30.10/m_comp_devg-dist/gaussdb-81-0001.html) |
|
| 2127 | - |
|
| 2128 | - |
|
| 2129 | -## 六 Vastbase G100 参考手册 |
|
| 2130 | - |
|
| 2131 | - |
|
| 2132 | -Vastbase 海量数据库基本上兼容Postgres SQL,所以SQL语法和Postgres一样,可以直接把Vastbase作为Postgres使用. |
|
| 2133 | - |
|
| 2134 | -SQL语法可以直接参考: [PostgreSQL 特性](/iidpwiki/PostgreSQL.md#第二节-postgresql-特性) |
|
| 2135 | - |
|
| 2136 | - |
|
| 2137 | -### 1.参考指南 |
|
| 2138 | - |
|
| 2139 | -[https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/6fffc868878a49e3902ba0a6f68d087e](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/6fffc868878a49e3902ba0a6f68d087e) |
|
| 2140 | - |
|
| 2141 | - |
|
| 2142 | -### 2. [SQL语法参考](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/65ccc3f66f1a413eb169bb5f514e5e83) |
|
| 2143 | - |
|
| 2144 | -[https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/65ccc3f66f1a413eb169bb5f514e5e83](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/65ccc3f66f1a413eb169bb5f514e5e83) |
|
| 2145 | - |
|
| 2146 | - |
|
| 2147 | - |
|
| 2148 | -### 3.兼容性手册 |
|
| 2149 | - |
|
| 2150 | -[https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/5fda827143144783b9958728321c467c](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/5fda827143144783b9958728321c467c) |
|
| 2151 | - |
|
| 2152 | - |
|
| 2153 | -### 4.MySQL兼容性 |
|
| 2154 | - |
|
| 2155 | -[https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/9363aeb3a4264c468b93079db61cdf6e](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/9363aeb3a4264c468b93079db61cdf6e) |
|
| 2156 | - |
|
| 2157 | - |
|
| 2158 | -### 5.JAVA语言应用开发 |
|
| 2159 | - |
|
| 2160 | -[https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/e4b9ce00d5244d4786dcd26a20508f57](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/e4b9ce00d5244d4786dcd26a20508f57) |
|
| 2161 | - |
|
| 2162 | - |
|
| 2163 | -### 6.快速入门 |
|
| 2164 | - |
|
| 2165 | -[https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/0095ee60bd934df9b7a0fcafdf9b5361](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/0095ee60bd934df9b7a0fcafdf9b5361) |
|
| 2166 | - |
|
| 2167 | - |
|
| 2168 | - |
|
| 2169 | -本章节对 Vastbase G100 进行了简单的产品介绍以及安装和使用指导,帮助用户快速上手使用。 |
|
| 2170 | - |
|
| 2171 | -若用户希望了解更多 Vastbase G100 的详细特性以及参考信息,请查阅具体的文档。例如,《安装升级指南》提供了有关安装要求和过程的完整信息,《开发者指南》为基于 Vastbase G100 进行C/Java应用程序开发的程序员提供了必要的参考信息,《管理员指南》介绍了 Vastbase G100 数据库常用的管理员操作,方便管理员阅读参考。 |
|
| 2172 | - |
|
| 2173 | -- 产品概述 |
|
| 2174 | -- 新手指引 |
|
| 2175 | -- 安装数据库 |
|
| 2176 | -- 升级说明 |
|
| 2177 | -- 初始化数据库 |
|
| 2178 | -- 启停数据库 |
|
| 2179 | -- 使用数据库 |
|
| 279 | +### 5. 不兼容项速览 |
|
| 2180 | 280 | |
| 281 | +1. 唯一索引/复合唯一索引需包含分布列,否则报错 |
|
| 282 | +2. `INSERT ... SELECT ... WHERE NOT EXISTS` 在 GTM-free 模式不支持 |
|
| 283 | +3. 分布式列值不允许 UPDATE |
|
| 284 | +4. 事务回滚行为与 PostgreSQL 一致(语句级回滚) |
|
| 2181 | 285 | |
| 286 | +--- |
|
| 2182 | 287 | |
| 2183 | -### 6.管理员指南/数据库使用 |
|
| 288 | +## 六、Vastbase G100 参考手册 |
|
| 2184 | 289 | |
| 2185 | -本章节介绍使用数据库的相关操作,帮助使用本手册的管理员获取到使用和管理数据库的相关信息。包括如下内容: |
|
| 290 | +Vastbase G100 与 PostgreSQL 语法基本一致,可直接参考本文“PostgreSQL 特性”章节。 |
|
| 2186 | 291 | |
| 2187 | -- 从这里开始 |
|
| 2188 | -- 创建和管理分区表 |
|
| 2189 | -- 创建和管理视图 |
|
| 2190 | -- 启停Vastbase |
|
| 2191 | -- 状态查询 |
|
| 2192 | -- 连接数据库 |
|
| 2193 | -- 创建和管理数据库 |
|
| 2194 | -- 规划存储模型 |
|
| 2195 | -- 创建和管理表空间 |
|
| 2196 | -- 创建和管理表 |
|
| 2197 | -- 查看系统表 |
|
| 2198 | -- 触发器 |
|
| 2199 | -- 查询缓存 |
|
| 2200 | -- 其它操作 |
|
| 292 | +- 官方文档:[Vastbase G100 文档中心](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/6fffc868878a49e3902ba0a6f68d087e) |
|
| 293 | +- Docker 安装: |
|
| 2201 | 294 | |
| 2202 | -### 7.Docker 单机镜像安装 |
|
| 295 | +```bash |
|
| 296 | +docker run -d --name vastbase \ |
|
| 297 | + -e VB_USERNAME=vastbase \ |
|
| 298 | + -e VB_DBCOMPATIBILITY=PG \ |
|
| 299 | + -p 5432:5432 \ |
|
| 300 | + vastbase:v2.2.15 |
|
| 301 | +``` |
|
| 2203 | 302 | |
| 2204 | -[https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/d9d69078b93448bbb219ec6407c4c0f2](https://docs.vastdata.com.cn/zh_CN/VastbaseG100/V2.2.15/1/d9d69078b93448bbb219ec6407c4c0f2) |
|
| 303 | +### 本地 dbcp.properties 配置 |
|
| 2205 | 304 | |
| 305 | +#### 默认兼容模式(PostgreSQL) |
|
| 2206 | 306 | |
| 307 | +```properties |
|
| 308 | +########DBCP########## |
|
| 309 | +driverClassName=cn.com.vastbase.Driver |
|
| 310 | +url=jdbc:vastbase://ip:25432/snest_jichen?currentSchema=snest_changwen |
|
| 311 | +username=snest_jichen |
|
| 312 | +password=****** |
|
| 313 | +``` |
|
| 2207 | 314 | |
| 2208 | -| **参数名称** | **含义** | |
|
| 2209 | -| --------------------- | ------------------------------------------------------------ | |
|
| 2210 | -| -e VB_USERNAME | 自动创建用户名称,和初始用户共享密码。 | |
|
| 2211 | -| -e VB_DBCOMPATIBILITY | 指定数据库初始化兼容模式,取值范围:A、B、C、PG、MSSQL。分别表示兼容Oracle、MySQL、PostgreSQL、SQL Server。 | |
|
| 2212 | -| –name | 运行容器名称。 | |
|
| 315 | +#### MySQL 兼容模式 |
|
| 2213 | 316 | |
| 317 | +```properties |
|
| 318 | +########DBCP########## |
|
| 319 | +driverClassName=cn.com.vastbase.Driver |
|
| 320 | +url=jdbc:vastbase://ip:25434/snest_tpcc?currentSchema=snest_changwen&db_compatibility=mysql |
|
| 321 | +username=snest_changwen |
|
| 322 | +password=****** |
|
| 323 | +dbCompatibility=mysql |
|
| 324 | +``` |
|
| 2214 | 325 | |
| 2215 | -## 七 Dameng(国产达梦数据库) 参考手册 |
|
| 326 | +--- |
|
| 2216 | 327 | |
| 2217 | -#### 1.数据库版本:DM8 |
|
| 328 | +## 七、Dameng 参考手册 |
|
| 2218 | 329 | |
| 2219 | -#### 2.Docker安装 |
|
| 2220 | -参考:https://eco.dameng.com/document/dm/zh-cn/start/dm-install-docker.html |
|
| 2221 | -安装前准备 |
|
| 2222 | -| **软硬件** | **版本** | |
|
| 2223 | -| --------------------- | ------------------------------------------------------------ | |
|
| 2224 | -| 终端 | X86-64 架构 | |
|
| 2225 | -| Docker | 2023 年 6 月版 | |
|
| 330 | +### 1. 版本:DM8 |
|
| 2226 | 331 | |
| 332 | +### 2. Docker 安装 |
|
| 2227 | 333 | |
| 2228 | -**下载 Docker 安装包** |
|
| 2229 | -请在达梦数据库官网下载 https://eco.dameng.com/download/ 。 |
|
| 2230 | -导入安装包 |
|
| 2231 | -拷贝安装包到 /opt 目录下,执行以下命令导入安装包: |
|
| 334 | +```bash |
|
| 2232 | 335 | docker load -i dm8_20230808_rev197096_x86_rh6_64_single.tar |
| 2233 | -结果显示如下: |
|
| 2234 | -导入完成后,可以使用 docker images 查看导入的镜像。 |
|
| 2235 | - |
|
| 2236 | -启动容器 |
|
| 2237 | -镜像导入后,使用 docker run 启动容器,启动命令如下: |
|
| 2238 | -docker run -d -p 30236:5236 --restart=always --name dm8_test --privileged=true -e PAGE_SIZE=16 -e LD_LIBRARY_PATH=/opt/dmdbms/bin -e EXTENT_SIZE=32 -e BLANK_PAD_MODE=1 -e LOG_SIZE=1024 -e UNICODE_FLAG=1 -e LENGTH_IN_CHAR=1 -e INSTANCE_NAME=dm8_test -v /data/dm8_test:/opt/dmdbms/data dm8_single:dm8_20230808_rev197096_x86_rh6_64 |
|
| 2239 | -注:挂载的磁盘/data/dm8_test要足够大,否则会启动失败。 |
|
| 2240 | - |
|
| 2241 | -容器启动完成后,使用 docker ps 查看镜像的启动情况,结果显示如下: |
|
| 2242 | -启动完成后,可通过日志检查启动情况,命令如下: |
|
| 2243 | -docker logs -f dm8_test |
|
| 2244 | -或 |
|
| 2245 | -docker logs -f 58deb28d1209 |
|
| 2246 | - |
|
| 2247 | -启动/停止数据库 |
|
| 2248 | -停止数据库命令如下: |
|
| 2249 | -docker stop dm8_test |
|
| 2250 | - |
|
| 2251 | -启动数据库命令如下: |
|
| 2252 | -docker start dm8_test |
|
| 2253 | - |
|
| 2254 | -重启命令如下: |
|
| 2255 | -docker restart dm8_test |
|
| 2256 | - |
|
| 2257 | -注意1.如果使用 docker 容器里面的 disql,进入容器后,先执行 source /etc/profile 防止中文乱码。 |
|
| 2258 | -##### 2.新版本 Docker 镜像中数据库默认用户名/密码为 SYSDBA/SYSDBA001。 |
|
| 2259 | - |
|
| 2260 | - |
|
| 2261 | -### 测试环境安装位置: |
|
| 2262 | -数据库连接信息: |
|
| 2263 | -服务器:192.168.175.193 |
|
| 2264 | - docker 镜像:dm8_test |
|
| 2265 | - |
|
| 2266 | - |
|
| 2267 | - |
|
| 2268 | -#### 3.安装DM 管理工具 |
|
| 2269 | -参考文档:https://eco.dameng.com/document/dm/zh-cn/start/tool-dm-manager.html |
|
| 2270 | - |
|
| 2271 | -#### 1.先去https://eco.dameng.com/download/?_blank 下载 windows DM8 |
|
| 2272 | - |
|
| 2273 | -#### 2.安装的时候如果不需要安装数据库,只勾选DM 管理工具 |
|
| 2274 | - |
|
| 2275 | -#### 4.测试连接DM数据库 |
|
| 2276 | -参考链接:https://eco.dameng.com/document/dm/zh-cn/start/tool-dm-manager.html |
|
| 2277 | - |
|
| 2278 | -数据库连接信息: |
|
| 2279 | -192.168.175.193:30236 |
|
| 2280 | -SYSDBA/SYSDBA001 |
|
| 336 | +docker run -d -p 30236:5236 --name dm8_test \ |
|
| 337 | + -e PAGE_SIZE=16 -e LD_LIBRARY_PATH=/opt/dmdbms/bin \ |
|
| 338 | + -e EXTENT_SIZE=32 -e BLANK_PAD_MODE=1 \ |
|
| 339 | + -e LOG_SIZE=1024 -e UNICODE_FLAG=1 -e LENGTH_IN_CHAR=1 \ |
|
| 340 | + -v /data/dm8_test:/opt/dmdbms/data \ |
|
| 341 | + dm8_single:dm8_20230808_rev197096_x86_rh6_64 |
|
| 342 | +``` |
|
| 2281 | 343 | |
| 344 | +默认用户名/密码:`SYSDBA` / `SYSDBA001` |
|
| 2282 | 345 | |
| 346 | +### 3. Maven 依赖 |
|
| 2283 | 347 | |
| 2284 | -#### 5.DM添加数据库驱动包,添加maven依赖 |
|
| 2285 | -添加Maven依赖(DmJdbcDriver18已经上传到maven仓库) |
|
| 2286 | - ``` |
|
| 2287 | - <dependency> |
|
| 2288 | - <groupId>com.dameng</groupId> |
|
| 2289 | - <artifactId> </artifactId> |
|
| 2290 | - <version>8.1.3.111</version> |
|
| 2291 | - </dependency> |
|
| 348 | +```xml |
|
| 349 | +<dependency> |
|
| 350 | + <groupId>com.dameng</groupId> |
|
| 351 | + <artifactId>DmJdbcDriver18</artifactId> |
|
| 352 | + <version>8.1.3.111</version> |
|
| 353 | +</dependency> |
|
| 2292 | 354 | ``` |
| 2293 | 355 | |
| 356 | +### 4. 本地 dbcp.properties 配置 |
|
| 2294 | 357 | |
| 2295 | - 配置数据库连接信息 |
|
| 2296 | -在 dbcp.properties 配置连接信息如下: |
|
| 2297 | - |
|
| 2298 | -``` |
|
| 358 | +```properties |
|
| 2299 | 359 | ########dameng########## |
| 2300 | 360 | driverClassName=dm.jdbc.driver.DmDriver |
| 2301 | -url=jdbc:dm://192.168.175.193:30236/IIDP_DEMO |
|
| 2302 | -username=SYSDBA |
|
| 2303 | -password=SYSDBA001 |
|
| 2304 | -``` |
|
| 2305 | - |
|
| 2306 | - |
|
| 2307 | - |
|
| 2308 | -#### 6.DM数据库兼容性测试 |
|
| 2309 | - |
|
| 2310 | -##### 6.1 修改 dbcp.properties 配置连接信息如下: |
|
| 2311 | -``` |
|
| 2312 | -########dameng########## |
|
| 2313 | -driverClassName=dm.jdbc.driver.DmDriver |
|
| 2314 | -url=jdbc:dm://192.168.175.193:30236/SNEST_TEST |
|
| 361 | +url=jdbc:dm://192.168.175.193:30236/SNEST_TEST |
|
| 2315 | 362 | username=SNEST_TEST |
| 2316 | 363 | password=SNEST_TEST#123 |
| 2317 | 364 | ``` |
| 2318 | -使用dbwaver客户端连接,连接方式选择ODBC,编辑ODBC模板 |
|
| 2319 | -dm.jdbc.driver.DmDriver |
|
| 2320 | -jdbc:dm://192.168.175.193:30236/SNEST_TEST |
|
| 2321 | -添加以下库为驱动: |
|
| 2322 | - |
|
| 2323 | -https://drive.weixin.qq.com/s?k=AAIAKAcJAAcPnHMZYSAS8ATAaiAIk |
|
| 2324 | - |
|
| 2325 | - |
|
| 2326 | - |
|
| 2327 | -##### 6.2 因为DM数据库是兼容oracle的,所以测试用例和测试App 和oracle一样。 |
|
| 2328 | - |
|
| 2329 | 365 | |
| 366 | +--- |
|
| ... | ... | \ No newline at end of file |