DB 테이블명 컬럼명을 모를때 값 조회 방법 문의
글쓴이: 익명 사용자 / 작성시간: 일, 2024/02/25 - 1:50오전
안녕하세요
sql 쿼리문 질문 좀 드리겠습니다
현재 분석중인 sqlite 파일에 테이블이 30개 정도 있고
테이블마다 row 개수는 수천개에서 500만개까지 다양합니다
여기서 문의 드립니다
예를들어
"ABC" 라는 값이 디비 어딘가에 저장이 되어있는건 확실한데
어느 테이블의 어느 컬럼에 있는 값인지 모르는 상황입니다
이것을 c++ 같은 프로그래밍 언어로 찾기보다는 sql 쿼리문으로 찾고 싶습니다
30개의 테이블을 하나의 테이블로 join하여
다양한 타입의 컬럼을 문자열 형태로 비교하면서 찾아야할까요?
어떤 방법을 사용하면 좋은지 궁금합니다
Forums:
저라면
저라면
테이블 별로 key로 소팅하고 모든 필드를 concatenate 해서
테이블명, row number, concat된 스트링으로 결과를 정형화 한 후 union하고 그 결과에 대해
regex 사용해서 concat된 string에 조건을 걸어 보겠습니다.
오늘 우리는 동지를 땅에 묻었습니다. 그러나 땅은 이제 우리들의 것입니다.
아직도 우리의 적은 강합니다. 그러나 우리는 그들보다 많습니다.
항상 많을 것입니다.
예전에 쓰던거인데 postgresql기준 수정필요
-- postgresql 모든 테이블에서 값을 찾기
DO $$
DECLARE
r RECORD;
query TEXT;
value_to_search VARCHAR := 'g45'; -- 여기가 값
result RECORD;
BEGIN
FOR r IN SELECT table_name, column_name, data_type
FROM information_schema.columns
WHERE table_schema = 'public' -- Replace with your schema
LOOP
IF r.data_type IN ('character varying', 'varchar', 'text') THEN
query := 'SELECT ' || quote_ident(r.column_name) || ' FROM ' || quote_ident(r.table_name) ||
' WHERE ' || quote_ident(r.column_name) || ' = ' || quote_literal(value_to_search);
FOR result IN EXECUTE query
LOOP
RAISE NOTICE 'Value found in table %, column %', r.table_name, r.column_name;
EXIT; -- Exit the inner loop after finding the value
END LOOP;
END IF;
END LOOP;
END $$;
--컬럼이름 찾기
DO $$
DECLARE
r RECORD;
column_to_search VARCHAR := '찾고자 하는 컬럼명'; -- Replace with the column name you are searching for
BEGIN
FOR r IN SELECT table_schema, table_name
FROM information_schema.columns
WHERE column_name = column_to_search
LOOP
RAISE NOTICE 'Column found in schema %, table %', r.table_schema, r.table_name;
END LOOP;
END $$;
#도움이 될지는 모르겠지만 그냥 던져보고 갑니다.
댓글 달기