九天猎人 发表于 2024-8-27 06:03:07

达梦数据库建表空间建用户建数据库(命令行操作)

一、创建表空间

1.切换用户dmdba (用户创建在:达梦数据库安装)

        su - dmdba
2.进入数据库体系用户SYSDBA下操作

         cd dmdbms/bin
         ./disql
        输入用户名暗码即可进入
        https://i-blog.csdnimg.cn/direct/62a48c4f3cd44811895e4148f82f0ff6.png
3.创建表空间

使用SYSDBA用户登录后,首先先创建表空间,由于给存储表
使用命令创建表空间 DMTEST, 指定数据库文件为 '/dmdata/data/DAMENG/DMTEST.DBF',初始大小为 128M,其它默认,示比方下:
create tablespace "DMTEST" datafile '/dmdata/data/DAMENG/DMTEST.DBF' size 128 ;
        注:/dmdata/data文件夹权限已在创建dmdba用户时给过了

https://i-blog.csdnimg.cn/direct/5cb8231653e3415cbad795227fc8504f.png

   添加的数据文件大小最小为 4096*页大小,如页大小为 8K,则可添加的文件最小值为 4096*8k=32M。上图中文件最小为 128 MB,对应页大小为 32 KB。
初始化页大小的选择不仅影响表空间数据文件的大小选择,也会对表中每个字段及每条记载产生限制,如下表所示:
数据库页大小每个字符类型字段实际最大长度(字节)每行记载最大字段外其他字段总长度(字节)表空间单个数据文件最小 (MB)/最大 (MB)4 KB1938204716/83886088 KB3878409532/1677721616 KB8000819564/3355443232 KB818816176128/67108864 页大小在初始化数据库时设置,详见配置实例-数据库初始化参数章节。

4.修改表空间

可根据项目需要,修改表空间文件、路径、大小、是否主动扩充、扩充上限等信息,
命令行修改表空间,打开主动扩展,每次主动扩展 100M ,扩展上限 10240M,参考示比方下:
alter tablespace "DMTEST" datafile '/dmdata/data/DAMENG/DMTEST.DBF' autoextend on next 100 maxsize 10240; 主动扩展默认为打开状态,每次主动扩展大小和扩展上限请根据实际业务需求设置。
5.设置加密算法,暗码

可根据项目需要,设置加密算法、加密暗码等信息,该设置均可为空
创建表空间 DMTEST, 指定数据库文件为 '/dmdata/data/DAMENG/DMTEST.DBF',初始大小为 128M,打开主动扩展,每次主动扩展 100M ,扩展上限 10240M,使用 RC4 加密算法。使用命令行方式创建示例表空间如下:
create tablespace "DMTEST" datafile '/dmdata/data/DAMENG/DMTEST.DBF' size 128 autoextend on next 100 maxsize 10240 CACHE = NORMAL encrypt with RC4;

二、创建用户

1.新建用户

使用 SYSDBA 用户登录
使用命令行方式创建用户 DMTEST,暗码 “Dameng@123”,使用散列算法 SHA512 ,使用存储加密密钥为 “123456”(可选择不加),指定表空间为 DMTEST,索引表空间为 DMTEST,授予 “PUBLIC”,"RESOURCE" 和 “SOI” 权限。示例参考如下:
create user "DMTEST" identified by "Dameng@123" hash with SHA512 salt
encrypt by "123456"
default tablespace "DMTEST"
default index tablespace "DMTEST";         注:这几行代码需要放一行执行!!!
grant "PUBLIC","RESOURCE","SOI" to "DMTEST";  注:授权有 DBA,PUBLIC,RESOURCE,SOI,SVI,VIT ;
1. DBA(Database Administrator)


[*]定义:DBA是数据库管理员的缩写,具备数据库中的最高级别权限。
[*]权限内容:DBA险些拥有创建数据库的全部权限,包括创建新的数据库、管理用户权限、备份和规复数据库、监控和优化数据库性能、管理数据库的安全性和完备性等。DBA可以创建数据库实例、数据库表、数据库对象等,并管理全部用户和他们的权限。
[*]作用:DBA是数据库体系的核心管理者,负责确保数据库的正常运行和安全性。
2. PUBLIC


[*]定义:PUBLIC是一个特殊的角色,它代表数据库中的全部用户。
[*]权限内容:PUBLIC角色具有一些基本的、默认的权限,重要是对自己模式下操作数据的权限。但需要注意的是,PUBLIC角色本身并不直接授予用户创建数据库对象或执行高级管理操作的权限。
[*]作用:PUBLIC角色提供了一种统一的管理方式,使得数据库管理员可以为全部用户设置一些基本的、共通的权限。
3. RESOURCE


[*]定义:RESOURCE是一个预定义的角色,用于管理数据库对象。
[*]权限内容:RESOURCE角色具有在自己模式下创建表、视图等对象的权限,也具有操作自己模式下对象数据的权限。但是,它不能创建数据库布局,如数据库实例或数据库本身。
[*]作用:RESOURCE角色为普通用户提供了在数据库中举行日常操作所需的权限,如数据录入、查询等。
4. SOI(System Object Inspector)


[*]定义:SOI是一个特殊的角色,用于查询体系表。
[*]权限内容:SOI角色具有查询体系表(通常是SYS开头的表)的权限。这些体系表包含了数据库的元数据信息,如数据库布局、对象定义等。
[*]作用:SOI角色允许用户查询数据库的元数据信息,有助于相识数据库的布局和对象定义。
5. SVI 和 VIT


[*]注意:在达梦数据库的官方文档和常见资料中,SVI和VIT并不是标准的预定义角色。这大概是因为它们是在特定环境或版本中自定义的角色,或者是用户误将其他角色名称(如VTI)与SVI和VIT肴杂。
[*]发起:如果SVI和VIT是在您的数据库环境中自定义的角色,那么它们的权限将取决于创建这些角色时所赋予的权限。发起查阅相干的数据库角色配置文档或接洽数据库管理员以获取准确信息。
6. VTI(View Table Inspector)


[*]定义(基于您提到的大概肴杂):固然VTI不是达梦数据库的标准预定义角色,但根据一些资料,它大概代表具有查询动态视图相干权限的角色。
[*]权限内容:如果VTI确实存在且代表如许的角色,那么它将具有查询体系动态视图的权限。动态视图通常包含数据库的实时状态信息,如性能统计、执行筹划等。
[*]作用:VTI角色允许用户查询数据库的实时状态信息,有助于举行性能调优和故障排查。
综上所述,DBA、PUBLIC、RESOURCE和SOI是达梦数据库中常见的预定义角色,它们各自具有不同的权限和作用。而SVI和VIT大概是特定环境或版本中的自定义角色,或者是其他角色的误称。对于VTI角色,固然它不是标准预定义角色,但根据描述大概代表具有查询动态视图权限的角色。
三、创建数据库对象

一、创建表

在模式 DMTEST 下创建表 SYS_ROLE,并插入数据。示例语句如下所示:
切换到DMTEST用户下

CREATE TABLE   "SYS_ROLE"
(
"ROLE_ID" INT IDENTITY(1, 1) NOT NULL,
"ROLE_NAME" VARCHAR(200) NOT NULL,
"ROLE_CODE" VARCHAR(200) NOT NULL,
"COMMENTS" VARCHAR(400),
"DELETED" INT DEFAULT 0 NOT NULL,
"TENANT_ID" INT DEFAULT 1 NOT NULL,
"CREATE_TIME" TIMESTAMP(6) DEFAULT CURRENT_TIMESTAMP NOT NULL,
"UPDATE_TIME" TIMESTAMP(6) DEFAULT CURRENT_TIMESTAMP NOT NULL,
NOT CLUSTER PRIMARY KEY("ROLE_ID"))   ;
COMMENT ON TABLE "SYS_ROLE" IS '角色';
COMMENT ON COLUMN   "SYS_ROLE"."COMMENTS" IS '备注';
COMMENT ON COLUMN   "SYS_ROLE"."CREATE_TIME" IS '创建时间';
COMMENT ON COLUMN   "SYS_ROLE"."DELETED" IS '是否删除, 0否, 1是';
COMMENT ON COLUMN   "SYS_ROLE"."ROLE_CODE" IS '角色标识';
COMMENT ON COLUMN   "SYS_ROLE"."ROLE_ID" IS '角色id';
COMMENT ON COLUMN   "SYS_ROLE"."ROLE_NAME" IS '角色名称';
COMMENT ON COLUMN   "SYS_ROLE"."TENANT_ID" IS '租户id';
COMMENT ON COLUMN   "SYS_ROLE"."UPDATE_TIME" IS '修改时间';

INSERT INTO  SYS_ROLE(role_name,role_code,comments,deleted,tenant_id,create_time,update_time)  VALUES ('管理员', 'admin', '管理员', 0, 1, '2020-02-26 15:18:37', '2020-03-21 15:15:54');
 
https://i-blog.csdnimg.cn/direct/8125bd20f9ee4e6cb416520698e4948b.png




免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页: [1]
查看完整版本: 达梦数据库建表空间建用户建数据库(命令行操作)