데이터 베이스 MySQL 튜토리얼 Oracle逗号分隔列转行实现方法

Oracle逗号分隔列转行实现方法

Jun 07, 2016 pm 06:07 PM
oracle

在做系统时,经常会遇到在一个字段中,用逗号或其他符号分隔存储多个信息,例如保存某个用户的一对多权限时,在权限组这个字段中,就会逗号分隔保存多个权限编号。

那么,现在如果给出一个权限编号,要去检索出用后这个权限的用户集合,就会需要在逗号分隔的多个权限编号中去匹配给出的这个权限编号。如果使用like去做,一则效率不高,二则匹配不精确。因此用到了逗号分隔列转行的方法。目前该方法只适合在oracle数据库中使用。该方法只需要sql语句就可以实现列转行。

  下面给出该方法的示例:

select a,b,c from
(with test as (select 'aaa' a,'bbb' b,'1,2,3' c from dual)
select a,b,substr(t.ca,instr(t.ca, ',', 1, c.lv) + 1,instr(t.ca, ',', 1, c.lv + 1) - (instr(t.ca, ',', 1, c.lv) + 1)) AS c
from (select a,b,',' || c || ',' AS ca,length(c || ',') - nvl(length(REPLACE(c, ',')), 0) AS cnt FROM test) t,
(select LEVEL lv from dual CONNECT BY LEVEL

  执行以上代码,结果如下图:

  模拟数据列 c 中的内容“1,2,3”被转成了三行,前面两列的内容同时附带过去。在实际运用时,只要把

select 'aaa' a,'bbb' b,'1,2,3' c from dual 替换成实际需要转换的数据表中的字段即可,其中c字段必须是要进行转换的保存逗号分隔内容的字段。下面的内容都可以不需要更改。其中“LEVEL

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25 : Myrise에서 모든 것을 잠금 해제하는 방법
3 몇 주 전 By 尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

SQL Plus를 사용하는 방법 SQL Plus를 사용하는 방법 Apr 09, 2025 pm 06:18 PM

SQL*Plus는 Oracle 데이터베이스와 상호 작용하기위한 명령 줄 도구입니다. 주요 기능에는 SQL 문 실행, 데이터 쿼리, 테이블 작성 및 사용자 관리가 포함됩니다. 사용하기 쉽고 크로스 플랫폼 호환성이 있으며 Oracle 데이터베이스에 대한 강력한 액세스를 제공하지만 명령 줄 인터페이스로 제한되며 그래픽 사용자 인터페이스가 부족합니다.

Navicat에서 테이블 노트를 보는 방법 Navicat에서 테이블 노트를 보는 방법 Apr 09, 2025 am 06:00 AM

NAVICAT에서 테이블 노트를 보는 방법 : 데이터베이스에 연결하고 대상 테이블로 이동하십시오. 노트 탭으로 전환하십시오. 테이블 노트가 있는지 확인하십시오.

데이터베이스에 연결하는 방법 데이터베이스에 연결하는 방법 Apr 09, 2025 am 06:45 AM

Navicat을 사용하여 데이터베이스에 연결하려면 다음 단계를 순서대로 수행하십시오. Navicat에서 연결을 만듭니다. 호스트 이름, 포트, 사용자 이름, 암호 및 데이터베이스 이름을 입력하십시오. 고급 설정 (선택 사항)을 조정하십시오. 연결을 저장하십시오. 연결을 테스트하십시오. 데이터베이스에 연결하십시오. 데이터베이스 객체를 봅니다.

다른 데이터베이스 시스템에서 열을 추가하기위한 구문의 차이점은 무엇입니까? 다른 데이터베이스 시스템에서 열을 추가하기위한 구문의 차이점은 무엇입니까? Apr 09, 2025 pm 02:15 PM

MySQL : MySQL : Alter Table_Name ADD CORMEN_NAME DATY_TYPE; POSTGRESQL : ALTER TABLE_NAME ADD CORMENT CORMENT CORMEN_NAME DATY_TYPE; ORACLE : ALTER TABLE_NAME ADD (column_name Data_Type); SQL 서버 : Alter Table_Name Data_name Data_name ADD

SQL 그래픽 도구에 열을 추가하는 방법은 무엇입니까? SQL 그래픽 도구에 열을 추가하는 방법은 무엇입니까? Apr 09, 2025 pm 12:54 PM

SQL 그래픽 도구에 열을 추가하십시오. 추가하려는 열을 선택하십시오. 마우스 오른쪽 버튼을 클릭하고 "Alter Table"또는 이와 유사한 옵션을 선택하십시오. 새 열의 속성 (이름, 데이터 유형, 길이 또는 비어 있는지)의 속성을 정의합니다. 해당되는 경우 새 열의 기본값을 지정합니다. 데이터 오류를 피하려면 적절한 데이터 유형을 선택하십시오. 의미있는 열 이름을 사용하십시오. 큰 테이블에서 열 추가 작업을 수행 할 때 성능 영향을 고려하십시오. 데이터 손실을 방지하기 위해 작업 전에 항상 데이터베이스를 백업하십시오.

Oracle에 Navicat을 사용하는 방법 Oracle에 Navicat을 사용하는 방법 Apr 09, 2025 am 07:24 AM

Oracle 용 Navicat은 다음 기능이있는 Oracle 데이터베이스 관리 도구입니다. 데이터베이스에 연결 : 연결 정보를 채우십시오. 객체 관리 : 테이블, 뷰, 인덱스 등과 같은 데이터베이스 개체를 관리합니다. SQL 쿼리 및 편집 : SQL 쿼리 작성 및 실행. 데이터 작업 :보기, 편집 및 삽입 데이터. 수입 및 내보내기 데이터 : 다양한 데이터 소스에서 데이터 가져 오기 및 내보내기 데이터.

Navicat에서 데이터베이스를 가져 오는 방법 Navicat에서 데이터베이스를 가져 오는 방법 Apr 09, 2025 am 06:27 AM

Navicat에서 데이터베이스를 가져 오는 단계에는 다음이 포함됩니다. 데이터베이스 서버에 연결하십시오. 데이터베이스 이름을 마우스 오른쪽 버튼으로 클릭하고 마법사 가져 오기를 선택하십시오. 데이터 소스 유형을 선택하십시오. 데이터 소스 설정을 지정하십시오. 데이터 파일 형식을 선택하십시오. 찾아보고 데이터 파일을 선택하십시오. 가져 오기 옵션 구성 (테이블 맵, 문자 세트, 데이터 유형). 수입 및 모니터링 진행 상황을 수행하십시오.

Navicat Premium을 활성화하는 방법 Navicat Premium을 활성화하는 방법 Apr 09, 2025 am 06:57 AM

Navicat Premium은 기능에 액세스하기 위해 활성화 할 수있는 데이터베이스 관리 도구입니다. 활성화 단계에는 라이센스 키 얻기, Navicat Premium 설치 및 라이센스 키로 활성화가 포함됩니다. 활성화 중에 문제가 발생할 때 키 입력이 올바른지 확인하고 네트워크가 연결되어 있는지 확인하십시오. 여전히 해결할 수없는 경우 기술 지원에 문의하십시오. 각 라이센스 키는 하나의 사본 만 활성화 할 수 있고, 영구 라이센스는 만료되지 않으며, 구독 라이센스를 갱신해야합니다.

See all articles