일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
- 리눅스
- Eclipse
- 코드이그나이터
- html
- 6월 공모주 청약 일정
- jquery
- JavaScript
- css
- 오라클
- 공모주 청약
- codeigniter
- 자바스크립트
- 7월 공모주 청약 일정
- 맥
- 주식 청약 일정
- Oracle
- 공모주
- 주식 청약
- 자바
- java
- SQL
- Stock ipo
- php
- 제이쿼리
- linux
- Stock
- IPO
- MYSQL
- 주식
- 공모주 청약 일정
- Today
- Total
개발자의 끄적끄적
[mysql] REPLACE 레코드 데이터 치환하기(REPLACE) 본문
MySQL REPLACE 레코드 데이터 치환하기(REPLACE)
게시판 데이터에 첨부파일 경로가 변경이 되었거나 그 외 일괄 변경이 필요한 경우 REPLACE 함수를 이용해 쉽게 DB 데이터를 변경 할 수 있습니다.
예제는 myTable이라는 테이블의 content 데이터 중 http://예전도메인.co.kr 문자를 http://현재도메인.co.kr으로 치환하는 과정입니다.
1. 변경할 데이터 조회 하기
우선 변경 될 대상의 레코드를 확인하시기 바랍니다. 간혹 의도치 않은 데이터가 변경 되는 것을 방지하기 위한 확인 작업입니다.
1 |
SELECT * FROM myTable WHERE content LIKE '%http://예전도메인.co.kr%'; |
2. REPLACE로 치환 될 데이터 확인 (SELECT)
문자를 치환한 후 문제가 발생하는 것을 방지하기 위해 SELECT 문으로 치환 후 대상 값을 확인합니다.
이때 SElECT문으로 조회하는 것이기 때문에 REPLACE 함수로 인한 데이터 변경은 없습니다.
1 2 3 |
SELECT REPLACE(content, 'http://예전도메인.co.kr', 'http://현재도메인.co.kr') AS content FROM myTable WHERE content LIKE '%http://예전도메인.co.kr%'; |
3. 데이터 치환 실행하기 (UPDATE)
1번과 2번에서 모두 이상이 없다면 실제로 치환을 실행합니다.
1 2 3 4 5 6 |
UPDATE myTable SET content = REPLACE(content, 'http://예전도메인.co.kr', 'http://현재도메인.co.kr');
또는
UPDATE myTable SET content = REPLACE(content, 'http://예전도메인.co.kr', 'http://현재도메인.co.kr') WHERE content LIKE '%http://예전도메인.co.kr%'; |
참고로 조건을 추가하고 싶으시다면 1, 2과 같이 쿼리문 뒤에 WHERE 절을 추가해주시면 됩니다. 위 예제는 조건이 없는 전체 데이터를 대상으로한 내용입니다.
'개발 > sql' 카테고리의 다른 글
[sql] 오라클 데이터베이스 백업(Backup) 및 복구(Recovery) - 전체, 계정(스키마), 테이블[펌] (0) | 2020.03.11 |
---|---|
[sql] mssql 날짜 형식 변환 ( convert ) (0) | 2020.03.11 |
[Tibero] 설치 / 삭제 / 재가동 [펌] (0) | 2020.02.26 |
[sql] mssql null 값 찾기 (0) | 2020.02.24 |
[sql] IFNULL(MYSQL), ISNULL(MSSQL), NVL(ORACLE) (0) | 2020.02.24 |