I have 2 tables in my database. First table is room_details and second table is booking_details.
room_details table:
 Room_Id |  Category  |  Type    |  Price
---------|------------|----------|---------
 R 001   |   DELUXE   |  NON-AC  |  2500
         |            |          |
 R 002   |   DELUXE   |  AC      |  3500
         |            |          |
 R 003   |   GRAND    |  NON-AC  |  4500
         |            |          |
 R 004   |   GRAND    |  AC      |  5500
         |            |          |
 R 005   |   SUITE    |  NON-AC  |  6500
         |            |          |
 R 006   |   SUITE    |  AC      |  7500
booking_details table:
 Room_Id  |  Booking_Id  |  Booking_Date  | Check_in_Date |  Check_out_Date
----------|--------------|----------------|---------------|-----------------
  R 001   |    B 001     |   2017-03-25   |   2017-03-26  |   2017-03-28
          |              |                |               |
  R 001   |    B 002     |   2017-03-25   |   2017-03-29  |   2017-04-01
          |              |                |               |
  R 004   |    B 003     |   2017-03-25   |   2017-03-26  |   2017-03-30
          |              |                |               |
  R 005   |    B 004     |   2017-03-25   |   2017-03-26  |   2017-03-28
Query:
$sql  = 'SELECT * FROM room_details
         WHERE room_id NOT IN(
               SELECT room_id FROM booking_details
               WHERE '$check_in' BETWEEN Check_in_Date AND Check_out_Date
                 OR '$check_out' BETWEEN Check_in_Date AND Check_out_Date
         )';
When I take the check_in and check_out dates as input from user using php to display all the available rooms then it displays a error as given below :
Parse error: syntax error, unexpected '$check_in' (T_VARIABLE)
What is wrong with this query?
This is the complete php code:
<?php
  $a = $_POST["data_1"];
  $b = $_POST["data_2"];
  $check_in = date("Y-m-d", strtotime($a));
  $check_out = date("Y-m-d", strtotime($b));
  $dbhost = "localhost:3306"; 
  $dbuser = "root"; 
  $dbpass = ""; 
  $dbname="hotel";
  //create connection
  $conn = new mysqli($dbhost, $dbuser, $dbpass, $dbname);
  //check connection 
  if( $conn->connect_error ) { 
    die("Connection failed:" . $conn->connect_error);
  }
  $sql  = 'SELECT * FROM room_details
           WHERE room_id NOT IN(
             SELECT room_id FROM booking_details
             WHERE '$check_in' BETWEEN Check_in_Date AND Check_out_Date
               OR '$check_out' BETWEEN Check_in_Date AND Check_out_Date
           )';
  $result = $conn->query($sql);
 if ($result->num_rows > 0) {
   echo "<table border=1>
           <tr>
             <th>Room_Id</th>
             <th>Category</th>
             <th>Type</th>
             <th>Price</th>
           </tr>";
   // output data of each row
   while($row = $result->fetch_assoc()) {
     echo "<tr>";
     echo "<td>" . $row['Room_Id'] . "</td>";
     echo "<td>" . $row['Category'] . "</td>";
     echo "<td>" . $row['Type'] . "</td>";
     echo "<td>" . $row['Price'] . "</td>";
     echo "<td>" . "<a href = room_booking.php> BOOK NOW </a>" . "</td>";
     echo "</tr>";
   }
   echo "</table>";
 } else {
   echo "Error:" . $sql . "<br>" . $conn->error;
 }
 $conn->close();
?>
 
     
     
    