海量数据库使用操作

news2024/12/18 15:01:32

海量数据库-vastbase G100使用操作

文章目录

    • 海量数据库-vastbase G100使用操作
      • 使用vsql本地连接数据库
      • 创建数据库
        • 功能描述
      • 创建表
      • 管理表
        • 向表中插入数据
        • 更新表中数据
      • 查看数据
      • 删除表中数据
      • 示例
      • 查看帮助信息
      • 查看数据库
      • 列举表
      • 查看表结构
      • 列举schema
      • 查看索引
      • 切换数据库
    • 总结

使用vsql本地连接数据库

步骤1 以操作系统用户vastbase登录数据库实例所在主机。

步骤2 使用vsql连接本地数据库。

vsql -d vastbase -p 5432
  • vastbase:需要连接的数据库名称,安装完成后,默认生成名称为vastbase的数据库,实际登录时请根据具体情况替换。
  • 5432:数据库的端口号,实际登录时请根据具体情况替换。

步骤3 首次登陆时修改密码。

  • (管理员首次登录时)如果用户的数据库版本是2.2(Build 5.75)及以上且角色是系统管理员(vbadmin)、安全管理员(vbsso)或者审计管理员(vbaudit),首次登录时系统会强制要求修改口令,修改语法如下:

    ALTER ROLE 用户名 IDENTIFIED BY '新口令' REPLACE '原随机口令';
    

    其中原随机口令表示:

    • 实例化数据库安装:安装过程中会生成随机口令作为管理员初始口令,显示信息如下:
数据库三个默认管理员vbaudit、vbsso、vbadmin的默认口令为:
系统管理员[vbadmin] 初始密码: A4b&b858
安全管理员[vbsso] 初始密码: U6/f305f
审计管理员[vbaudit] 初始密码: E5b44f8-

​ 首次登录数据库,需要自行修改口令后才可以正常操作数据库,修改实例:

ALTER ROLE vbadmin IDENTIFIED BY 'Huayu123' REPLACE 'A4b&b858';

步骤4 退出数据库。

\q

创建数据库

功能描述

数据库安装完成后,默认生成名称为vastbase的数据库。用户需要自己创建一个新的数据库。默认情况下新数据库将通过复制标准系统数据库template0来创建,且仅支持使用template0来创建。

  • 创建一个新的数据库testdb1。
CREATE DATABASE testdb1;
  • 创建角色(用户)
    在 VastBase 中,你需要先创建名为 dbuser 的角色(如果还未创建的话)。可以使用以下命令来创建角色:
CREATE ROLE dbuser WITH LOGIN PASSWORD 'Huayu123';
# 注释
CREATE ROLE 语句用于创建一个新的角色。
WITH LOGIN 表示这个角色可以用于登录数据库,也就是相当于创建了一个具有登录权限的用户。
PASSWORD 'your_password' 用于设置该角色(用户)的登录密码
  • 用模板template0创建数据库testdb2,并指定所有者为dbuser。
CREATE DATABASE testdb2 OWNER dbuser TEMPLATE template0;
  • 查看数据库(vsql客户端可用)。
\l
vastbase=# \l
                                   数据库库列表
   名称    |  拥有者  | 字元编码 |  校对规则  |   Ctype    |       存
权限        
-----------+----------+----------+------------+------------+----------
-------------
 postgres  | vastbase | UTF8     | en_US.utf8 | en_US.utf8 | 
 template0 | vastbase | UTF8     | en_US.utf8 | en_US.utf8 | =c/vastba
se          +
           |          |          |            |            | vastbase=
CTc/vastbase
 template1 | vastbase | UTF8     | en_US.utf8 | en_US.utf8 | =c/vastba
se          +
           |          |          |            |            | vastbase=
CTc/vastbase
 testdb1   | vastbase | UTF8     | en_US.utf8 | en_US.utf8 | 
 testdb2   | dbuser   | UTF8     | en_US.utf8 | en_US.utf8 | 
 vastbase  | vastbase | UTF8     | en_US.utf8 | en_US.utf8 | 
(6 行记录)
  • 修改将testdb1数据库名称修改为testdb3。
ALTER DATABASE testdb1 RENAME TO testdb3;
  • 删除数据库testdb3。
DROP DATABASE testdb3;

创建表

表是建立在数据库中的,在不同的数据库中可以存放相同的表。甚至可以通过 使用模式在同一个数据库中创建相同名称的表。

  • 创建简单的表。
CREATE TABLE public.warehouse_t1(
W_WAREHOUSE_SK INTEGER NOT NULL,
W_WAREHOUSE_ID CHAR(16) NOT NULL,
W_WAREHOUSE_NAME VARCHAR(20) ,
W_WAREHOUSE_SQ_FT INTEGER ,
W_COUNTRY VARCHAR(20) ,
W_GMT_OFFSET DECIMAL(5,2)
);
  • 创建表,并指定W_STATE字段的缺省值为GA。
CREATE TABLE public.warehouse_t2
(
W_WAREHOUSE_SK INTEGER NOT NULL,
W_WAREHOUSE_ID CHAR(16) NOT NULL,
W_COUNTY VARCHAR(30) ,
W_STATE CHAR(2) DEFAULT 'GA',
W_ZIP CHAR(10) ,
W_COUNTRY VARCHAR(20) ,
W_GMT_OFFSET DECIMAL(5,2)
);
  • 创建一个带有70%填充因子的表。
CREATE TABLE public.warehouse_t3
(
W_WAREHOUSE_SK INTEGER NOT NULL,
W_COUNTRY VARCHAR(20) ,
W_GMT_OFFSET DECIMAL(5,2)
) WITH(fillfactor=70);
  • 创建表,并指定该表数据不写入预写日志。
CREATE UNLOGGED TABLE public.warehouse_t4
(
W_WAREHOUSE_SK INTEGER NOT NULL,
W_COUNTRY VARCHAR(20) ,
W_GMT_OFFSET DECIMAL(5,2)
);
  • 创建表临时表。
CREATE TEMPORARY TABLE warehouse_t5
(
W_WAREHOUSE_SK INTEGER NOT NULL,
W_COUNTRY VARCHAR(20) ,
W_GMT_OFFSET DECIMAL(5,2)
);
  • 创建表时,指定表空间PG_DEFAULT。
CREATE TABLE public.warehouse_t6
(
W_ID INTEGER NOT NULL,
W_NAME VARCHAR(20) ,
W_MAIL VARCHAR(40)
) TABLESPACE PG_DEFAULT;
  • 创建一个有主键约束的表。
CREATE TABLE public.warehouse_t7
(
W_WAREHOUSE_SK INTEGER PRIMARY KEY,
W_WAREHOUSE_ID CHAR(16) NOT NULL,
W_COUNTRY VARCHAR(20) ,
W_GMT_OFFSET DECIMAL(5,2)
);
  • 创建一个有复合主键约束的表。
CREATE TABLE public.warehouse_t8
(
W_WAREHOUSE_SK INTEGER NOT NULL,
W_WAREHOUSE_ID CHAR(16) NOT NULL,
W_WAREHOUSE_NAME VARCHAR(20),
W_COUNTRY VARCHAR(20),
W_GMT_OFFSET DECIMAL(5,2),
CONSTRAINT W_CSTR_KEY2 PRIMARY KEY(W_WAREHOUSE_SK, W_WAREHOUSE_ID)
);
  • 定义一个检查列约束。
CREATE TABLE public.warehouse_t9
(
W_WAREHOUSE_SK INTEGER CHECK (W_WAREHOUSE_SK > 0),
W_WAREHOUSE_ID CHAR(16) NOT NULL,
W_WAREHOUSE_NAME VARCHAR(20) CHECK (W_WAREHOUSE_NAME IS NOT NULL),
W_WAREHOUSE_SQ_FT INTEGER ,
W_GMT_OFFSET DECIMAL(5,2)
);
  • 向表中增加一个varchar列。
ALTER TABLE public.warehouse_t1 ADD W_GOODS_CATEGORY varchar(30);
  • 给表增加一个检查约束。
ALTER TABLE public.warehouse_t2 ADD CONSTRAINT W_CONSTR_KEY4 CHECK (W_WAREHOUSE_SK >10);
  • 给一个已存在字段添加非空约束。
ALTER TABLE public.warehouse_t3 ALTER COLUMN W_COUNTRY SET NOT NULL;
  • 重命名已存在的表。
ALTER TABLE public.warehouse_t4 RENAME TO newtab;
  • 删除表。
DROP TABLE public.warehouse_t1;
DROP TABLE public.warehouse_t2;
DROP TABLE public.warehouse_t3;

管理表

向表中插入数据

在创建一个表后,表中并没有数据,在使用这个表之前,需要向表中插入数据。本小节介绍如何使用INSERT命令插入一行或多行数据,及从指定表插入数据。

示例

执行如下命令建立示例中需要使用的表customer_t1。

CREATE TABLE customer_t1
(
c_customer_sk integer,
c_customer_id char(5),
c_first_name char(6));

向表中插入数据前,意味着表已创建成功。创建表的步骤请参见创建表。

  • 向表customer_t1中插入一行数据:

    数据值是按照这些字段在表中出现的顺序列出的,并且用逗号分隔。通常数据值是文本(常量),但也允许使用标量表达式。

    INSERT INTO customer_t1(c_customer_sk, c_customer_id, c_first_name)
    VALUES (3769, 'hello', 'Grace');
    

    如果用户已经知道表中字段的顺序,也可无需列出表中的字段。例如以下命令与上面的命令效果相同。

    INSERT INTO customer_t1 VALUES (3769, 'hello', 'Grace');
    

    如果用户不知道所有字段的数值,可以忽略其中的一些。没有数值的字段将被填充为字段的缺省值。例如:

    INSERT INTO customer_t1 (c_customer_sk, c_first_name) VALUES (3769, 'Grace');
    INSERT INTO customer_t1 VALUES (3769, 'hello');
    
  • 如果需要在表中插入多行,请使用以下命令:

    INSERT INTO customer_t1 (c_customer_sk, c_customer_id, c_first_name) VALUES(6885, 'maps', 'Joes'), (4321, 'tpcds', 'Lily'), (9527, 'world', 'James');
    

    如果需要向表中插入多条数据,除此命令外,也可以多次执行插入一行数据命令实现。但是建议使用此命令可以提升效率。

  • 如果从指定表插入数据到当前表,例如在数据库中创建了一个表customer_t1的备份表customer_t2,现在需要将表customer_t1中的数据插入到表customer_t2中,则可以执行如下命令。

    CREATE TABLE customer_t2
    (
    c_customer_sk integer,
    c_customer_id char(5),
    c_first_name char(6),
    c_last_name char(8)
    );
    
    INSERT INTO customer_t2 SELECT * FROM customer_t1;
    
更新表中数据

修改已经存储在数据库中数据的行为叫做更新。用户可以更新单独一行,所有行或者指定的部分行。还可以独立更新每个字段,而其他字段则不受影响。

使用UPDATE命令更新现有行,需要提供以下三种信息:

  • 表的名称和要更新的字段名。
  • 字段的新值。
  • 要更新哪些行。

SQL通常不会为数据行提供唯一标识,因此无法直接声明需要更新哪一行。但是可以通过声明一个被更新的行必须满足的条件。只有在表里存在主键的时候,才可以通过主键指定一个独立的行。

建立表和插入数据的步骤请参考创建表与管理表。

示例

  • 需要将表customer_t1中c_customer_sk为9527的地域重新定义为9876:

    UPDATE customer_t1 SET c_customer_sk = 9876 WHERE c_customer_sk = 9527;
    

    这里的表名称也可以使用模式名修饰,否则会从默认的模式路径找到这个表。SET后面紧跟字段和新的字段值。新的字段值不仅可以是常量,也可以是变量表达式。

  • 把所有c_customer_sk的值增加100:

    UPDATE customer_t1 SET c_customer_sk = c_customer_sk + 100;
    

    在这里省略了WHERE子句,表示表中的所有行都要被更新。如果出现了WHERE子句,那么只有匹配其条件的行才会被更新。在SET子句中的等号是一个赋值,而在WHERE子句中的等号是比较。WHERE条件不一定是相等测试,许多其他的操作符也可以使用。

  • 用户可以在一个UPDATE命令中更新更多的字段,方法是在SET子句中列出更多赋值,比如:

    UPDATE customer_t1 SET c_customer_id = 'Admin', c_first_name = 'Local' WHERE c_customer_sk = 4421;
    

查看数据

在以下示例执行前,需按照管理表将示例对应数据表与数据进行创建与插入。

  • 执行如下命令查询表customer_t1的数据行数。

    SELECT count(*) FROM customer_t1;
    

    返回结果为:

    count
    -------
        7
    (1 row)
    
  • 执行如下命令查询表customer_t1的所有数据。

    SELECT * FROM customer_t1;
    

    返回结果为:

    c_customer_sk | c_customer_id | c_first_name
    ---------------+---------------+--------------
            3869 | hello         | Grace
            3869 | hello         | Grace
            3869 |               | Grace
            3869 | hello         |
            6985 | maps          | Joes
            9976 | world         | James
            4421 | Admin         | Local
    (7 rows)
    
  • 执行如下命令只查询字段c_customer_sk的数据。

    SELECT c_customer_sk FROM customer_t1;
    

    返回结果为:

    c_customer_sk
    ---------------
            3869
            3869
            3869
            3869
            6985
            9976
            4421
    (7 rows)
    
  • 执行如下命令过滤字段c_customer_sk的重复数据。

    SELECT DISTINCT( c_customer_sk ) FROM customer_t1;
    

    返回结果为:

    c_customer_sk
    ---------------
            9976
            6985
            3869
            4421
    (4 rows)
    
  • 执行如下命令查询字段c_customer_sk为3869的所有数据。

    SELECT * FROM customer_t1 WHERE c_customer_sk = 3869;
    

    返回结果为:

    c_customer_sk | c_customer_id | c_first_name
    ---------------+---------------+--------------
            3869 | hello         | Grace
            3869 | hello         | Grace
            3869 |               | Grace
            3869 | hello         |
    (4 rows)
    
  • 执行如下命令按照字段c_customer_sk进行排序。

    SELECT * FROM customer_t1 ORDER BY c_customer_sk;
    

    返回结果为:

    c_customer_sk | c_customer_id | c_first_name
    ---------------+---------------+--------------
            3869 | hello         |
            3869 | hello         | Grace
            3869 |               | Grace
            3869 | hello         | Grace
            4421 | Admin         | Local
            6985 | maps          | Joes
            9976 | world         | James
    (7 rows)
    

删除表中数据

在使用表的过程中,可能会需要删除已过期的数据,删除数据必须从表中整行的删除。

SQL不能直接访问独立的行,只能通过声明被删除行匹配的条件进行。如果表中有一个主键,用户可以指定准确的行。用户可以删除匹配条件的一组行或者一次删除表中的所有行。

示例

在以下示例执行前,需按照本文开头管理表中的步骤对应数据表与数据进行创建与插入。

  • 使用DELETE命令删除行,如果删除表customer_t1中所有c_customer_sk为3869的记录:

    DELETE FROM customer_t1 WHERE c_customer_sk = 3869;
    
  • 如果执行如下命令之一,会删除表中所有的行。

    DELETE FROM customer_t2;
    

    或者

    TRUNCATE TABLE customer_t2;
    

    全表删除的场景下,建议使用truncate,不建议使用delete。

  • 删除创建的表:

    DROP TABLE customer_t1;
    

查看帮助信息

使用\?查看所有可执行的命令,使用此命令输出结果较多,会分屏显示,可以按空格键分页,按q退出当前内容查看。

\?

查看数据库

\l

列举表

\dt

查看表结构

\d tablename

列举schema

\dn

查看索引

\di

切换数据库

\c dbname

总结

vsql连接

vsql -h <IP地址> -p <端口号> -d <数据库名> -U <用户名>

创建数据库

CREATE DATABASE 数据库名

创建角色

CREATE  ROLE 角色名 WITH LOGIN PASSWORD '密码';

修改权限

ALTER USER 角色名 CREATEROLE;

管理员权限

grant all privileges TO lfx;

创建表

CREATE  TABLE 表名(字段 数据类型);

插入数据

INSERT INTO 表名(字段) VALUES (数据);

更新数据

UPDATE 表名 SET 字段 = 字段 + 100

查看表数据

SELECT * FROM 表名;

删除表字段数据

DELETE FROM 表名 字段 = xx;

删除表

DROP TABLE 表名;

创建索引

CREATE INDEX 索引名 ON 表(字段)

查看索引

\di+ 表名

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

NVM:安装配置使用(详细教程)

文章目录 一、简介二、安装 nvm三、配置 nvm 镜像四、配置环境变量五、使用教程5.1 常用命令5.2 具体案例 六、结语 一、简介 在实际的开发和学习中可能会遇到不同项目的 node 版本不同&#xff0c;而出现的兼容性问题。 而 nvm 就可以很好的解决这个问题&#xff0c;它可以在…

Spark优化----Spark 数据倾斜

目录 数据倾斜的表现&#xff1a; 定位数据倾斜问题&#xff1a; 解决方案一&#xff1a;聚合原数据 避免 shuffle 过程 缩小 key 粒度&#xff08;增大数据倾斜可能性&#xff0c;降低每个 task 的数据量&#xff09; 增大 key 粒度&#xff08;减小数据倾斜可能性&#xff0c…

第十六届蓝桥杯模拟赛(第一期)-Python

本次模拟赛我认为涉及到的知识点&#xff1a; 分解质因数 Python的datetime库 位运算 简单dp 1、填空题 【问题描述】 如果一个数 p 是个质数&#xff0c;同时又是整数 a 的约数&#xff0c;则 p 称为 a 的一个质因数。 请问 2024 有多少个质因数。 【答案提交】 这是一道结…

MATLAB2021B APP seriallist 串口通信

文章目录 前言一、项目需要二、使用步骤1.查找串口填写到查找列表2.发送函数3. 接收函数4.检测串口按钮5.选择串口号 总结 前言 提示&#xff1a;这里可以添加本文要记录的大概内容&#xff1a; 项目需要&#xff1a; 提示&#xff1a;以下是本篇文章正文内容&#xff0c;下面…

OpenShift 4 - 多云管理(2) - 配置多集群观察功能

《OpenShift / RHEL / DevSecOps 汇总目录》 本文在 OpenShift 4.17 RHACM 2.12 环境中进行验证。 文章目录 多集群观察技术架构安装多集群观察功能监控多集群的运行状态监控多集群的应用运行在被管集群监控应用运行在管理集群监控被管集群的应用运行 参考 多集群观察技术架构…

AMBA-CHI协议详解(十二)

AMBA-CHI协议详解&#xff08;一&#xff09;- Introduction AMBA-CHI协议详解&#xff08;二&#xff09;- Channel fields / Read transactions AMBA-CHI协议详解&#xff08;三&#xff09;- Write transactions AMBA-CHI协议详解&#xff08;四&#xff09;- Other transac…

【win10+RAGFlow+Ollama】搭建本地大模型助手(教程+源码)

一、RAGFlow简介 RAGFlow是一个基于对文档深入理解的开源RAG&#xff08;Retrieval-augmented Generation&#xff0c;检索增强生成&#xff09;引擎。 主要作用&#xff1a; 让用户创建自有知识库&#xff0c;根据设定的参数对知识库中的文件进行切块处理&#xff0c;用户向大…

Android中坐标体系知识超详细讲解

说来说去都不如画图示意简单易懂啊&#xff01;&#xff01;&#xff01;真是的&#xff01; 来吧先上张图&#xff01; &#xff08;一&#xff09;首先明确一下android 中的坐标系统&#xff1a; 屏幕的左上角是坐标系统原点&#xff08;0,0&#xff09; 原点向右延伸是X轴正…

IO的进阶

目录 1. 字符流转向字节流的桥梁1.1 OutputStreamWriter1.2 InputStreamReader1.3 编码与解码1.4 常见编码方式1.5 编码与解码的注意事项 2.Properties2.1概述2.2 Properties 的常用方法2.3 Properties 的应用场景2.4 实例 3.序列化3.1 ObjectOutputStream 4.字符编码4.1 ASCII…

【计算机网络】期末考试预习复习|中

作业讲解 转发器、网桥、路由器和网关(4-6) 作为中间设备&#xff0c;转发器、网桥、路由器和网关有何区别&#xff1f; (1) 物理层使用的中间设备叫做转发器(repeater)。 (2) 数据链路层使用的中间设备叫做网桥或桥接器(bridge)。 (3) 网络层使用的中间设备叫做路…

Edge Scdn用起来怎么样?

Edge Scdn&#xff1a;提升网站安全与性能的最佳选择 在当今互联网高速发展的时代&#xff0c;各种网络攻击层出不穷&#xff0c;特别是针对网站的DDoS攻击威胁&#xff0c;几乎每个行业都可能成为目标。为了确保网站的安全性与稳定性&#xff0c;越来越多的企业开始关注Edge …

UE4_控件蓝图_制作3D生命血条

一&#xff1a;效果图如下&#xff1a; 二、实现步骤&#xff1a; 1、新建敌人 右键蓝图类 选择角色&#xff0c; 重命名为BP_Enemytest。 双击打开&#xff0c;配置敌人网格体 修改位置及朝向 效果如下&#xff1a; 选择合适的动画蓝图类&#xff1a; 人物就有了动作&#x…

厦门凯酷全科技有限公司引领电商营销新风尚

在当今数字化经济快速发展的背景下&#xff0c;抖音作为领先的短视频和直播平台&#xff0c;已成为品牌推广和产品销售的重要渠道。厦门凯酷全科技有限公司&#xff08;以下简称“凯酷全”&#xff09;凭借其专业的团队和丰富的经验&#xff0c;专注于为客户提供高质量的抖音电…

高扬程潜水泵:大流量与高效率的完美结合|深圳鼎跃

洪水是由暴雨、风暴潮等等自然因素引起的江河湖海水量迅速增加或水位迅猛上涨的水流现象。一旦发生洪水事件&#xff0c;会侵袭河道沿岸的城市、农田等场景&#xff0c;在低洼地区容易形成积水&#xff0c;不仅影响人们的生活&#xff0c;还存在一定的安全风险。 高扬程潜水泵是…

神经网络基础-神经网络搭建和参数计算

文章目录 1.构建神经网络2. 神经网络的优缺点 1.构建神经网络 在 pytorch 中定义深度神经网络其实就是层堆叠的过程&#xff0c;继承自nn.Module&#xff0c;实现两个方法&#xff1a; __init__方法中定义网络中的层结构&#xff0c;主要是全连接层&#xff0c;并进行初始化。…

web网页前后端交互方式

参考该文&#xff0c; 一、前端通过表单<form>向后端发送数据 前端是通过html中的<form>表单&#xff0c;设置method属性定义发送表单数据的方式是get还是post。 如使用get方式&#xff0c;则提交的数据会在url中显示&#xff1b;如使用post方式&#xff0c;提交…

Mac配置 Node镜像源的时候报错解决办法

在Mac电脑中配置国内镜像源的时候报错,提示权限问题,无法写入配置文件。本文提供解决方法,青测有效。 一、原因分析 遇到的错误是由于 .npm 目录下的文件被 root 用户所拥有,导致当前用户无法写入相关配置文件。 二、解决办法 在终端输入以下命令,输入管理员密码即可。 su…

Linux实操篇-远程登录/Vim/开机重启

目录 传送门前言一、远程登录1、概念2、ifconfig3、实战3.1、SSH&#xff08;Secure Shell&#xff09;3.2、VNC&#xff08;Virtual Network Computing&#xff09;3.3、RDP&#xff08;Remote Desktop Protocol&#xff09;3.4、Telnet&#xff08;不推荐&#xff09;3.5、FT…

【C/C++进阶】CMake学习笔记

本篇文章包含的内容 一、CMake简介二、使用CMake构建工程2.1 一个最简单的CMake脚本2.2 使用变量和宏2.3 文件搜索 三、使用CMake制作和使用库文件3.1 静态库和动态库3.2 字符串操作3.3 CMake制作库文件3.4 CMake使用库文件3.4.1 使用link_libraries链接3.4.2 使用target_link_…

JS 生成防篡改水印

网页中有水印的需求&#xff0c;今天我们实现手写一个防篡改水印&#xff0c;先看下效果图&#xff1a; 一、创建class函数 传递一个dom为水印包裹器&#xff0c;有一些监听防篡改的observer&#xff0c;然后实例化的时候创建水印&#xff0c;执行create()方法 class WaterMa…