达梦数据库(DM8)常用SQL学习

这篇具有很好参考价值的文章主要介绍了达梦数据库(DM8)常用SQL学习。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

达梦产品手册

1.检查数据库版本及服务状态

1.1 查看达梦数据库运行状态

SELECT status$ as 状态 FROM v$instance;

达梦数据库(DM8)常用SQL学习

1.2 查看达梦数据库版本

SELECT banner as 版本信息 FROM v$version;

达梦数据库(DM8)常用SQL学习

2.创建用户并授权

2.1 创建用户

-- 使用 CREATE USER 语句创建 DM 用户,登录密码为 "dameng123"。
CREATE USER DM IDENTIFIED BY "dameng123";

2.2 授予用户基本权限

-- 使用GRANT语句给DM用户授予RESOURCE角色
GRANT RESOURCE TO DM;
-- 给 DM 用户授予 dmhr 用户下 employee 表的 select 权限;
GRANT SELECT ON dmhr.employee TO DM;
-- 给 DM 用户授予 dmhr 用户下 department 表的 select 权限;
GRANT SELECT ON dmhr.department TO DM;
-- 给 DM 用户授予 创建表的权限
GRANT CREATE TABLE to DM;

2.3 查看用户信息

-- 通过字典表 dba_users 查看基本信息
SELECT username,account_status,created FROM dba_users WHERE username='DM';

从输出结果看出,用户状态 account_status 为 open,输出的时间为用户的创建时间。
达梦数据库(DM8)常用SQL学习

2.4 切换用户

-- 使用 conn 命令切换用户。
conn DM/dameng123;

注意:windows系统在DM管理工具中使用该命令无法完成用户切换,直接断开登录后重新连接,更换登录用户即可。

-- 使用 user 关键字返回当前登录用户。
SELECT user FROM DUAL;

3. 表相关

3.1创建表并添加约束

-- 创建employee表
CREATE TABLE employee
(
  employee_id INTEGER,
  employee_name VARCHAR2(20) NOT NULL,
  hire_date DATE,
  salary INTEGER,
  department_id INTEGER NOT NULL
);
-- 使用 CREATE TABLE 语句创建 department 表
CREATE TABLE department
(
  department_id INTEGER PRIMARY KEY,
  department_name VARCHAR(30) NOT NULL
);
-- 非空约束
ALTER TABLE employee MODIFY( hire_date not null);
-- 主键约束
ALTER TABLE employee ADD constraint pk_empid PRIMARY KEY(employee_id);
-- 外键约束
ALTER TABLE employee ADD constraint fk_dept FOREIGN KEY (department_id) REFERENCES department (department_id);

3.2 查看表主键外键

SELECT table_name, constraint_name, constraint_type FROM all_constraints WHERE owner='DM' AND table_name='EMPLOYEE';

3.3 表字段增加

ALTER TABLE "DM"."EMPLOYEE" add "IS_REPEAT" VARCHAR(255);
COMMENT ON COLUMN "DM"."EMPLOYEE"."IS_REPEAT" IS '是否重复,1、是,0、否';

3.4 表字段删除

ALTER TABLE "DM"."EMPLOYEE" DROP COLUMN IS_REPEAT;

4. 验证数据表 CRUD 功能

-- 插入数据
INSERT INTO department VALUES(666, '数据库产品中心');
INSERT INTO employee VALUES (9999, '王达梦','2008-05-30 00:00:00', 30000, 666);
commit;
-- 因为 employee 员工表和 department 部门表存在主外键约束,所以此示例中须按顺序执行插入语句,即先在 department 表中插入数据。

-- 更新数据
UPDATE employee SET salary='35000' WHERE employee_id=9999;
commit;

-- 验证数据
SELECT salary,employee_id FROM employee;

-- 删除数据
DELETE FROM employee;
DELETE FROM department WHERE department_id=666;
commit;

-- 验证数据
SELECT * FROM employee;

5. 批量插入及选择排序

-- 在 t1 表中批量插入 100000 条数据记录。
CREATE TABLE t1 AS
     SELECT rownum AS id,
       trunc(dbms_random.value(0, 100)) AS random_id,
       dbms_random.string('x', 20) AS random_string
     FROM dual
     connect BY level <= 100000;
-- 使用 COUNT(*) 聚集函数统计 t1 表中的总数据记录。
SELECT COUNT(*) FROM t1;
-- 使用 ORDER BY 语句实现选择排序。
SELECT * FROM t1 where rownum<5 ORDER BY id DESC;

6.验证分组查询

-- 插入准备数据
INSERT INTO department (department_id, department_name)
     SELECT department_id, department_name FROM dmhr.department;
INSERT INTO employee
     (employee_id, employee_name, hire_date, salary, department_id)
     SELECT employee_id, employee_name, hire_date, salary,
     department_id FROM dmhr.employee;
commit;
SELECT dept.department_name as 部门, count(*) as 人数
     FROM employee emp, department dept
     where emp.department_id=dept.department_id
     GROUP BY dept.department_name
     HAVING count(*) > 20;

7.创建视图

-- 定义视图
CREATE OR replace VIEW v1 AS
     SELECT dept.department_name, emp.employee_name,
     emp.salary,emp.hire_date
     FROM employee emp, department dept
     WHERE salary > 10000
     AND hire_date >= '2013-08-01'
     AND emp.department_id = dept.department_id;
-- 通过视图简化查询
 SELECT * FROM v1 WHERE hire_date > '2014-09-01';

8.索引

-- 创建普通索引
CREATE INDEX ind_emp_salary ON employee(salary);
SELECT table_name, index_name, index_type
     from user_indexes WHERE index_name='IND_EMP_SALARY';
-- 删除索引
DROP INDEX IND_EMP_SALARY;

9.创建表

-- 若该表存在则删除
DROP TABLE IF EXISTS TEST_TEMP; 
-- 创建对应的表:
-- 主键自增配置  IDENTITY(1, 1),CLUSTER PRIMARY KEY("ID")
-- 自动创建时间  DEFAULT (CURDATE)
CREATE TABLE "TEST_TEMP"
(
"ID" INT IDENTITY(1, 1) NOT NULL,
"PROJECT_KEY" 	VARCHAR(100), 
"CREAT_TIME" 	DATE 			DEFAULT (CURDATE),
CLUSTER PRIMARY KEY("ID"))
STORAGE(ON "TEST", CLUSTERBTR) ;

9.1 批量插入数据

-- 语法
SET IDENTITY_INSERT [<模式名>.]<表名> ON | OFF;
-- 初始化数据,自增id赋值。需要指定列且IDENTITY_INSERT设置ON
SET IDENTITY_INSERT SYSDBA.TEST_TEMP ON;
INSERT INTO TEST_TEMP(ID,PROJECT_KEY,CREAT_TIME) VALUES (1, '测试项目', '2022-12-15 14:15:30');
-- 记得提交,否则无法真正的落库。
commit;

9.2 数据库自动新增日期

-- 自动生成日期,不带时分秒
"CREAT_TIME" 	DATE 			DEFAULT (CURDATE),
-- 自动生成日期,带时分秒
"CREAT_TIME" 	TIMESTAMP 		DEFAULT (SYSDATE),

9.3 数据库自动更新时间

通过触发器脚本实现

create trigger UPDATE_TIME_CUSTOM_NAME
before update on "DEV"."CUSTOM_NAME" for each row
begin
new.UPDATE_TIME:=sysdate;
end;

解析
UPDATE_TIME_CUSTOM_NAME:触发名称
DEV: 模式名
CUSTOM_NAME:表名称
UPDATE_TIME:字段名称
– 字段配置,自动生成日期,带时分秒
“UPDATE_TIME” TIMESTAMP DEFAULT (SYSDATE),

10. 查询表中的字段信息

-- SYSDBA为模式,TEST_TEMP 为表名称
-- 查询表字段情况,但不包含注释信息
select * from all_tab_columns where owner='SYSDBA' and Table_Name='TEST_TEMP'

达梦数据库(DM8)常用SQL学习

-- 查询表字段的注释信息
select * from dba_col_comments  where owner='SYSDBA' and Table_Name='TEST_TEMP'

达梦数据库(DM8)常用SQL学习文章来源地址https://www.toymoban.com/news/detail-428468.html

11.修改字段

11.1 修改字段名称及注释

-- 将SYSDBA模式的TEST_TEMP表中的UPDATE_TIME字段名称修改为CREATE_TIME
ALTER TABLE  "SYSDBA"."TEST_TEMP"  RENAME COLUMN "UPDATE_TIME" TO "CREATE_TIME";
COMMENT ON COLUMN "SYSDBA"."TEST_TEMP"."CREATE_TIME" IS '数据创建时间';

11.2 修改字段类型

-- 将SYSDBA模式的TEST_TEMP表中的CREATE_TIME 字段类型修改为TIMESTAMP DEFAULT SYSDATE
ALTER TABLE "SYSDBA"."TEST_TEMP" MODIFY CREATE_TIME TIMESTAMP DEFAULT SYSDATE

到了这里,关于达梦数据库(DM8)常用SQL学习的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • dmfldr-快速装载-载入(DM8:达梦数据库)

    DM 提供了快速装载工具:dmfldr; 通过使用快速装载工具能够把按照一定格式排序的文本数据以简单、快速、高效的方式载入到 DM 数据库中,或把 DM 数据库中的数据按照一定格式载出到文本文件中。 dmfldr 在一台机器上启动即可,独立完成快速装载任务,简单高效。 其中,表

    2024年02月06日
    浏览(42)
  • 开发 | JAVA连接达梦数据库(DM8)

    本文参考文献 https://eco.dameng.com/docs/zh-cn/start/java-development.html https://eco.dameng.com/docs/zh-cn/app-dev/index.html 本文通过以下方式实现Java程序与DM8数据库的交互 使用JDBC接口(不用框架,最简单) 使用MyBatis框架 使用Spring框架 使用SpringBoot Jdbc 框架 Java的软件开发工具包(SDK) JDK(Ja

    2024年02月07日
    浏览(67)
  • springboot使用达梦数据库(DM8)整合MybatisPlus

    在idea中开发spring boot项目,用到的数据库是达梦数据库,想要使用 MybatisPlus 自动生成实体类和服务,并且通过 MybatisPlus 完成一些简单的数据库CRUD ps:这里的 MybatisPlus 版本必须要是3.0以上 2.1、pom ps:其中需要将达梦数据库的依赖添加到指定目录下,不然达梦的依赖无法生效

    2024年02月16日
    浏览(52)
  • Linux安装达梦数据库/DM8(附带客户端工具安装完整版)

    1.1、创建安装与运行的Linux用户 官方也明确提出,为了减少对操作系统的影响, Linux 用户不应该已 root 用户和默认的用户组来安装与运行达梦数据库,应该为 DM 创建一个专用的用户组和系统用户。例如: 1.2、操作系统资源限制检查 这也是官方给出的提醒,在 Linux 系统中,

    2024年02月02日
    浏览(53)
  • -9501 MAL系统没有配置或者服务器不是企业版(dm8达梦数据库)

    搭建主备集群时,遇到报错-9501 MAL系统没有配置或者服务器不是企业版 检查dmmal.ini配置文件权限正确 dmdba:dinstall,内容正确 检查dm.key授权是支持主备或读写分离 检查dm.ini 参数配置 最终定位问题是 dm.ini 中 INSTANCE_NAME 参数值 与dmmal.ini 中MAL_INST_NAME 不匹配的原因,修改后启动

    2024年02月11日
    浏览(42)
  • 麒麟操作系统Kylin V10 安装达梦数据库DM8 客户端远程调试

    一、环境准备 软件名称 版本 vmware workstation 16.1.2 build-17966106 银河麒麟 Kylin-Server-10-SP2-x86-Release-Build09-20210524.iso 达梦DM8 DMInstall.bin 银河麒麟 server v10 x86架构安装iso镜像。 Kylin-Server-10-SP2-x86-Release-Build09-20210524.iso 二、DM8数据库安装 以下操作可以使用远程工具执行命令 1. 启动网络

    2024年02月04日
    浏览(94)
  • 配置ODBC驱动连接DM8数据库

    ODBC提供访问不同类型的数据库的途径。结构化查询语言 SQL 是一种用来访问数据库的语言。通过使用 ODBC,应用程序能够使用相同的源代码和各种各样的数据库交互。这使得开发者不需要以特殊的数据库管理系统 DBMS 为目标,或者了解不同支撑背景的数据库的详细细节,就能

    2024年02月16日
    浏览(48)
  • 达梦(DM)数据库存储加密

    这里主要讲述DM数据库存储加密中比较常用也比较容易理解的非透明加密相关内容。 引用官方的话说:DM 对非透明加密的支持是通过对用户提供加解密接口实现的。用户在使用非透明加密时,需要提供密钥并调用加解密接口。采用非透明加密可以保证个人私密数据不被包括

    2024年04月29日
    浏览(40)
  • 【DM】达梦数据库与MySQL适配

    新手直接看达梦入门技术文档即可 1、介绍 达梦数据库管理系统是达梦公司推出的具有完全自主知识产权的高性能数据库管理系统,简称DM,它具有如下特点: 通用性、高性能、高可用、跨平台、高可扩展 2、与MySQL的区别 (1)创建表的时候,不支持在列的后面直接加 comme

    2024年02月14日
    浏览(47)
  • SSH项目集成DM达梦数据库

    接上一篇文章【Mysql数据库迁移到达梦DM】,迁移完成后,做出的调整 目录 1.需要改成DM的连接数据的方式 2.启动项目报错 3.在做插入数据操作时报错 1.需要改成DM的连接数据的方式 2.启动项目报错 报错内容如下图 原因:没有连接上数据库,连接数据缺了compatibleMode=oracle,就

    2024年02月10日
    浏览(60)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包