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

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

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

뜨거운 주제











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

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

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

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

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

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

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