gbase8s之建表相关问题

第一章..绪论

1.1..背景

需要对明年所有系统的表新建。

1.2..要求

对导切建表可能遇到的一些问题罗列及解决办法。

第二章..新建表的的过程

1.1..获取DDL

获取DDL一定要在服务器上去获取,千万别用gds去导出ddl。

1.1.1..切换数据库用户

su – gbasedbt

1.1.2..根据需要选取以下其中一个DDL导出方式

获取某个库的DDL

dbschema -d 库名 -ss > 库名.sql

获取某个表的的DDL

dbschema -d 库名 表名 -ss > 表名.sql

1.2..修改上面一步导出的sql文件里的DDL

总共有以下三处要改:

同一个库的表名必须唯一,需要改表名。

同一个库的约束名必须唯一,需要改主键或者唯一约束名。

同一个库的索引名必须唯一,需要改索引名称。

1.3..新建2025年所有系统的表

1.3.1..根据需要选取以下其中一个方式建表

dbaccess 库名  库名.sql

dbaccess 库名  表名.sql

第三章..测试

1.1..测试

1.1.1..拷贝到测试环境

将导出的sql文件拷贝到测试环境的/home/gbase/,

1.1.2..切换到root用户,授予sql文件777权限

su - root

chmod 777 库名.sql

chmod 777 表名.sql

1.1.3..切换到数据库用户, 根据需要选取以下其中一个方式建表

su - gbasedbt

dbaccess 库名  库名.sql

dbaccess 库名  表名.sql

第四章..实施步骤

1.1..执行建表

切换到数据库用户, 根据需要选取以下其中一个方式建表

su - gbasedbt

dbaccess 库名  库名.sql

dbaccess 库名  表名.sql

第五章..建表遇见的问题

1.1..在线修改表结构

如果有业务在访问该表,此时需要去修改表结构,会遇到如下两个问题。

1.1.1..在线表结构成功应用报错

Table (tablename) has been dropped, altered or renamed

如果遇见上面报错内容,一般只会报错一次就会恢复,如果连续报错,请重启应用

1.1.2..在线表结构修改失败

失败原因是不能独占锁资源,请用如下语句去修改

dbaccess 库名  -

SET ENVIRONMENT FORCE_DDL_EXEC "60";--强制修改表结构
SET LOCK MODE TO WAIT 60;--锁等待

alter 语句;

rename 语句;

1.2..not null 要在default表达式后面

not null不在default会建表报错

1.3..建表时候不能default ‘’ not null

因为数据库ENABLE_NULL_STRING 配置参数,启用或禁用空字符串(’’)查询时是否等同于 NULL 的功能。
1 = 启用(缺省值),空字符串(’’)等同于 NULL
0 = 禁用,空字符串(’’)不等同于 NULL

default ‘’ not null此时没问题,'一个空格' 等价于 '多个空格’,原因gbase会丢弃字符串右边大于1的空格。

ENABLE_NULL_STRING1 = 启用时候,此时null 等价于 ’’ 等价于’   ’,'一个空格' 等价于 '多个空格’,原因gbase会丢弃字符串右边大于1的空格,default ‘’ not null逻辑矛盾,建表会成功,但是insert会报错误.

完结!!!!!!!!!!!!!!!!!!!

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

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

相关文章

HTTP vs WebSocket

本文将对比介绍HTTP 和 WebSocket ! 相关文章: 1.HTTP 详解 2.WebSocket 详解 一、HTTP:请求/响应的主流协议 HTTP(超文本传输协议)是用于发送和接收网页数据的标准协议。它最早于1991年由Tim Berners-Lee提出来&…

如何查看GB28181流媒体平台LiveGBS中对GB28181实时视频数据统计的负载信息

目录 1、负载信息2、负载信息说明3、会话列表查看 3.1、会话列表4、停止会话5、搭建GB28181视频直播平台 1、负载信息 实时展示直播、回放、播放、录像、H265、级联等使用数目 2、负载信息说明 直播:当前推流到平台的实时视频数目回放:当前推流到平台的回…

OpenAI Canvas最新发布,编程和写作迎来全新史诗级加强!

文章目录 零、前言一、GPT-40 with canvas操作指导写作领域加强建议编辑调整长度阅读水平添加最后的润色添加表情 编程领域加强选中代码问问题添加评论(添加注释)添加日志转换语言代码审查 二、感受 零、前言 最新消息,国庆期间OpenAI有大动…

解放双手-Mac电脑自定义文件默认打开方式的最有效方法

你们使用Mac的过程中,文件格式是不是每次都要自己选择打开方式,文件类型太多了,默认打开方式没办法兼顾所有的文件类型,这样太麻烦了,如果收到了新文件类型的文件,每次都要弹窗选择打开方式会不会心累 试试…

QT工程概述

在Qt中,创建 "MainWindow" 与 "Widget" 项目的主要区别在于他们的用途和功能范围: MainWindow:这是一个包含完整菜单栏、工具栏和状态栏的主窗口应用程序框架。它适合于更复 杂的应用程序,需要这些额外的用户…

git删除错误的commit

文章目录 1、git删除错误的commit2、.gitignore配置文件不生效的问题 1、git删除错误的commit git的流程如图: 当某次失误造成commit的版本有问题,需要回退到正常的版本修改后重新add。 首先通过git log查看commit提交记录,可以看到HEAD-…

使用Pytorch写简单线性回归

文章目录 Pytorch一、Pytorch 介绍二、概念三、应用于简单线性回归 1.代码框架2.引用3.继续模型(1)要定义一个模型,需要继承nn.Module:(2)如果函数的参数不具体指定,那么就需要在__init__函数中添加未指定的变量: 2.定义数据3.实例…

Redis哨兵模式部署(超详细)

哨兵模式特点 主从模式的弊端就是不具备高可用性,当master挂掉以后,Redis将不能再对外提供写入操作,因此sentinel模式应运而生。sentinel中文含义为哨兵,顾名思义,它的作用就是监控redis集群的运行状况,此…

如何利用phpstudy创建mysql数据库

phpStudy诞生于2007年,是一款老牌知名的PHP开发集成环境工具,产品历经多次迭代升级,目前有phpStudy经典版、phpStudy V8(2019版)等等,利用phpstudy可以快速搭建一个mysql环境,接下来我们就开始吧…

Unity MVC框架1-2 实战分析

该课程资源来源于唐老狮,吃水不忘打井人,不胜感激 Unity MVC框架演示 1-1 理论分析-CSDN博客 首先你需要知道什么mvc框架,并且对三个层级有个比较清晰的认识,当然不清楚也好,下面例子中将会十分细心地让你理解&#x…

SpringBoot在高校竞赛平台开发中的优化策略

1系统概述 1.1 研究背景 随着计算机技术的发展以及计算机网络的逐渐普及,互联网成为人们查找信息的重要场所,二十一世纪是信息的时代,所以信息的管理显得特别重要。因此,使用计算机来管理高校学科竞赛平台的相关信息成为必然。开发…

TensorFlow详细配置

Anaconda 的安装路径配置系统环境变量 1 windows path配置 2 conda info C:\Users\Administrator>conda info active environment : None user config file : C:\Users\Administrator\.condarc populated config files : C:\Users\Administrator\.condarc …

Vue3中常用的八种组件通信方式

一、props父组件向子组件通信 父组件&#xff1a; props用于父组件向子组件传递数据&#xff0c;子组件用defineprops接收父组件传来的参数 在父组件中使用子组件时&#xff0c;给子组件以添加属性的方式传值 <sonCom car"宝马车"></sonCom> 其中如…

如何在 Jupyter Notebook 执行和学习 SQL 语句(上)—— 基本原理详解和相关库安装篇

近期我找工作很多岗位问到sql&#xff0c;由于我简历上有写&#xff0c;加上我实习的时候确实运用了&#xff0c;所以我还是准备复习一下SQL语句&#xff0c;常见的内容&#xff0c;主要包括一些内容&#xff0c;比如SQL基础&#xff08;主要是取数select&#xff0c;毕竟用的时…

electron-vite打包踩坑记录

electron-vite打包踩坑记录 大前端已成趋势&#xff0c;用electron开发桌面端应用越来越普遍 近期尝试用electronvite开发了个桌面应用&#xff0c;electron-vite地址&#xff0c;可用使用vue开发&#xff0c;vite打包&#xff0c;这样就很方便了 但是&#xff0c;我尝试了一…

Java项目实战II基于Java+Spring Boot+MySQL的桂林旅游景点导游平台(源码+数据库+文档)

目录 一、前言 二、技术介绍 三、系统实现 四、文档参考 五、核心代码 六、源码获取 全栈码农以及毕业设计实战开发&#xff0c;CSDN平台Java领域新星创作者 一、前言 桂林&#xff0c;以其独特的喀斯特地貌、秀美的自然风光闻名遐迩&#xff0c;每年吸引着无数国内外游…

N1从安卓盒子刷成armbian

Release Armbian_noble_save_2024.10 ophub/amlogic-s9xxx-armbian (github.com) armbian下载&#xff0c;这里要选择905d adb 下载地址 https://dl.google.com/android/repository/platform-tools-latest-windows.zip 提示信息 恩山无线论坛 使用usb image tool restet a…

月饼市场新风潮:解析茶味的消费趋势

茶味月饼评论分析 一、评论的基本统计分析(数据来源&#xff1a;淘宝评论信息接口) 评论长度分布图&#xff1a; 根据接口拉取数据获得的评论数据&#xff0c;并进行数据清洗后&#xff0c;得到的评论如下&#xff1a; 评论总数: 9**3 评论长度描述性统计&#xff1a; Cou…

【GT240X】【3】Wmware17和Centos 8 安装

文章目录 一、说明二、安装WMware2.1 下载WMware2.2 安装2.3 虚拟机的逻辑结构 三、安装Centos3.1 获取最新版本Centos3.2 创建虚拟机 四、问题和简答4.1 centos被淘汰了吗&#xff1f;4.2 centos里面中文显示成小方块的解决方法4.3 汉语-英语输入切换4.4 全屏和半屏切换 五、练…

【unity框架开发12】从零手搓unity存档存储数据持久化系统,实现对存档的创建,获取,保存,加载,删除,缓存,加密,支持多存档

文章目录 前言一、Unity对Json数据的操作方法一、JsonUtility方法二、Newtonsoft 二、持久化的数据路径三、数据加密/解密加密方法解密方法 四、条件编译指令限制仅在编辑器模式下进行加密/解密四、数据持久化管理器1、存档工具类2、一个存档数据3、存档系统数据类4、数据存档存…