0

如何将数据插入两个或多个表中?

目前我正在使用这个技巧。(假设语法是正确的)

$Sql1 = "insert into user";
$Sql2 = "insert into files";
$Sql3 = "insert into messages";

query $Sql1
query $$ql2
query $Sql3

所以我正在使用它,我需要优化。

另外,我想我需要使用外键?但我不知道如何在 phpmyadmin 上执行此操作。

最后:

这就是我想要的。

要在“用户”表上插入数据,然后自动表“消息”和“文件”也将具有与用户相同的 ID。这就是我在代码中使用 3 个查询的原因。

请帮我。

提前致谢!

我的

4

3 回答 3

3

使用多个查询非常好。

但是,您应该将 3 个查询包装到一个事务中。也就是说,如果一个查询由于某种原因失败,所有先前查询(如果有)的影响可以回滚,以便您的数据库保持一致状态。

注意:事务不能使用 MySQL 的 MyISAM 表。此外,您必须使用 PHP 的Mysqli(或PDO)才能使用事务。(我假设您没有使用一些高级数据库抽象层。)

至于您关于外键的问题:据我所知,当您将 MyISAM 引擎用于数据库中的表时(我认为)没有区别,因为 MyISAM 甚至不支持外键的显式建模键。然而,像 InnoDB 这样的其他表引擎可以使用外键来检查某些约束,例如“消息必须始终与现有人员相关联”。

这里有一些关于外键的好例子:http ://www.postgresql.org/files/documentation/books/aw_pgsql/node131.html

于 2011-09-19T10:50:33.383 回答
1

这就是答案,我认为:http ://dev.mysql.com/doc/refman/5.1/en/example-foreign-keys.html

于 2011-09-19T10:54:01.057 回答
1

使用 mysql,您可以使用 LAST_INSERT_ID() 或 php mysql_insert_id() 函数。查看此手册条目:

http://dev.mysql.com/doc/refman/5.0/en/getting-unique-id.html

http://php.net/manual/en/function.mysql-insert-id.php

于 2011-09-19T11:00:47.497 回答