메뉴 건너뛰기

프로그램언어

조회 수 20157 추천 수 0 댓글 0
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄
?

단축키

Prev이전 문서

Next다음 문서

크게 작게 위로 아래로 댓글로 가기 인쇄

MySQL DB 중복여부 검사하여 없는 것만 추가


자료를 DB에 입력하는 걸 좀 편하게 하려고 중복검사 루틴을 만들어서 테스트를 했는데 계속 자료가 중복으로 들어가 저장된다.

서버 DB 자료를 엑셀로 내보내기 해서 중복검사를 하면 중복된 데이터는 전부 체크하여 표시를 해준다.

어디서 잘못된 걸까? 계속 머리 싸매다가 네이버 검색으로 하는데 자료 찾아도 잘 안나온다.

구글링을 해서 찾았더니 뭔가 힌트가 될만한 것이 검색된다.

넣어서 검사를 했더니 제대로 중복검사 여부를 체크한다.

WHERE eng = '".addslashes($line[0])."'

바로 이 부분 때문에 중복검사를 제대로 못했던 거다.

물론 '(Apostrophe) and " (Quotation mark) 가 없는 한글은 WHERE han = '$line[1]' 으로 검사해도 중복체크를 잘 한다.

중복검사 하는 가장 핵심적인 팁이라 할 수 있는 걸 찾게 되어 너무 기쁘다.


<?
$DB_CONNECT = isConnectDb($DB);
########### DB 연결 ###########
$file=fopen("insert_data.csv","r");
if(!$file){
    echo("Failed to open the file");
    exit;
}

while($line = fgetcsv($file,1000, ";")) { // 구분자는 ; 로 지정, 한줄씩 읽어드린 값을 끝라인까지 계속하라.
    $query = mysql_query("SELECT uid, eng FROM engtable WHERE eng = '".addslashes($line[0])."'",$DB_CONNECT);
    $dupcheck = mysql_fetch_array($query);
    if ($dupcheck['uid']) {
           $dup_line ++;
    } else {     // 중복된 자료가 없을 경우
        $eng = addslashes(trim($line[0]));    // 쿼터(')의 경우 역슬래쉬(\) 처리해야 DB에 저장됨

        $sql = "INSERT INTO $tblName (uid,eng,kor) VALUES (NULL,'$eng','$kor')";
        mysql_query($sql,$DB_CONNECT); // MYSQL DB에 저장
        $ok ++;
        if (($ok % 500) == 0) {
            echo(" $ok 건 저장");
            flush();
            sleep(3); //500개 저장할때마다 3초씩 쉰다.
        }
    $total_line++;
    } //중복체크 END 문
}

if ($dup_line > 0) {
    echo("중복 $dup_line 건 있음");
    echo "<br>";
}
echo("총 $total_line 자료 추가");
fclose ($file);
?>


List of Articles
번호 제목 날짜 조회 수
240 무조건 알아야 할 PHP 속도 테스트 14 가지 2014.02.27 30280
239 몫과 나머지 구하기 2017.03.07 18471
238 메일주소의 골뱅이를 그림처리하기 2017.03.06 15508
237 메모장소스 2019.01.08 2000
236 멀티 파일다운로드 꽁수로 구현하기 2020.06.19 437
235 마우스 오버시 사진변환, 파일에러시 대체이미지 적용(소스일부) 2018.07.24 4584
234 링크를 걸때 http 처리방법 2016.12.23 19019
233 리스트 페이징 2014.02.27 19386
232 리다이렉션(페이지 이동)의 3가지 방법, location.href 2017.03.07 40132
231 로또 숫자 랜덤하게 1~45까지 숫자 빼오기 2014.02.27 25432
230 로그인페이지에서 온 경우/로그인한 페이지로 이동 2016.12.23 18847
229 디비내용을 엑셀 파일로 다운로드 시키는 방법 2019.01.08 1391
228 디렉토리의 제어 2019.01.08 1222
227 디렉토리내 특정 확장자를 가진 파일 전부 삭제 file 2015.04.14 25515
226 디렉토리 안의 파일의 내용들을 읽는 예 2016.12.23 19012
225 두 날짜 사이의 차이 구하기 2017.03.07 18866
224 도메인 앞에 자동으로 WWW를 붙이는 방법 2017.03.07 18885
223 대소문자 바꾸기 (strtoupper, strtolower) 2016.12.23 19658
222 단어필터링 2019.01.08 1251
221 다중파일 업로드 + 이미지 미리보기 (Javascript, jQuery ) file 2020.12.15 912
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

하단 정보를 입력할 수 있습니다

© k2s0o1d4e0s2i1g5n. All Rights Reserved