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

时间:2012-06-12 15:46:40

标签: php javascript jquery sql

如果我完全错误地接近这一点,我希望有人可以帮助我或指出我正确的方向。

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

我正处于用户正确显示的位置,我已将费用附加到复选框的值,但我似乎无法弄清楚如何将用户重新输入新表。

我希望下面的代码示例足够明确,以帮助澄清我的目标。

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

谢谢!

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);

    });

});

1 个答案:

答案 0 :(得分:1)

而不是

<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*/)