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

news2025/2/2 18:48:27

达梦产品手册

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

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

SELECT status$ as 状态 FROM v$instance;

windows上DM8执行结果

1.2 查看达梦数据库版本

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

windows上DM8执行结果

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,输出的时间为用户的创建时间。
在这里插入图片描述

2.4 切换用户

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

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

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

3. 创建表并添加约束

-- 创建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';

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) ;

初始化数据

-- 语法
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;

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

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

相关文章

Python爬虫详解

从今天开始&#xff0c;给大家介绍Python爬虫相关知识&#xff0c;今天主要内容是爬虫的基础理论知识。 一、爬虫简介 爬虫是指通过编写程序&#xff0c;来模拟浏览器访问Web网页&#xff0c;然后通过一定的策略&#xff0c;爬取指定内容。因此&#xff0c;爬虫的编写通常分为…

Nature Communications:人类丘脑的基因结构及其与十种常见大脑疾病的重叠

丘脑是位于大脑中心的重要交流中枢&#xff0c;由不同的核组成&#xff0c;对意识和高级皮层功能至关重要。丘脑结构和功能的改变涉及到常见的大脑疾病的发病机制&#xff0c;但丘脑的遗传结构仍然很大程度上未知。在这里&#xff0c;使用来自30114个个体的大脑扫描和基因型数据…

【Linux】进程创建、进程终止、进程等待

目录 一、进程创建 1.1 深入 fork 函数 1.2 写时拷贝 二、进程终止 2.1 进程退出码 2.2 exit 与 _exit 三、进程等待 3.1 进程等待必要性 3.2 进程等待 3.2 wait 与 waitpid 3.3 获取子进程 status 3.4 非阻塞等待 一、进程创建 1.1 深入 fork 函数 在 Linux 中…

如何对图片进行旋转?这些工具能将图片进行旋转

大家平时在日常生活中有没有遇到这种情况&#xff1a;从网上保存下来的图片发现角度方向是错误的&#xff0c;或者是从相机导入拍摄的图片&#xff0c;打开图片发现它们的方向不统一&#xff0c;不方便我们进行观看。这时需要我们对图片进行旋转操作&#xff0c;才能将图片摆正…

图表控件LightningChart.NET 系列教程(四):安装

LightningChart.NET SDK 是一款高性能数据可视化插件工具&#xff0c;由数据可视化软件组件和工具类组成&#xff0c;可支持基于 Windows 的用户界面框架&#xff08;Windows Presentation Foundation&#xff09;、Windows 通用应用平台&#xff08;Universal Windows Platfor…

Linux 内核网络栈分析: 接收数据

引言 对于内核网络栈的分析我在大二听了李勇大神来小组的讲座以后就想干了&#xff0c;但像很多主题的文章一样&#xff0c;始终没有勇气&#xff0c;也没有时间动手&#xff0c;我终究还是把这个话题从大二延到大三&#xff0c;从大三延到大四了。冥冥之中某种东西好像早已是…

Python 帮同事用pandas快速筛选Excel文件

同事正在为怎样处理一个18万行的全年财务Excel文件发愁&#xff0c;文件足足有30M&#xff0c;打开文件也要两三分钟&#xff0c;于是他就向我求助。大概意思就是要筛选出Data工作簿“源数据”Sheet中所有收款人对应的付款人及付款笔数、金额小计&#xff0c;于是我简化做了一个…

【RuoYi-Vue-Plus】学习笔记 45 - Spring 事件监听器 @EventListener 注解简单分析

文章目录前言参考目录测试方法配置说明测试方法功能调用流程分析事件监听器初始化事件发布流程前言 因为之前比较忙所以匿了一段时间&#xff0c;顺便当了神雕大侠&#xff08;“阳过”&#xff09;。前段时间框架已经发布了新版本 V4.4.0&#xff0c;而在最新的 dev 分支中使…

labelImg数据标注及yolov5的训练和测试

labelImg数据标注及yolov5的训练和测试 一、labelImg数据标注的使用 数据标注主要针对于哪个地方是什么&#xff0c;一般像隐私类的是不能标注的&#xff0c;如鲁迅的故居可以标&#xff0c;但是张三的住所就不能进行标注。 labelImg是数据标注主要使用的工具。 1、首先使用…

第十四章 概率图模型

14.1 隐马尔可夫模型 机器学习最重要的任务&#xff0c;是根据一些已观察到的证据&#xff08;例如训练样本&#xff09;来对感兴趣的未知变量&#xff08;例如类别标记&#xff09;进行估计和推测。概念模型提供了一种描述框架&#xff0c;将学习任务归结于计算变量的概率分布…

ffmpeg-AVPacket

目录 引子 翻译一下官方注释&#xff1a; 成员变量&#xff1a; AVBufferRef *buf pts dts data size stream_index flag side_data side_data_elems duration pos opaque opaque_ref time_base 引子 AVPacket是ffmpeg基础且非常重要的数据结构…

我国脐橙行业现状:种植面积、产量及市场规模不断增长 江西赣州是最大生产区

根据观研报告网发布的《2022年中国脐橙市场分析报告-市场全景评估与发展定位研究》显示&#xff0c;脐橙是芸香科&#xff0c;属柑橘亚科&#xff0c;是柑橘属植物甜橙的一类栽培品种&#xff0c;果皮难或稍易剥离&#xff0c;瓢囊9-12瓣&#xff0c;果心实或半充实&#xff0c…

ChatGPT

ChatGPT是由OpenAI开发的一个人工智能聊天机器人程序&#xff0c;于2022年11月推出。该程序使用基于GPT-3.5架构的大型语言模型并通过强化学习进行训练。目前&#xff0c;有部分地区&#xff08;例如中国大陆、香港&#xff09;无法使用此项服务&#xff0c;这里我就介绍一下中…

代码随想录训练营第55天|LeetCode 583. 两个字符串的删除操作、72. 编辑距离

参考 代码随想录 题目一&#xff1a;LeetCode 583. 两个字符串的删除操作 确定dp数组下标及其含义 为了方便dp数组的初始化&#xff0c;在整个分析问题的过程中在word1和word2的最前面添加空字符&#xff0c;注意&#xff0c;不是真正的添加&#xff0c;只是这么认为。 dp[i]…

大学英语笔记

words in use unit 1 The mayor condenseIt was reported exceedresearchers put deficittoo much————exposuremoving forward managerialthe lawyer adequateto help the competentmost parents&#xff0c;&#xff0c;&#xff0c;adjustingyou can count preciselyin …

工控CTF之协议分析8——特殊隧道

协议分析 流量分析 主要以工控流量和恶意流量为主&#xff0c;难度较低的题目主要考察Wireshark使用和找规律&#xff0c;难度较高的题目主要考察协议定义和特征 简单只能简单得干篇一律&#xff0c;难可以难得五花八门 常见的工控协议有&#xff1a;Modbus、MMS、IEC60870、…

Python爬虫学习

文章目录前言概述简单爬虫requests模块⼊⻔数据解析re解析re模块总结前言 本博客仅做学习笔记&#xff0c;如有侵权&#xff0c;联系后即刻更改 科普&#xff1a; 学习参考网站 概述 安全 爬⾍在法律上是不被禁⽌的 像王欣说过,技术是⽆罪的. 主要看你⽤它来⼲嘛 robots.tx…

经纬恒润以太网开发及测试方案,助力智能汽车落地

近年来&#xff0c;为了满足智能网联汽车的开发要求&#xff0c;车载以太网技术开始逐渐进入人们的视野。车载以太网可以满足带宽密集型应用如高级驾驶辅助系统&#xff08;ADAS&#xff09;、车载诊断系统&#xff08;OBD&#xff09;以及车载信息娱乐系统等所需的更高数据传输…

controlsfx框架NotificationPane组件的使用

controlsfx 是javaFx开源UI框架&#xff0c;里面有很多默认组件的补充&#xff0c;最近在使用其中的NotificationPane组件时&#xff0c;遇到一些问题&#xff0c;记录下来。 官方demo链接&#xff1a; https://github.com/controlsfx/controlsfx/blob/jdk-8/controlsfx-samp…

Unittest接口自动化分享

一、环境搭建 1. Python安装 1. 1Python&#xff08;3.6.8版本&#xff09; 下载地址 https://www.python.org/downloads/release/python-368/ 1.1.1 Windows系统 1. 下载1. 对前缀的说明&#xff1a;​ 以Windows x86-64开头的是 64 位的 Python 安装程序&#xff1b;​ …