메뉴 건너뛰기

프로그램언어

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

단축키

Prev이전 문서

Next다음 문서

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

단축키

Prev이전 문서

Next다음 문서

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

쿠폰번호 발행 업데이트판. (간단한 클래스화[PHP4 기준] 등...)

 

 

 

DB

CREATE TABLE `coupon_test` (
  `couponNO` varchar(16) NOT NULL default '',
  `ID` varchar(20) NOT NULL default '',
  PRIMARY KEY  (`couponNO`)
) TYPE=MyISAM;

 

 

쿠폰생성 소스

<?
// Mysql 클래스
class TMySql {
    var $dbconn; // DB 연결 리소스
    var $result; // Query 결과 저장 리소스

  

     // 생성자: DB에 연결
    function TMySQL($Host, $DB, $ID, $PW) {
        $this->dbconn=mysql_connect($Host, $ID, $PW) or die("데이터베이스 연결에 실패하였습니다.<br/>".mysql_error());
        mysql_select_db($DB, $this->dbconn) or die("{$DB}를 사용할 수 없습니다.<br/>".mysql_error());
    }

 

    // Query 실행. 결과를 $this->result 에 저장
    function Query($SQL) {
        mysql_real_escape_string($SQL);
        $this->result=mysql_query($SQL, $this->dbconn);
        if (!$this->result) die('INVALID QUERY: '.mysql_error());  
    }

 

    // Query 결과의 갯수 반환
    function Count() {
        return mysql_num_rows($this->result);
    }
}

 


// 쿠폰번호 클래스
class TCoupon {
    var $coupon_len;  // 쿠폰길이
    var $arr_no;      // 숫자배열
    var $arr_alphabet;// 알파벳배열

 

    // 생성자: 쿠폰길이를 받아 멤버에 세팅하고, 숫자와 알파벳배열을 세팅
    function TCoupon($CouponLength=16) {
         $this->coupon_len=$CouponLength;

         // 숫자
         for ($i=Ord('0'); $i<=Ord('9'); $i++) $this->arr_no[]=Chr($i);
         // 알파벳
         for ($i=Ord('A'); $i<=Ord('Z'); $i++) $this->arr_alphabet[]=Chr($i);    
    }

 

    // 쿠폰번호 반환
    function GetCoupon() {
         $result_str="";

         $len_no=count($this->arr_no);
         $len_alphabet=count($this->arr_alphabet);

 

         for ($i=0; $i<$this->coupon_len; $i++){
             // 랜덤을 돌려 0 이면 숫자, 1 이면 알파벳
             if (rand(0,1)==0) $result_str.=$this->arr_no[rand(0,$len_no-1)];
             else                 $result_str.=$this->arr_alphabet[rand(0,$len_alphabet-1)];
         } 
         return $result_str;
    }
}

 

 

 

// DB 객체 생성
$MySQL=new TMySQL('localhost', 'db_bloodguy', 'bloodguy', 'nicehide');

// 길이가 16인 쿠폰번호 객체 생성
$Coupon=new TCoupon(16);


// 쿠폰발행 루프 (10000개의 번호를 생성한다고 가정)
$x=0;
while ($x<10000){
    $CouponNo=$Coupon->GetCoupon();

   

    // 해당 번호가 DB 있는 중복번호인가 체크
    $MySQL->Query("select * from coupon_test where couponNO='{$CouponNo}'");
    // 중복번호가 아니라면 DB 에 넣음
    if ($MySQL->Count==0) {
         $MySQL->Query("insert into coupon_test VALUES ('{$CouponNo}' ,'')");
         //echo $CouponNo."<br>";
         $x++;
    }
    // 중복번호라면 다시
    else continue;
} // while ($x<10000)
?>



List of Articles
번호 제목 날짜 조회 수
340 환경변수 HTTP_USER_AGENT를 이용해서 스마트 기기 분류하기 2016.09.21 25959
339 확장자 추출 하기 2021.03.26 308
338 홈페이지 귀퉁이에 붙이는 공지창 file 2015.04.06 25426
337 헤더이용 다운로드 받을시 바로열기부분 소스 2018.07.24 7320
336 해당하는 날짜가 그달의 몇주째인지 계산 2014.02.27 26351
335 함수이름을 변수로 사용하기, 매개변수 없는 함수에 매개변수 넣기 2021.03.26 746
334 한글줄바꾸기 또는 utf-8 wordwrap 2014.04.12 26546
333 한글자르기 substr 2015.04.14 25198
332 한글이 깨져서 나올 때 - iconv 2018.08.29 3933
331 필드값 저장 2014.02.27 24276
330 프레임 사이트에서 새로고침(F5) 할때 초기화면으로 이동하지 않음 2019.01.08 1280
329 폴더에 사진올려놓고 리스트자동으로 만들기 2019.01.08 1302
328 폴더 용량 체크 2023.01.12 216
327 포트체크 방법 2019.01.16 1288
326 페이지 로딩 시간 측정 2014.02.27 26041
325 파일을 변수에 담기(ob_start를 이용한 방법) 2021.03.26 674
324 파일업로드 2017.02.19 19352
323 파일시스템, 폼 파일업로드 관련 함수 2017.03.27 21681
322 파일 확장자 비교 2016.12.23 21970
321 파일 종류에 따른 아이콘표시하기 함수 2019.01.16 1421
Board Pagination Prev 1 2 3 4 5 6 7 8 9 10 ... 17 Next
/ 17

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

© k2s0o1d4e0s2i1g5n. All Rights Reserved