当前位置: 首页 > news >正文

openGauss数据库-头歌实验1-1 初识openGauss

一、历史与特性

任务描述

本关任务:了解openGauss的发展历史以及相关特性。

相关知识

为了完成本关任务,你需要掌握:1.openGauss的发展历程,2.openGauss的功能特性。

发展历程

2019年9月19日在华为全联接大会上,华为宣布将开源其数据库产品,开源后命名为openGauss。
2020 年6月30日openGauss数据库源代码正式开放。
2021年9月30日,openGauss 2.1.0版本正式上线。

产品简介

openGauss 是一款开源的,支持 SQL2003 标准语法,支持主备部署的高可用关系型(OLTP)数据库。

采用客户端/服务器、单进程多线程架构,支持单机和一主多备部署方式,备机只读,支持双机高可用和读扩展。

产品特点

openGauss 相比于其他开源数据库主要有以下几个主要特点:

1.高性能

提供了面向多核架构的并发控制技术结合鲲鹏硬件优化,在两路鲲鹏下 TPCC Benchmark 达成性能 150 万 tpmc 。
针对当前硬件多核 numa 的架构趋势, 在内核关键结构上采用了 Numa-Aware 的数据结构。
提供 Sql-bypass 智能快速引擎、融合引擎技术。

2.高可用

支持主备同步、异步和级联备机多种部署模式。
数据页 CRC 校验,损坏数据页通过备机自动修复。
备机并行恢复,10 秒内可升主提供服务。

3.高安全

支持全密态计算、访问控制、加密认证、数据库审计和动态数据脱敏等安全特性,提供全方位端到端的数据安全保护。

4.易运维

基于 AI 的智能参数调优和索引推荐,提供 AI 自动参数推荐。
慢 SQL 诊断,多维性能自监控视图,实时掌控系统的性能表现。
提供在线自学习的 SQL 时间预测。

5.全开放

采用木兰宽松许可证协议,允许对代码自由修改、使用和引用。
数据库内核能力全开放。
提供丰富的伙伴认证,培训体系和高校课程。

编程要求

经过本关的学习,你已经对 openGauss 的历史和特性有了一定的认识。请完成右边的相关选择题测验任务,以检验你的认识是否准确吧。

答案 

二、安装与连接

任务描述

本关任务:完成对 openGauss 数据库管理系统的特定连接要求。

相关知识

为了完成本关任务,你需要掌握:1. openGauss 的安装,2.openGauss 的连接。

安装 openGauss

openGauss支持单机部署和单机HA部署两种部署方式。单机部署时,可在一个主机部署多个数据库实例,但为了数据安全,不建议用户这样部署。单机HA部署支持一台主机和最少一台备机,备机一共最多8台的配置方式。

连接数据库

可以使用openGauss自带的 gsql (openGauss交互终端)连接数据库。

gsql 是 openGauss 提供的在命令行下运行的数据库连接工具。此工具除了具备操作数据库的基本功能,还提供了若干高级特性,便于用户使用。

因为 openGauss 不建议使用root账户管理数据库,所以首先切换到 omm 用户:

su - omm

命令行显示如下信息,表示当前使用系统的用户为 omm :

常用的 gsql 连接数据库的指令格式有:

 gsql -d <数据库名称> -p <端口号>gsql -d <数据库名称> -U <用户名称> -W '数据库密码';


数据库安装完成后,默认生成名称为postgres的数据库。第一次连接数据库时可以连接到此数据库。

执行以下命令以连接到postgres 数据库:

 gsql -d postgres -p 5432


其中 postgres为需要连接的数据库名称,5432为数据库主节点的端口号。

连接成功后提示如下信息:

omm 用户是管理员用户,因此系统显示DBNAME=#。若使用普通用户身份登录和连接数据库,系统显示DBNAME=>。

“Non-SSL connection”表示未使用SSL方式连接数据库。如果需要高安全性时,就使用SSL连接。

登录数据库后可以进行修改密码等操作。例如将 abc 用户的密码从Mypwd123修改为Test@2021,命令如下:

ALTER ROLE abc IDENTIFIED BY 'Test@2021' REPLACE 'Mypwd123';


退出数据库的命令为\q:

本节只介绍如何使用gsql连接数据库,有关 gsql 的更多内容可以参考 gsql 使用指南。

编程要求

根据介绍,在命令行中使用用户omm登录postgres数据库,密码为passwd123@123。
登陆后将gaussdb用户的密码修改为Mypassword@123。

编程实现

三、常用交互操作

任务描述

本关任务:学习 openGauss 数据库常用的交互操作。

相关知识

为了完成本关任务,你需要掌握:1.openGauss 数据库的常用操作,2.对数据库和数据表的常用操作。

连接数据库

上一关中介绍了利用 gsql 连接 openGauss 数据库的方法,本关中使用 omm 用户连接到数据库。

1.首先切换到操作系统的 omm 用户:
su - omm

2.连接到 postgres 数据库:
gsql -d postgres -p 5432
3.创建数据库用户

openGauss 默认只有安装时创建的管理员用户可以访问初始数据库,还可以创建其他数据库用户账号访问数据库。

可以通过如下命令创建一个用户名为 joe,密码为 Bigdata@123 的用户:

CREATE USER joe WITH PASSWORD "Bigdata@123";

创建成功后提示如下信息:

4.创建数据库

使用如下命令创建一个属于用户 joe 的数据库 db_tpcc:

CREATE DATABASE db_tpcc OWNER joe;

结果显示为以下信息时表示创建成功:

5.切换用户

db_tpcc 数据库创建完成后,退出数据库,使用新用户 joe 连接到 db_tpcc 执行以后的操作(也可以选择继续在默认数据库中进行后续的体验):

6.创建 schema

执行如下语句创建 schema:

CREATE SCHEMA joe AUTHORIZATION joe;

提示如下信息表示创建成功:

7.创建表

使用如下命令创建一个名称为 mytable, 只有一列的表。

CREATE TABLE mytable(firstcol int);

其中字段名称为 firstcol,字段类型为 integer。

显示如下信息时表示创建成功:

8.执行如下语句向表中插入数据:
INSERT INTO mytable values(100);

结果显示为如下信息时表示插入数据成功:

9.查看表中数据

执行以下语句查看 mytable 表中的数据:

SELECT * FROM mytable;

可以看到刚刚插入的数据:

10.常用的交互操作
1.使用\l命令可以列表查看当前所有数据库的信息:

2.使用\d命令可以查看当前数据表的信息:

3.使用\c命令可以切换数据库:

4.输入\?指令可以查看 openGauss 支持的所有快捷命令及其说明。

编程要求

根据提示,在右侧命令行进行操作,创建用户jackson,密码为jackson@123并使用该用户创建数据库userdb,在该数据库中创建只有一列的数据表userinfo。

 编程实现


http://www.mrgr.cn/news/63898.html

相关文章:

  • Effective C++读书笔记——item13(使用对象管理资源)
  • python无需验证码免登录12306抢票 --selenium(2)
  • 探秘MetaGPT:革新软件开发的多智能体框架(22/30)
  • 大模型WebUI:Gradio全解11——Chatbots:融合大模型的多模态聊天机器人(2)
  • 《Spring Framework实战》7:4.1.2.容器概述
  • MIT心律不齐数据库信号和标注读取
  • 【rust实战】rust博客系统4_连接数据库及查询数据
  • 华为 HCIP-Datacom H12-821 题库 (41)
  • nodejs入门教程8:nodejs EventEmitter
  • HTML 基础标签——表单标签<form>
  • 基于java+SpringBoot+Vue的学生网上选课系统设计与实现
  • 1014:与圆相关的计算
  • 使用onnxruntime-web 运行yolov8-nano推理
  • 查缺补漏----关于计组两道题辨析
  • Leetcode 剑指 Offer II 100.三角形最小路径和
  • OR63 删除公共字符
  • 【JAVA 笔记】10 ch07_oop_fundamentals 面向对象编程(基础部分)
  • Linux网络配置与管理:掌握访问与管理的关键技能
  • C++ | Leetcode C++题解之第526题优美的排列
  • 闪存学习_1:Flash-Aware Computing from Jihong Kim
  • nodejs入门教程1:nodejs简介
  • 聊一聊Elasticsearch的索引的分片分配机制
  • 更懂你的AI助手来了
  • C#/.NET/.NET Core技术前沿周刊 | 第 11 期(2024年10.21-10.31)
  • 线性数据结构之队列
  • 字符串函数