首页 > 数据库 >OushuDB 数据库基本用法(中)

OushuDB 数据库基本用法(中)

时间:2023-02-07 10:36:47浏览次数:52  
标签:postgres 数据库 用法 path test myschema OushuDB schema


1、概述

一个OushuDB集群管理着多个数据库(database),每个数据库又包含多个模式(schema), 一个模式包含多个对象(表,视图,函数等),所以这些对象之间的层级结构为:

database -> schema -> (tables, functions, views)

每个模式,表,视图,函数等只属于一个database。本章主要介绍每一种对象的常见用法。具体使用语法可以参见参考手册。

2、数据库

OushuDB在初始化完成后,会默认生成三个数据库,可以使用l命令查看,或者查看

postgres=# l

List of databases

Name | Owner | Encoding | Access privileges

-----------+----------+----------+-------------------

postgres | ChangLei | UTF8 |

template0 | ChangLei | UTF8 |

template1 | ChangLei | UTF8 |

(4 rows)

其中template0和template1为模版数据库。template1为系统默认用来创建新数据库的模版数据库,用户可以修改。template0默认不接受连接,所以不可更改,目的是始终保存一个干净的模版数据库。

创建一个数据库的时候,可以指定一个数据库的模版数据库。缺省为template1,现在OushuDB只支持以template0,template1和postgres数据库为模版数据库。例如:

postgres=# create database tdb; # 创建一个新数据库,默认以template0为模版

CREATE DATABASE

postgres=#c postgres # 连接postgres

postgres=# create table test(i int); # 在postgres数据库中创建表test

CREATE TABLE

postgres=# create table test_orc(i int) with (appendonly=true, orientation=orc); # 在postgres数据库中创建ORC格式表

CREATE TABLE

postgres=# create database dbnew template postgres;

CREATE DATABASE

postgres=#c dbnew # 连接dbnew

可以看到,dbnew中现在包含test表

dbnew=#d

List of relations

Schema | Name | Type | Owner | Storage

--------+------+-------+----------+-------------

public | test | table | ChangLei | append only

(1 row)

3、模式

一个数据库包含多个模式(schema),而一个模式可以包含多种命名对象,比如表,数据类型,函数,操作符等。同一个对象名字可以用在不同的模式中而不产生冲突。比如schema1中可以包含表test,schema2中也可以同时包含名字为test的表。从这个意义上,模式很像一个命名空间(namespace)。

当创建一个对象时,默认被放置在public模式中。下面是系统默认创建的schema。

template1=# dn

List of schemas

Name | Owner

--------------------+----------

hawq_toolkit | ChangLei

information_schema | ChangLei

pg_aoseg | ChangLei

pg_bitmapindex | ChangLei

pg_catalog | ChangLei

pg_toast | ChangLei

public | ChangLei

(7 rows)

通常在这样几个场景下,用户需要使用模式:

允许多个用户同时使用一个数据库,而不产生名字冲突。

把数据库对象组织成多个schema,好像是多个命名空间一样

第三方应用可以把它们的对象放到一个单独的schema中,而不和其他对象产生从图。

注意:schema不可以嵌套,也就是说,schema中不可以再包含schema。

下面是创建schema的例子。

create schema myschema;

创建或者存取一个schema中的对象,可以使用{schema}.{object}形式,例如:

create table myschema.test(i int);

select * from myschema.test;

删除一个空的schema,可以使用:

drop schema myschame;

删除不空的schema,可以使用cascade关键词:

drop schema myschema cascade;

使用{schema}.{object}形式,通常用起来不是很方便。可以通过设置schema搜索路径来简化。”SHOW search_path”命令可以给出当前的schema搜索路径。”SET search_path TO schema-name1, schema-name2”可以设置schema搜索路径。例如:

postgres=# show search_path;

search_path

----------------

"$user",public

(1 row)

postgres=# create schema myschema;

CREATE SCHEMA

postgres=# set search_path = public, myschema;

SET

postgres=# show search_path;

search_path

------------------

public, myschema

(1 row)

标签:postgres,数据库,用法,path,test,myschema,OushuDB,schema
From: https://blog.51cto.com/u_15334349/6041385

相关文章

  • OushuDB 产品基本介绍——表
    1、表OushuDB表由行(rows)和(columns)组成。每一个列有一个列名和一个数据类型,一个表的列数和列的顺序是固定的。一个表的行数是可变的。SQL并不假设表中行的顺序。当读一个表......
  • 关于oushudb-hawq:OushuDB-基本用法-启动停止
    启动OushuDB有两种形式,一种是通过”hawqstartcluster”命令来启动整个集群,包含master和segment。启动哪些segment是由”/hawq-install-path/etc/slaves”中蕴含的节点确定......
  • OushuDB 用户指南之类型转换值存储
    要插入表中的数值也根据下面的步骤转换成目标列的数据类型。值存储数据类型解析1.查找与目标准确的匹配。2.否则,试着将表达式直接转换成目标类型。如果已知这两种类型之间......
  • OushuDB数据库基本用法(下)
    一个数据库包含多个模式(schema),而一个模式可以包含多种命名对象,比如表,数据类型,函数,操作符等。同一个对象名字可以用在不同的模式中而不产生冲突。比如schema1中可以包含表tes......
  • 偶数科技:基于OushuDB的新一代云原生湖仓一体为企业助力
    实时性数据分析需求暴增,偶数湖仓一体为企业助力在愈发复杂的大数据场景下,数据仓库与数据湖各自的弊端开始显现,湖仓一体架构走向舞台中央。在国外有两种流行的实现数据湖仓......
  • OushuDB连接带kerberos的HDFS
    一.KDC上的操作1.登录KDCserver,将Kerberos配置文件/etc/krb5.conf分发至KDW每个节点:scp/etc/krb5.conf10.0.5.58:/etc/scp/etc/krb5.conf10.0.5.146:/etc/scp/etc/......
  • OushuDB 创建和管理表空间
    OushuDB里的表空间允许数据库管理员在文件系统里定义那些代表数据库对象的文件存放位置。一旦创建了表空间,那么就可以在创建数据库对象的时候引用它。通过使用表空间,管理......
  • About OushuDB (Oushu Database)
    OverviewOushuDatabase(OushuDBforshort)isanewgenerationofcloud-nativedatawarehousecreatedbythefoundingteamofApacheHAWQ.Thisproductadoptst......
  • mysql数据库备份(windows环境)
    备份:cmd输入指令,按照新数据库的字符集去备份,备份等待即可;恢复:之前新建数据库,注意字符集问题,输入指令还原即可; ......
  • 09 数据库查询(3) | OushuDB 数据库使用入门
    表连接、组合查询大家好,本节课程我们将学习数据查询的进阶部分,主要包括表连接和组合查询。在上一节的课程中,我们尝试了在两个数据表中通过不同的条件来查询想要的数据,但是在......