1.ORACLE 索引及性能相关系统视图使用2.ORACLE闪回功能基本用法3.【检查ORACLE阻塞】如果阻塞超过N秒则发短信报警并KILL进程4.如何批量脚本停用(启用)SQL Server 和 ORACLE 数据库用户作业5.ORACLE隔离级别与脏读/不可重复读/幻读的关系以及SELECT FOR UPDATE用法6.ORACLE 中 START WITH CONNECT BY PRIOR 用法(用于父子关系的数据表查询)7.ORACLE / SQL Server-查询最终阻塞者进程脚本8.关于Oracle客户端运行SQLPlus.exe9.SQL SERVER / ORACLE 拼接多行记录字段为一个字符串的方法10.ORACLE自定义函数返回记录集(表类型)的写法11.【转】Oracle 建立索引及SQL优化12.【ORACLE】调整序列的当前种子值13.ORACLE 检索某列包含特定字符串的数据表工具存储过程14.ORACLE常用修改字段脚本15.在oracle中怎么通过字段名查询其所在的表16.ORACLE 查询所有用户调度作业17.【ORACLE】查看死锁进程并结束死锁的脚本18.Oracle获取最近执行的SQL语句19.Oracle的函数返回表类型(转)20.ORACLE变量定义及使用(另,T-SQL EXISTS的PLSQL替代写法)21.ORACLE常用脚本示例22.使用 PL/SQL Developer Version 14 调试 Oracle 存储过程23.Oracle前端工具(PL/SQL Developer)—在不安装Oracle客户端的情况下使用
24.SQL SERVER/ORACLE 将ID串列转换为多行的写法
25.ORACLE 游标和NULLIF函数在触发器中的使用26.关于“LINQ to Entities does not recognize the Method '...' ”问题原因浅析27.Oracle作业执行与SQL Develop运行语句(脚本)的区别28.ORACLE 创建表前判断是否已存在29.ORACLE 返回类型为SYS_REFCURSOR的存储过程用法30.ORACLE杂文之自定义函数与随机函数SQL SERVER 将ID串列转换为多行的写法:
select distinct a.employeeid as MANAGEREMPLOYEEID
, CAST(SUBSTRING(a.AttributeValue,number,CHARINDEX(',',a.AttributeValue+',',number)-number) AS INT) as MEMBEREMPLOYEEID
from dbo.tbEmployeeAttribute a, master..spt_values
where number >= 1
and number < len(a.AttributeValue)
and a.AttributeFlag = 15
and SUBSTRING(','+a.AttributeValue,number,1) = ',';
原表数据:


执行结果如下:

ORACLE 将ID串列转换为多行的写法:
CREATE OR REPLACE VIEW ROLE.TEAMEMEMBER AS
SELECT a.employeeid MANAGEREMPLOYEEID, b.column_value MEMBEREMPLOYEEID
FROM role.employeeattribute a
, table(CONCEPT.fnIDInString(a.attributevalue,',')) b
WHERE a.attributecode = 15;
原表数据:

SQL执行转换之后:

附录:CONCEPT.fnIDInString 自定义函数
CREATE OR REPLACE FUNCTION CONCEPT.fnIDInString(p_string IN VARCHAR2, p_delimiter IN VARCHAR2)
RETURN type_str_split
PIPELINED
AS
v_length NUMBER := LENGTH(p_string);
v_start NUMBER := 1;
v_index NUMBER;
BEGIN
WHILE(v_start <= v_length)
LOOP
v_index := INSTR(p_string, p_delimiter, v_start);
IF v_index = 0
THEN
PIPE ROW(SUBSTR(p_string, v_start));
v_start := v_length + 1;
ELSE
PIPE ROW(SUBSTR(p_string, v_start, v_index - v_start));
v_start := v_index + 1;
END IF;
END LOOP;
RETURN;
END ;
日期、时间戳和字符串互转格式:
SQL> SELECT TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SS') FROM DUAL;
-------------------------------------------------------
2023-02-14 11:44:27
SQL> SELECT TO_CHAR(SYSDATE,'YYYY-MM-DD HH24:MI:SSxFF') FROM DUAL;
-------------------------------------------------------
ORA-01821: 日期格式无法识别
SQL> SELECT TO_CHAR(current_timestamp(5),'YYYY-MM-DD HH24:MI:SSxFF') FROM DUAL;
-------------------------------------------------------
2023-02-14 11:43:45.89415
SQL> SELECT TO_DATE('2023-02-14 11:04:28','yyyy-mm-dd HH:mi:ss') FROM DUAL;
-------------------------------------------------------
2023/2/14 11:04:28
SQL> SELECT TO_DATE('2023-02-14 11:39:26.34183','YYYY-MM-DD HH24:MI:SSXFF') FROM DUAL;
-------------------------------------------------------
ORA-01821: 日期格式无法识别
SQL> SELECT TO_TIMESTAMP('2023-02-14 11:39:26.34183','YYYY-MM-DD HH24:MI:SSXFF') FROM DUAL;
-------------------------------------------------------
14-2月 -23 11.39.26.341830000 上午
SQL> SELECT TO_TIMESTAMP('2023-02-14 11:39:26','YYYY-MM-DD HH24:MI:SS') FROM DUAL;
-------------------------------------------------------
14-2月 -23 11.39.26.000000000 上午
合集:
ORACLE
, SQL SERVER
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 一个费力不讨好的项目,让我损失了近一半的绩效!
· 清华大学推出第四讲使用 DeepSeek + DeepResearch 让科研像聊天一样简单!
· 实操Deepseek接入个人知识库
· CSnakes vs Python.NET:高效嵌入与灵活互通的跨语言方案对比
· Plotly.NET 一个为 .NET 打造的强大开源交互式图表库
2011-09-19 在SilverLight4中如何让TextBox的IsReadOnly属性为True时的背景色仍然是白色(透明)的呢?