컴퓨터일반/DB (6) 썸네일형 리스트형 [Oracle] NUMBER 컬럼 사이즈 변경 시 "데이터가 있으면 축소 불가" 해결 방법 오라클 데이터베이스를 운영하다 보면 테이블 설계 변경으로 인해 숫자형(NUMBER) 컬럼의 사이즈를 조정해야 할 때가 있습니다. 하지만 데이터가 이미 들어있는 상태라면 마음대로 변경되지 않아 당황스러운 경우가 생기죠.오늘은 NUMBER 컬럼 사이즈 변경 시 발생하는 오류 원인과 최신 버전에서도 통용되는 해결 팁을 정리해 보겠습니다.1. 왜 오류가 발생할까? (ORA-01440)데이터가 존재하는 컬럼의 사이즈를 줄이려고 하면 오라클은 다음과 같은 오류를 뱉어냅니다.ORA-01440: column to be modified must be empty to decrease precision or scale (정밀도 또는 스케일을 축소할 열은 비어 있어야 합니다)이 오류는 단순히 전체 자릿수를 줄일 때뿐만 아니라.. [MSSQL] 데이터베이스 내 모든 테이블 및 객체 일괄 삭제 방법 (최신 버전 완벽 정리) 개발이나 테스트 과정을 반복하다 보면 데이터베이스의 모든 테이블을 삭제하고 초기화해야 할 때가 있습니다. 하지만 테이블이 수십 개가 넘어가면 일일이 DROP TABLE을 입력하기란 쉽지 않죠.오늘은 MSSQL(SQL Server)에서 시스템 프로시저를 이용하는 간편한 방법부터, 최신 버전에서 권장하는 카탈로그 뷰 활용 방법까지 정리해 보겠습니다.⚠️ 주의사항 (필독)이 작업은 실행 즉시 데이터와 구조가 영구적으로 삭제됩니다. 복구가 불가능하므로, 운영 서버가 아닌 반드시 테스트 환경에서만 사용하시기 바랍니다. 실행 전 백업 여부를 반드시 확인하세요!1. 시스템 프로시저 sp_MSforeachtable 사용하기Microsoft에서 공식적으로 지원 문서를 제공하지는 않지만, 오랫동안 널리 쓰여온 미등록(Un.. [MSSQL] 대용량 데이터 페이징 처리 성능 최적화 가이드 데이터베이스의 규모가 커질수록 SELECT *로 모든 데이터를 가져오는 것은 불가능에 가깝습니다.수백만 건의 데이터 중 사용자가 보고 있는 10~20건만 효율적으로 골라내는 MSSQL 페이징 기법 3가지를 소개합니다.1. OFFSET-FETCH (SQL Server 2012 이상 권장)ANSI 표준이며 현재 MSSQL에서 가장 권장되는 방식입니다. 구문이 직관적이고 가독성이 매우 높습니다.특징: 반드시 ORDER BY 절과 함께 사용해야 합니다.장점: 코드가 간결하며 유지보수가 쉽습니다.SQL -- 11번째부터 10개의 행을 가져오는 예시 (Page 2)SELECT *FROM OrdersORDER BY OrderDate DESC, OrderID ASCOFFSET 10 ROWS FETCH NEXT 10 R.. [Oracle]오라클 대용량 데이터 페이징 처리 완벽 가이드 대용량 테이블에서 단순히 SELECT를 수행하면 전체 데이터를 읽어오느라 성능이 급격히 저하됩니다.사용자가 필요한 범위만큼만 데이터를 끊어서 가져오는 효율적인 페이징 기법 3가지를 소개합니다.1. ROWNUM과 인라인 뷰를 이용한 전통적 방식 (Oracle 11g 이전)오라클 11g 이하 버전에서 가장 많이 사용되던 방식입니다.ROWNUM은 행이 추출되는 순서대로 번호를 부여하는 가상 컬럼입니다.구현 원리: 정렬된 서브쿼리(인라인 뷰)를 먼저 실행한 후, ROWNUM으로 범위를 지정합니다.특징: 반드시 2중 중첩 구조를 사용해야 합니다. WHERE ROWNUM > 10과 같은 조건은 첫 번째 행부터 체크하기 때문에 직접 사용하면 결과가 나오지 않기 때문입니다.SQL SELECT * FROM ( SE.. [Oracle] 정규식(Regex)으로 문자열에서 숫자만 추출 & 제거하는 방법 데이터 정제(Cleaning) 작업을 하다 보면 010-1234-5678 같은 연락처에서 하이픈(-)을 제거하고 숫자만 남기거나, 주소에서 번지수를 제외한 텍스트만 추출해야 하는 경우가 많습니다.오라클의 REGEXP_REPLACE 함수를 사용하면 복잡한 REPLACE 중첩 없이 한 줄의 쿼리로 해결할 수 있습니다.1. 기본 함수 구조: REGEXP_REPLACE정규표현식을 지원하는 치환 함수입니다.SQL REGEXP_REPLACE(대상문자열, '패턴', '치환할문자')2. 문자열에서 "숫자만" 추출하기숫자가 아닌 모든 문자를 찾아 공백('')으로 치환하여 없애버리는 원리입니다.정규식 패턴: [^0-9] 또는 [^[:digit:]]^: 패턴의 시작 부분에서 사용되면 'NOT(부정)'을 의미합니다. 즉, 숫.. [Oracle] "아차!" 하는 순간 필요한 데이터 복구 전략: Flashback Query 활용법 데이터베이스를 다루다 보면 누구나 한 번쯤 실수로 WHERE 절을 빼먹고 UPDATE를 날리거나, 중요한 데이터를 DELETE 하는 아찔한 경험을 하곤 합니다.오라클에서는 이런 상황을 대비해 특정 과거 시점의 데이터를 조회할 수 있는 강력한 기능인 Flashback Query를 제공합니다.1. Flashback Query란?오라클의 Undo 데이터를 활용하여, 현재 시점이 아닌 과거 특정 시점의 테이블 상태를 마치 스냅샷을 찍듯 조회하는 기능입니다. 별도의 백업 복원 과정 없이 SQL만으로 빠르게 데이터를 확인할 수 있다는 것이 가장 큰 장점입니다.2. 과거 데이터 조회하기 (AS OF TIMESTAMP)가장 일반적으로 사용하는 방법은 AS OF TIMESTAMP 구문을 사용하는 것입니다.특정 시간 기준.. 이전 1 다음