MySQL-쿼리 삽입

MySQL 테이블에 데이터를 삽입하려면 SQL을 사용해야합니다. INSERT INTO명령. mysql> 프롬프트를 사용하거나 PHP와 같은 스크립트를 사용하여 MySQL 테이블에 데이터를 삽입 할 수 있습니다.

통사론

다음은 MySQL 테이블에 데이터를 삽입하는 INSERT INTO 명령의 일반적인 SQL 구문입니다.

INSERT INTO table_name ( field1, field2,...fieldN )
   VALUES
   ( value1, value2,...valueN );

문자열 데이터 유형을 삽입하려면 모든 값을 큰 따옴표 또는 작은 따옴표로 유지해야합니다. 예를 들면"value".

명령 프롬프트에서 데이터 삽입

명령 프롬프트에서 데이터를 삽입하려면 SQL INSERT INTO 명령을 사용하여 MySQL 테이블 tutorials_tbl에 데이터를 삽입합니다.

다음 예제는 3 개의 레코드를 tutorials_tbl 표 −

root@host# mysql -u root -p password;
Enter password:*******
mysql> use TUTORIALS;
Database changed

mysql> INSERT INTO tutorials_tbl 
   ->(tutorial_title, tutorial_author, submission_date)
   ->VALUES
   ->("Learn PHP", "John Poul", NOW());
Query OK, 1 row affected (0.01 sec)

mysql> INSERT INTO tutorials_tbl
   ->(tutorial_title, tutorial_author, submission_date)
   ->VALUES
   ->("Learn MySQL", "Abdul S", NOW());
Query OK, 1 row affected (0.01 sec)

mysql> INSERT INTO tutorials_tbl
   ->(tutorial_title, tutorial_author, submission_date)
   ->VALUES
   ->("JAVA Tutorial", "Sanjay", '2007-05-06');
Query OK, 1 row affected (0.01 sec)
mysql>

NOTE− 모든 화살표 기호 (->)는 SQL 명령의 일부가 아닙니다. 새 줄을 나타내며 명령의 각 줄 끝에 세미콜론을 제공하지 않고 Enter 키를 누르면 MySQL 프롬프트에 의해 자동으로 생성됩니다.

위의 예에서는 테이블 생성시이 필드에 대해 AUTO_INCREMENT 옵션을 제공했기 때문에 tutorial_id를 제공하지 않았습니다. 따라서 MySQL은 이러한 ID를 자동으로 삽입합니다. 여기,NOW() 현재 날짜와 시간을 반환하는 MySQL 함수입니다.

PHP 스크립트를 사용하여 데이터 삽입

PHP 함수에 동일한 SQL INSERT INTO 명령을 사용할 수 있습니다. mysql_query() MySQL 테이블에 데이터를 삽입합니다.

이 예제는 사용자로부터 세 개의 매개 변수를 가져 와서 MySQL 테이블에 삽입합니다.

<html>

   <head>
      <title>Add New Record in MySQL Database</title>
   </head>

   <body>
      <?php
         if(isset($_POST['add'])) {
            $dbhost = 'localhost:3036';
            $dbuser = 'root';
            $dbpass = 'rootpassword';
            $conn = mysql_connect($dbhost, $dbuser, $dbpass);
         
            if(! $conn ) {
               die('Could not connect: ' . mysql_error());
            }

            if(! get_magic_quotes_gpc() ) {
               $tutorial_title = addslashes ($_POST['tutorial_title']);
               $tutorial_author = addslashes ($_POST['tutorial_author']);
            } else {
               $tutorial_title = $_POST['tutorial_title'];
               $tutorial_author = $_POST['tutorial_author'];
            }

            $submission_date = $_POST['submission_date'];
   
            $sql = "INSERT INTO tutorials_tbl ".
               "(tutorial_title,tutorial_author, submission_date) "."VALUES ".
               "('$tutorial_title','$tutorial_author','$submission_date')";
               mysql_select_db('TUTORIALS');
            $retval = mysql_query( $sql, $conn );
         
            if(! $retval ) {
               die('Could not enter data: ' . mysql_error());
            }
         
            echo "Entered data successfully\n";
            mysql_close($conn);
         } else {
      ?>
   
      <form method = "post" action = "<?php $_PHP_SELF ?>">
         <table width = "600" border = "0" cellspacing = "1" cellpadding = "2">
            <tr>
               <td width = "250">Tutorial Title</td>
               <td>
                  <input name = "tutorial_title" type = "text" id = "tutorial_title">
               </td>
            </tr>
         
            <tr>
               <td width = "250">Tutorial Author</td>
               <td>
                  <input name = "tutorial_author" type = "text" id = "tutorial_author">
               </td>
            </tr>
         
            <tr>
               <td width = "250">Submission Date [   yyyy-mm-dd ]</td>
               <td>
                  <input name = "submission_date" type = "text" id = "submission_date">
               </td>
            </tr>
      
            <tr>
               <td width = "250"> </td>
               <td> </td>
            </tr>
         
            <tr>
               <td width = "250"> </td>
               <td>
                  <input name = "add" type = "submit" id = "add"  value = "Add Tutorial">
               </td>
            </tr>
         </table>
      </form>
   <?php
      }
   ?>
   </body>
</html>

데이터 삽입을 수행하는 동안 함수를 사용하는 것이 가장 좋습니다. get_magic_quotes_gpc()매직 따옴표의 현재 구성이 설정되었는지 확인합니다. 이 함수가 false를 반환하면 함수를 사용합니다.addslashes() 따옴표 앞에 슬래시를 추가합니다.

입력 된 데이터가 올바른지 여부를 확인하기 위해 여러 유효성 검사를 수행하고 적절한 조치를 취할 수 있습니다.