达梦(DM) SQL数据及字符串操作

2024-05-15 11:44

本文主要是介绍达梦(DM) SQL数据及字符串操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

达梦DM SQL数据及字符串操作

  • 数据操作
  • 字符串操作

这里继续讲解DM数据库的操作,主要涉及插入、更新、删除操作。

数据操作

插入数据,不指定具体列的话就需要插入除自增列外的其他列,当然自增列也可以直接指定插入

INSERT INTO SYS_USER VALUES(110,'test002','test002','00',null,'13522266688',0,null,'dfhgjhsfjg','12323',0,0,null,null,'test002','2023-10-23 10:11:11',null,null,null);

执行成功后查看数据
在这里插入图片描述
插入多行,比如创建测试表

CREATE TABLE testASSELECT user_id,user_name,login_name,phonenumber,dept_idFROM sys_userWHERE 1 = 2;

创建成功后查询可以看到表创建成功,带WHERE 1 = 2条件的话,实测是只创建指定字段表结构,不带WHERE条件的话会携带对应字段的数据
在这里插入图片描述

CREATE TABLE test1ASSELECT user_id,user_name,login_name,phonenumber,dept_idFROM sys_user;

执行结果
在这里插入图片描述
批量插入test表数据

insert into test VALUES (1,'test','test','13511122211',1),(2,'test1','test1','13511122222',1),(3,'test2','test2','13511122233',1);

执行成功后
在这里插入图片描述
可以按指定列插入行,未指定值的列上若定义了默认值,则插入默认值。没有指定默认值,为 NULL,则插入 NULL 值

insert into test (user_id,login_name) VALUES (4,'test3'),(5,'test4');

执行结果如图
在这里插入图片描述
如需快速复制表结构且不需要数据,如需表机构和数据的话 WHERE 1 = 1; 或者不要WHERE条件

CREATE TABLE test2 AS SELECT * FROM test WHERE 1 = 0;

查询表数据库看到
在这里插入图片描述
使用 SP_TABLEDEF 过程查看 test2 的结构,所有定义在 test 列上的约束均没有被新表继承。
为表语句添加约束条件

ALTER TABLE test  ADD PRIMARY KEY (user_id);
ALTER TABLE test  ALTER COLUMN user_name SET DEFAULT 'dm2020';
ALTER TABLE test  ALTER COLUMN login_name SET NOT NULL;
ALTER TABLE test  ALTER COLUMN phonenumber SET DEFAULT '13511122255';

使用 MERGE INTO 语法可合并 UPDATE 和 INSERT 语句,使用 MERGE 可以实现记录“存在则 update,不存在则 insert”的逻辑。
通过 group by + having 子句分组查询的方式,查找员工名称相同的记录

select user_name,count(*) FROM TEST group by USER_NAME HAVING count(*)>1;

查询结果如图
在这里插入图片描述
查询重复数据,通过 group by + rowid 的方式,查找员工名称重复的记录

select * from test where ROWID not in (select max(ROWID) from test group by user_name);

查找到重复记录后直接删除

delete from test where ROWID not in (select max(ROWID) from test group by user_name);

执行完再查询发现重复的1 2 3 4 已经删除了
在这里插入图片描述

字符串操作

使用函数 regexp_count、regexp_replace 或 translate 统计字符串个数
创建视图

CREATE OR REPLACE VIEW v AS SELECT 'STUDENT,TEACHER,TEAM' AS str FROM DUAL;
select * from V;

看到创建成功的视图
在这里插入图片描述
使用函数 regexp_count 统计子串个数

SELECT regexp_count(str,',')+1 as cnt FROM v;

执行结果如图
在这里插入图片描述
使用 regexp_replace 迂回求值统计子串个数

SELECT length(regexp_replace(str,'[^,]'))+1 as cnt FROM v;

使用 translate 统计子串个数

SELECT length(translate(str,',' || str,','))+1 AS cnt FROM v;

使用 translate 或者 regexp_replace 在某个字段中去掉不需要的字符,先创建视图

CREATE OR REPLACE VIEW vASSELECT 'CLARK' ename FROM DUALUNION ALLSELECT 'MILLER' FROM DUALUNION ALLSELECT 'KING' FROM DUAL;

创建成功如图
在这里插入图片描述
去掉ename中的元音字母

SELECT ename,translate(ename,'1AEIOU','1') stripped1 FROM v;

可以看到元音字母已经去掉了
在这里插入图片描述
使用正则函数 regexp_replace [] 内列举的字符替换为空

SELECT ename,regexp_replace(ename,'[AEIOU]') AS stripped FROM v;

使用 regexp_replace 正则表达式实现字符串中字符与数字分离,创建测试视图

CREATE OR REPLACE VIEW vASSELECT 'CLARK10' data FROM DUALUNION ALLSELECT 'MILLER20' FROM DUALUNION ALLSELECT 'KING30' FROM DUAL;

查询结果如图
在这里插入图片描述
使用 regexp_replace 正则表达式

SELECT REGEXP_REPLACE (data, '[0-9]', '') dname,REGEXP_REPLACE (data, '[^0-9]', '') deptnoFROM v;

执行结果如图
在这里插入图片描述
使用 regexp_like 实现查询只包含字母或者数字型的数据,创建测试视图

  CREATE OR REPLACE VIEW vASSELECT '123' AS data FROM DUALUNION ALLSELECT 'abc' FROM DUALUNION ALLSELECT '123abc' FROM DUALUNION ALLSELECT 'abc123' FROM DUALUNION ALLSELECT 'a1b2c3' FROM DUALUNION ALLSELECT 'a1b2c3#' FROM DUALUNION ALLSELECT '3$' FROM DUALUNION ALLSELECT 'a 2' FROM DUAL;

查询执行结果如图
在这里插入图片描述
在上面的语句中,有些数据包含了空格、逗号、$ 等字符。现在要求只返回其中只有字母及数字的行,使用 regexp_like 语句

SELECT data FROM v WHERE REGEXP_LIKE (data, '^[0-9a-zA-Z]+$');

查询结果如图
在这里插入图片描述
注意下方内容
在这里插入图片描述
通过正则表达式或者 translate 函数实现按字符串中的数值排序,创建视图

CREATE OR REPLACE VIEW vASSELECT 'ACCOUNTING 10 NEW YORK' data FROM DUALUNION ALLSELECT 'OPEARTINGS 40 BOSTON' FROM DUALUNION ALLSELECT 'RESEARCH 20 DALLAS' FROM DUALUNION ALLSELECT 'SALES 30 CHICAGO' FROM DUAL;

执行后查询结果如图
在这里插入图片描述
用正则表达式替换非数字字符

SELECT data, TO_NUMBER (REGEXP_REPLACE (data, '[^0-9]', '')) AS deptno FROM V ORDER BY 2;

执行结果如图
在这里插入图片描述
使用 translate 函数,直接替换掉非数字字符

SELECT data,TO_NUMBER (TRANSLATE (data, '0123456789' || data, '0123456789'))AS deptno FROM V ORDER BY 2;

通过 listagg 分析函数实现多行字段的合并显示,创建视图

CREATE OR REPLACE VIEW vASSELECT '10' deptno, 'CLARK' name, '800' sal FROM DUALUNION ALLSELECT '10', 'KING', '900' FROM DUALUNION ALLSELECT '20', 'JAMES', '1000' FROM DUALUNION ALLSELECT '20', 'KATE', '2000' FROM DUALUNION ALLSELECT '30', 'JONES', '1150' FROM DUAL;

执行结果如图
在这里插入图片描述
使用 listagg 分析函数实现合并显示

SELECT deptno,SUM (sal) AS total_sal,LISTAGG (name, ',') WITHIN GROUP (ORDER BY name) AS total_name FROM v GROUP BY deptno;

执行结果如图
在这里插入图片描述
同 sum 一样,listagg 函数也起到汇总结果作用。sum 将数值结果累计求和,而 listagg 是把字符串的结果连在一起。
通过 regexp_substr 实现第 n 个子串的分割,创建测试视图

CREATE OR REPLACE VIEW v AS SELECT 'CLARK,KATE,JAMES''CLARK,KATE,JAMES' AS name;

执行结果如图
在这里插入图片描述
使用 regexp_substr 分割子串

SELECT REGEXP_SUBSTR (v.name,'[^,]+',1,2) AS 子串 FROM v;

执行结果如图
在这里插入图片描述
说明:
参数 1:“^”在方括号里表示否的意思,+ 表示匹配 1 次以上。第二个参数表示匹配不包含逗号的多个字符。
参数 2:“1”表示从第一个字符开始。
参数 3:“2”表示第二个能匹配目标的字符串,也就是 KATE。

使用 regexp_substr 实现字符串拆分。比如将 IP 地址“192.168.1.111”中的各段取出来

SELECT REGEXP_SUBSTR (v.ip,'[^.]+',1,1)a,REGEXP_SUBSTR (v.ip,'[^.]+',1,2)b,REGEXP_SUBSTR (v.ip,'[^.]+',1,3)c,REGEXP_SUBSTR (v.ip,'[^.]+',1,4)dFROM (SELECT '192.168.1.111' AS ip FROM DUAL) v;

执行结果如图
在这里插入图片描述
到这里数据新增,修改,删除的操作以及字符串的相关操作就介绍完了。

这篇关于达梦(DM) SQL数据及字符串操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/991745

相关文章

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

MySQL中between and的基本用法、范围查询示例详解

《MySQL中betweenand的基本用法、范围查询示例详解》BETWEENAND操作符在MySQL中用于选择在两个值之间的数据,包括边界值,它支持数值和日期类型,示例展示了如何使用BETWEEN... 目录一、between and语法二、使用示例2.1、betwphpeen and数值查询2.2、be

MySQL快速复制一张表的四种核心方法(包括表结构和数据)

《MySQL快速复制一张表的四种核心方法(包括表结构和数据)》本文详细介绍了四种复制MySQL表(结构+数据)的方法,并对每种方法进行了对比分析,适用于不同场景和数据量的复制需求,特别是针对超大表(1... 目录一、mysql 复制表(结构+数据)的 4 种核心方法(面试结构化回答)方法 1:CREATE

Go异常处理、泛型和文件操作实例代码

《Go异常处理、泛型和文件操作实例代码》Go语言的异常处理机制与传统的面向对象语言(如Java、C#)所使用的try-catch结构有所不同,它采用了自己独特的设计理念和方法,:本文主要介绍Go异... 目录一:异常处理常见的异常处理向上抛中断程序恢复程序二:泛型泛型函数泛型结构体泛型切片泛型 map三:文

详解C++ 存储二进制数据容器的几种方法

《详解C++存储二进制数据容器的几种方法》本文主要介绍了详解C++存储二进制数据容器,包括std::vector、std::array、std::string、std::bitset和std::ve... 目录1.std::vector<uint8_t>(最常用)特点:适用场景:示例:2.std::arra

SQL Server中行转列方法详细讲解

《SQLServer中行转列方法详细讲解》SQL行转列、列转行可以帮助我们更方便地处理数据,生成需要的报表和结果集,:本文主要介绍SQLServer中行转列方法的相关资料,需要的朋友可以参考下... 目录前言一、为什么需要行转列二、行转列的基本概念三、使用PIVOT运算符进行行转列1.创建示例数据表并插入数

MySQL MHA集群详解(数据库高可用)

《MySQLMHA集群详解(数据库高可用)》MHA(MasterHighAvailability)是开源MySQL高可用管理工具,用于自动故障检测与转移,支持异步或半同步复制的MySQL主从架构,本... 目录mysql 高可用方案:MHA 详解与实战1. MHA 简介2. MHA 的组件组成(1)MHA

SQL 注入攻击(SQL Injection)原理、利用方式与防御策略深度解析

《SQL注入攻击(SQLInjection)原理、利用方式与防御策略深度解析》本文将从SQL注入的基本原理、攻击方式、常见利用手法,到企业级防御方案进行全面讲解,以帮助开发者和安全人员更系统地理解... 目录一、前言二、SQL 注入攻击的基本概念三、SQL 注入常见类型分析1. 基于错误回显的注入(Erro

MySQL基本表查询操作汇总之单表查询+多表操作大全

《MySQL基本表查询操作汇总之单表查询+多表操作大全》本文全面介绍了MySQL单表查询与多表操作的关键技术,包括基本语法、高级查询、表别名使用、多表连接及子查询等,并提供了丰富的实例,感兴趣的朋友跟... 目录一、单表查询整合(一)通用模版展示(二)举例说明(三)注意事项(四)Mapper简单举例简单查询

Nginx概念、架构、配置与虚拟主机实战操作指南

《Nginx概念、架构、配置与虚拟主机实战操作指南》Nginx是一个高性能的HTTP服务器、反向代理服务器、负载均衡器和IMAP/POP3/SMTP代理服务器,它支持高并发连接,资源占用低,功能全面且... 目录Nginx 深度解析:概念、架构、配置与虚拟主机实战一、Nginx 的概念二、Nginx 的特点