题
我有以下代码,用于将表单数据插入到数据库中的单个表中。
function insert_interests($uid, $interests) {
/* first, we'll delete any entries this user already has in the table */
purge_lookup("jss_users_interests_table", $uid);
/* now create the sql insert query */
global $db;
$db->query(create_checkbox_query($interests, "jss_users_interests_table", $uid));
}
/* helper function for insert_interests(). removes all rows in $table with $uid */
function purge_lookup($table, $uid) {
global $db;
$db->query("DELETE FROM $table WHERE users_id = '".$db->escape($uid)."'");
}
/* helper function for insert_interests(). generates the actual SQL query */
function create_checkbox_query($arr, $table, $uid) {
$q = "INSERT INTO $table (users_id, subcategories_id) VALUES";
foreach ($arr as $check) {
$q .= " ( '$uid' , $check )" . ",";
}
/* remove the last comma and return */
return substr($q, 0, -1);
}`
在这段代码之后,我想使用相同的表单数据与另一个表中的其他数据配对,将新记录插入到不同的表中。这是两个表的结构。
jss_用户_兴趣_表
- 用户 ID
- 子类别_id
jss_info_requests_表
- 用户 ID
- 供应商ID
- 子类别_id
jss_providers_分配_表
- 供应商ID
- 子类别_id
那么将数据插入后我需要做什么 jss_users_interests_table
是与每个一起插入相同的数据 subcategories_id's
相应的 provider_id
来自 jss_provider_分配_表 进入 jss_info_requests_表. 。合理?我是否把事情搞得一团糟、变得复杂了?
任何有关语法的帮助都会很棒。谢谢!
解决方案
这个 SQL 可能会起作用。
INSERT INTO jss_info_requests_table
(users_id, provider_id, subcategories_id)
SELECT a.users_id,
b.provider_id, b.subcategories_id FROM
jss_users_interests_table a,
jss_providers_assignments_table b
WHERE a.subcategories_id =
b.subcategories_id AND a.users_id =
[USERID]
不隶属于 StackOverflow