doucaigai7176 2014-08-21 18:41
浏览 62
已采纳

Mysql INSERT SUBQUERY无法正常工作

Can anyone tell me what's wrong with this query

$query = "
    INSERT INTO brand_generic.brand_drug (
        drug_id, brand_drug_name, manufacturer, type, price
) VALUES (
    (SELECT id FROM brand_generic.generic_drug WHERE generic_drug_name = '{$safe_generic_drug_name}'), '{$safe_brand_drug_name}', '{$safe_manufacturer_name}', '{$safe_type}', {$safe_price}
);";

It's not showing any error, but it's also not inserting into database from PHP file but when I do it manually through phpmyadmin it works, I just put the actual value in place of variable. I don't think there is any wrong in my query but still it is not inserting data in database, so i think I should put whole content of file here......

<?php
if(isset($_POST['submit'])){
 $generic_drug_name = $_POST['generic_drug_name'];
 $brand_drug_name = $_POST['brand_drug_name'];
 $manufacturer_name = $_POST['manufacturer_name'];
 $type = $_POST['type'];
 $price = $_POST['price'];
 }else{
    $generic_drug_name = '';
    $brand_drug_name = '';
    $manufacturer_name = '';
    $type = '';
    $price = '';
}
    $errors = ''; 
    $errors['generic_drug_nameErr'] = '';
    $errors['brand_drug_nameErr'] = '';
    $errors['manufacturer_nameErr'] = '';
    $errors['typeErr'] = '';
    $errors['priceErr'] = '';

?>
 <body>
  <header>
    <?php echo navigation(); ?>
  </header>
<section>       
<div id="envelope">

<form action="<?php echo htmlspecialchars($_SERVER["PHP_SELF"]);?>" method="post">

<?php       

        if ($_SERVER["REQUEST_METHOD"] == "POST") {
            if (empty($_POST["generic_drug_name"])) {
               $errors['generic_drug_nameErr'] = "Name is required";

            }else{
               $generic_drug_name = test_input($_POST["generic_drug_name"]);
                 // check if name only contains letters and whitespace
                 if (!preg_match("/^[a-zA-Z ]*$/",$generic_drug_name)) {
                   $errors['generic_drug_nameErr'] = "Only letters and white space allowed";
                 }
               }
            if (empty($_POST["brand_drug_name"])) {
               $errors['brand_drug_nameErr'] = "Name is required";

            }else{
               $brand_drug_name = test_input($_POST["brand_drug_name"]);
                 // check if name only contains letters and whitespace
                 if (!preg_match("/^[a-zA-Z ]*$/",$brand_drug_name)) {
                   $errors['brand_drug_nameErr'] = "Only letters and white space allowed";
                 }
               }
            if (empty($_POST["manufacturer_name"])) {
               $errors['manufacturer_nameErr'] = "Name is required";

            }else{
               $manufacturer_name = test_input($_POST["manufacturer_name"]);
                 // check if name only contains letters and whitespace
                 if (!preg_match("/^[a-zA-Z ]*$/",$manufacturer_name)) {
                   $errors['manufacturer_nameErr'] = "Only letters and white space allowed";
                 }
               }
            if (empty($_POST["type"])) {
                 $errors['typeErr'] = "Type is required";
               } else {
                 $type = test_input($_POST["type"]);
                 // check if e-mail address is well-formed
                 if (!preg_match("/^[a-zA-Z ]*$/",$type)) {
                   $errors['typeErr'] = "Only letters and white space allowed";
                 }
               }
            if (empty($_POST["price"])) {
                 $errors['priceErr'] = "";
               } else {
                 $price = test_input($_POST["price"]);
                 // check if e-mail address is well-formed
                 if (!preg_match("/^[0-9\_]{1,4}/",$price)) {
                   $errors['priceErr'] = "Invalid price format";
                 }
               }                        
        }
?>
<center><h1>Add a new brand drug</h1></center><br>
<label>Generic Drug Name</label><span class="error">* </span><span class="text"><?php echo $errors['generic_drug_nameErr'];?></span>
<input type="text" name="generic_drug_name" placeholder="Enter Generic drug Names" value="<?php echo htmlspecialchars($generic_drug_name); ?>" width="100px;"/>
<label>Brand Drug Name</label><span class="error">* </span><span class="text"><?php echo $errors['brand_drug_nameErr'];?></span>
<input type="text" name="brand_drug_name" placeholder="Amlokind" autofocus="autofocus" value="<?php echo htmlspecialchars($brand_drug_name); ?>" width="100px;">
<label>Manufacturer</label><span class="error">* </span><span class="text"><?php echo $errors['manufacturer_nameErr'];?></span>
<input type="text" name="manufacturer_name" placeholder="Glaxo Smithkline Pharmaceuticals Pvt. Ltd." autofocus="autofocus" value="<?php echo htmlspecialchars($manufacturer_name); ?>">
<label>Type</label><span class="error">* </span><span class="text"><?php echo $errors['typeErr'];?></span>
<input type="text" name="type" placeholder="Tablet" autofocus="autofocus" value="<?php echo htmlspecialchars($type); ?>">       
<label>Price</label><span class="error">* </span><span class="text"><?php echo $errors['priceErr'];?></span>
<input type="text" name="price" placeholder="10.45" autofocus="autofocus" value="<?php echo htmlspecialchars($price); ?>" >
<input type="submit" name = "submit" value="Add" id="submit"/>

</form>
</div>
<?php  
if(isset($_POST['submit'])){
     /*$generic_drug_name = $_POST['generic_drug_name'];
     $brand_drug_name = $_POST['brand_drug_name'];
     $manufacturer_name = $_POST['manufacturer_name'];
     $type = $_POST['type'];
     $price = $_POST['price'];*/
        if(empty($errors)){
            $safe_generic_drug_name = strtoupper($generic_drug_name);               
            $safe_brand_drug_name = strtoupper($brand_drug_name);
            $safe_manufacturer_name = ucwords($manufacturer_name);
            $safe_type = ucfirst($type);
            $safe_price = $price;

            $query = "INSERT INTO brand_generic.brand_drug (drug_id, brand_drug_name, manufacturer, type, price)   
                        SELECT id, '{$safe_brand_drug_name}','{$safe_manufacturer_name}', '{$safe_type}', {$safe_price}
                        FROM brand_generic.generic_drug 
                        WHERE generic_drug_name = '{$safe_generic_drug_name}';";
                    //INSERT INTO brand_generic.brand_drug (drug_id, brand_drug_name, manufacturer, type, price) VALUES ((SELECT id FROM brand_generic.generic_drug WHERE generic_drug_name = 'AMLODIPINE'), 'ZODIPINE', 'Zorex Pharma Pvt  Ltd', 'Tablet', 10);
            if(!$query){ 
                die(mysqli_error());
            }
            $result = mysqli_query($connection, $query);
            var_dump($result);

            if($result){
            $_SESSION["message"] = "Successfully subject created";
                //redirect_to("manage_content.php");
            echo $_SESSION["message"];
            }else{
            $_SESSION["message"] = "Sorry, subject couldn't be created";
                //redirect_to("new_subject.php");
            echo $_SESSION["message"];
            }
        }
    }

?>

Sorry guys, but since morning I am trying to find error but I got nothing...please help me and don't get angry if there is a small-tiny error....thank you everyone.... :)

  • 写回答

3条回答 默认 最新

  • douchi1945 2014-08-21 18:44
    关注
    INSERT INTO brand_generic.brand_drug (drug_id, brand_drug_name, manufacturer, type, price)   
    SELECT id, '{$safe_brand_drug_name}','{$safe_manufacturer_name}', '{$safe_type}', {$safe_price}
    FROM brand_generic.generic_drug 
    WHERE generic_drug_name = '{$safe_generic_drug_name}'
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
  • ¥20 神经网络Sequential name=sequential, built=False
  • ¥16 Qphython 用xlrd读取excel报错
  • ¥15 单片机学习顺序问题!!
  • ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
  • ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
  • ¥15 相敏解调 matlab
  • ¥15 求lingo代码和思路
  • ¥15 公交车和无人机协同运输
  • ¥15 stm32代码移植没反应