繁体   English   中英

SQL-根据从先前查询中选择的行将新记录插入表中

[英]SQL - Insert new record into table based on rows chosen from previous query

如果我完全不正确地使用此方法,我希望有人能帮助我或为我指明正确的方向。

我的意图是根据特定条件从数据库中选择合格的用户。 在返回并显示在页面上的那些用户中,管理员用户应该能够从这些用户中选择并将其添加到数据库中的另一个表中,这一次需要付费。

我到了正确显示用户的地步,并且已经将费用附加到复选框的值上,但是我似乎无法弄清楚如何重新将用户重新输入到新表中。

我希望下面的代码示例足够清楚,以帮助阐明我要进行的操作。

我意识到这可能不是最有效的方法。 任何意见或建议都将受到欢迎。

谢谢!

PHP选择符合条件的用户

$sql = $db->prepare("       
        SELECT *
        FROM users                                              
        WHERE user_registration = 1
        ");
$sql ->execute();
$users = $sql ->fetchAll(PDO::FETCH_OBJ);

HTML和PHP通过复选框显示合格用户

<table>
    <thead>
        <th class="checked">Select</th>                            
        <th>First Name</th>
        <th>Last Name</th>
        <th>Birth Date</th>
        <th>Fee</th>
    </thead>

    <tbody>

    <?php foreach($users as $entry): ?>

        <tr>
            <td class="checked">
                <input type="checkbox" name="checked" value="<?php echo $entry->fee; ?>"/> 
            </td>
            <td class="first-name"><?php echo $entry->first_name; ?></td>
            <td><?php echo $entry->last_name; ?></td>
            <td><?php echo $entry->birthdate; ?></td>
            <td><?php echo $entry->fee; ?></td>                                     
        </tr>
    <?php endforeach; ?>

    </tbody>
</table> 


<div id="total" name="total">$0
</div>

JS计算每个用户的费用

$(document).ready(function() {

    $('.option').click(function(){

        var total = 0;

        $('.option:checked').each(function(){

            total += parseInt($(this).val());

        });

        $('#total').html('$' + total);

    });

});

代替

<input type="checkbox" name="checked" value="<?php echo $entry->fee; ?>"/>

<input type="checkbox" name="checked" value="<?php echo $entry->id; ?>"/>

然后,当选中一个复选框并提交表单时,您将拥有该用户的ID,并且可以执行简单的操作

INSERT INTO table2
SELECT FROM table1 WHERE table1.id IN (/* Your comma separated IDs here*/)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM