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

openGauss数据库管理实战指南——基本常用操作总结

查看所有数据库

查看所有表 \d

查看函数定义

查看所有用户 select usename from pg_user;

1.数据库创建管理

CREATE DATABASE test;

2.数据库用户创建管理

CREATE USER tom PASSWORD 'Root123456.';

3.表的创建及管理

3.1.创建表

CREATE TABLE test(ID INTEGER PRIMARY KEY, NAME TEXT);

3.2.数据的增删改查

--增insert into test values (1,'xiaoming'),(2,'xiaohong'),,(3,'xiaoqiang');
--删DELETE FROM test WHERE ID<2;--改UPDATE test SET ID = ID*2 WHERE ID=2;--查SELECT * FROM test LIMIT 1;

3.3.表的删除

DROP TABLE test;
--创建基表,并插入数据。
CREATE TABLE base_tbl (a int PRIMARY KEY, b text DEFAULT 'Unspecified');
INSERT INTO base_tbl values (1, 'insertTable');
--创建视图
REATE VIEW ro_view1 AS SELECT a, b FROM base_tbl;
--视图插入、更新和删除数据
INSERT INTO ro_view1 values (2, 'insertView');
UPDATE ro_view1 SET b = 'updateView' WHERE a = 1;
DELETE FROM ro_view1 WHERE a= 2;--创建check option视图
CREATE VIEW ro_view2 AS SELECT a, b FROM base_tbl WHERE a > 10 WITH CHECK OPTION;
--插入、更新视图不可见数据失败
INSERT INTO ro_view2 values (5, 'insertView');
INSERT INTO base_tbl values (15, 'insertTable');
UPDATE ro_view2 SET a = 5 WHERE a = 15;

4.SQL语法实验

4.1.DDL

定义数据库:CREATE DATABASE、ALTER DATABASE、DROP DATABASE

定义模式:CREATE SCHEMA、ALTER SCHEMA、DROP SCHEMA

定义表空间:CREATE TABLESPACE、ALTER TABLESPACE、DROP TABLESPACE

定义表:CREATE TABLE、ALTER TABLE、DROP TABLE

定义分区表:CREATE TABLE PARTITION、ALTER TABLE PARTITION

定义索引:CREATE INDEX、DROP INDEX

定义存储过程:CREATE PROCEDURE、ALTER PROCEDURE、DROP PROCEDURE

定义函数:CREATE FUNCTION、ALTER FUNCTION、DROPFUNCTION

定义视图:CREATE VIEW、ALTER VIEW、DROP VIEW

4.2.DML

INSERT。

UPDATE。

SELECT。

DELETE\TRUNCATE。

COPY。

CREATE TABLE test(ID INTEGER PRIMARY KEY, NAME TEXT);
insert into test values (1,'xiaoming'),(2,'xiaohong'),,(3,'xiaoqiang');
COPY test TO '/home/omm/ds_ship_mode.dat'

LOCK。

CALL。

4.3.DCL

定义角色CREATE/ALTER/DROP ROLE

定义用户CREATE/ALTER/DROP USER

授权GRANT

收回权限REVOKE

设置默认权限ALTER DEFAULT PRIVILEGES

关闭当前节点SHUTDOWN

5.创建和管理其他数据库对象

5.1.schema

CREATE SCHEMA ds;
ALTER SCHEMA ds RENAME TO ds_new;
ALTER SCHEMA ds_new OWNER TO tom;
DROP SCHEMA ds_new;

5.2.索引

create schema tpcds;
CREATE TABLE tpcds.ship_mode_t1
(SM_SHIP_MODE_SK           INTEGER               NOT NULL,SM_SHIP_MODE_ID           CHAR(16)              NOT NULL,SM_TYPE                   CHAR(30)                      ,SM_CODE                   CHAR(10)                      ,SM_CARRIER                CHAR(20)                      ,SM_CONTRACT               CHAR(20)
) 
;
--在表tpcds.ship_mode_t1上的SM_SHIP_MODE_SK字段上创建普通的唯一索引。
CREATE UNIQUE INDEX ds_ship_mode_t1_index1 ON tpcds.ship_mode_t1(SM_SHIP_MODE_SK);
--在表tpcds.ship_mode_t1上的SM_SHIP_MODE_SK字段上创建指定B-tree索引。
CREATE INDEX ds_ship_mode_t1_index4 ON tpcds.ship_mode_t1 USING btree(SM_SHIP_MODE_SK);
--在表tpcds.ship_mode_t1上SM_CODE字段上创建表达式索引。
CREATE INDEX ds_ship_mode_t1_index2 ON tpcds.ship_mode_t1(SUBSTR(SM_CODE,1 ,4));
--设置索引不可用。
ALTER INDEX tpcds.ds_ship_mode_t1_index2 UNUSABLE;
--删除一个现有的索引。
DROP INDEX tpcds.ds_ship_mode_t1_index2;
DROP TABLE tpcds.ship_mode_t1;
DROP SCHEMA tpcds;

5.3.视图

--创建基表,并插入数据。
CREATE TABLE base_tbl (a int PRIMARY KEY, b text DEFAULT 'Unspecified');
INSERT INTO base_tbl values (1, 'insertTable');
--创建视图
REATE VIEW ro_view1 AS SELECT a, b FROM base_tbl;
--视图插入、更新和删除数据
INSERT INTO ro_view1 values (2, 'insertView');
UPDATE ro_view1 SET b = 'updateView' WHERE a = 1;
DELETE FROM ro_view1 WHERE a= 2;--创建check option视图
CREATE VIEW ro_view2 AS SELECT a, b FROM base_tbl WHERE a > 10 WITH CHECK OPTION;
--插入、更新视图不可见数据失败
INSERT INTO ro_view2 values (5, 'insertView');
INSERT INTO base_tbl values (15, 'insertTable');
UPDATE ro_view2 SET a = 5 WHERE a = 15;

5.4.存储过程

CREATE PROCEDURE proc_insert_sql()
AS BEGIN insert into test values (1,'xiaoming'),(2,'xiaohong'),(3,'xiaoqiang');
END
/
CALL proc_insert_sql();
SELECT * FROM test;
DROP PROCEDURE proc_insert_sql;

5.5.函数

CREATE FUNCTION func_add_sql(num1 integer, num2 integer) RETURN integer
AS BEGIN 
RETURN num1 + num2;
END
/
SELECT func_add_sql(4,2);
DROP FUNCTION func_add_sql;

6.用户权限控制

6.1.角色

CREATE ROLE paul IDENTIFIED BY 'Root123456.';
ALTER ROLE paul IDENTIFIED BY 'Root123456&' REPLACE 'Root123456.';

6.2.权限

CREATE USER jack PASSWORD 'Root123456.';
create schema tpcds;
ALTER DEFAULT PRIVILEGES IN SCHEMA tpcds GRANT INSERT ON TABLES TO jack;

6.3.授权

GRANT ALL PRIVILEGES TO jack;
GRANT jack TO paul WITH ADMIN OPTION;

6.4.权限回收

REVOKE paul FROM jack;
REVOKE ALL PRIVILEGES FROM jack;
DROP ROLE paul;
DROP OWNED BY jack;
DROP USER jack;
http://www.dtcms.com/a/275942.html

相关文章:

  • AI:机器人未来的形态是什么?
  • Cisco ACI 生成Postman CSV 脚本场景
  • 死锁的避免
  • Spring Boot 应用中,配置的加载优先级
  • 锁相环初探
  • CTFHub————Web{信息泄露[Git泄露(Stash、Index)]}
  • Java 接口详解:从基础到高级,掌握面向对象设计的核心契约
  • 使用FastAdmin框架开发二
  • ollama - sqlcoder模型:面向提示词编程(根据用户信息生成sql语句并执行返回结果)
  • SQL新手入门详细教程和应用实例
  • 微信小程序121~130
  • [Vroom] 时间窗口 | 载重与货量管控 | 内部路由表示机制 | 增量式更新算法O(1)
  • 【Redis-05】高可用方案-主从哨兵
  • 【PTA数据结构 | C语言版】用两个栈实现队列
  • 监控28181连接到云服务器/推流分发/客户端网页端手机端拉流/实时性好极低延迟
  • 初等行变换会改变矩阵的什么?不变改变矩阵的什么?求什么时需要初等行变换?求什么时不能初等行变换?
  • GRPO PPO
  • Python 是动态类型的语言,它和静态类型语言(如 C++/Java)有什么优缺点?
  • CSS动画下划线
  • hot100链表(1)
  • 通过自制Flash算法文件,成功实现H7-TOOL脱机烧录nRF54L15,且支持自动解除SWD接口保护(2025-07-12)
  • Google MUVERA: 让多向量检索与单向量检索一样快
  • 2025Stockapi股票数据接口,股票实时数据,技术指标macd,kdj,cci技术指标算法,集合竞价数据,龙虎榜数据接口
  • TensorFlow2 study notes[2]
  • 启动Haproxy失败,如何排查问题
  • TCP与UDP协议详解:网络世界的可靠信使与高速快递
  • 参数化类型有哪些?自动化脚本如何实现数据参数化?
  • houdini vat 学习笔记
  • 滤波电路Multisim电路仿真实验汇总——硬件工程师笔记
  • Spring Security 安全认证深度解析与实战指南