0

外部キーを手動でインクリメントするにはどうすればよいですか。私は2つのテーブルを持っています

テーブルタイム

id-timeslot   times
------------------
   1       10:00
   2       10:30
   3       10:45
   4       11:00
   5       11:15
   6       11:30

私が今持っているテーブルブック

id-book   id-timeslot
-------------------
   1         1
   2         1  

ドロップダウン メニュー (所要時間)

<select name="minutes_booking" id="minutes_booking">
        <option value="0">15 Minutes</option>
        <option value="1">30 Minutes</option>
        <option value="2">45 Minutes</option>
        </select>

たとえば、ユーザーが 10:00 を選択し、「治療に費やす 30 分」を次のように表示したいとします。

   id-book   id-times
    -------------------
       1         1
       2         2   

phpコード:

if($minutes_booking == 0) :

     $mysqli->query("INSERT INTO doc_a(id_book, id_timeslot) 
     VALUES  ('','" . $id_timeslot . "')" ); 

     echo 'Booking has been added';

elseif($minutes_booking == 1) :


      $mysqli->query("INSERT INTO doc_a(id_book, id_timeslot) 
      VALUES  ('', '" . $id_timeslot . "')" ); 
      $mysqli->query("INSERT INTO doc_a(id_book, id_timeslot) 
      VALUES  ('', '" . $id_timeslot++ . "')" ); 
  echo 'Booking has been added';

 endif;
4

2 に答える 2

1

まず、id_book フィールドを自動インクリメントに切り替える必要があります。phpMyAdmin またはデータベース テーブルを変更するためのツールにアクセスできますか? 次に、このような構造を使用したい場合があります。これよりも良いかもしれませんが、私は物事をシンプルにしようとしています。

switch ($_POST['minutes_booking']) {
   case '0':
      $mysqli->query('INSERT INTO doc_a (id_timeslot) VALUES ('.$_POST['id_timeslot'].')');
      break;
   case '1':
      $mysqli->query('INSERT INTO doc_a (id_timeslot) VALUES ('.$_POST['id_timeslot'].')');
      $mysqli->query('INSERT INTO doc_a (id_timeslot) VALUES ('.++$_POST['id_timeslot'].')');
      break;
}

これがうまくいく場合は、この回答の横にあるチェックマークを選択してください。ありがとう!

于 2011-01-03T22:26:46.770 に答える
0

テーブル内の行のフィールドの値を変更できるMySQLUPDATEステートメントを見てください。

于 2011-01-03T20:55:46.703 に答える