首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在多个表中插入数据

如何在多个表中插入数据
EN

Stack Overflow用户
提问于 2017-06-16 00:08:33
回答 1查看 38关注 0票数 0

例如,我有一张3号桌

代码语言:javascript
复制
Table name: Role
table Attributes: roleid (pk), rolename

角色到用户的一对多

代码语言:javascript
复制
Table name: user
table Attributes: roleid (fk), userid(pk), trackingid(fk) username, password, email

用户对一对一的跟踪

代码语言:javascript
复制
Table name: tracking
table Attributes: trackingid(pk) approvalstatus*, status, createdby, createdDate(yyyy-mm-dd). 

*属性审批状态的含义-管理员将审批任何更改,使其可以处于待定、批准或拒绝状态

状态指示变更请求是新用户/编辑用户还是删除用户。

如何执行insert into语句以插入新用户以供审批。因为,当您在数据库中插入数据时应该如下所示

代码语言:javascript
复制
+----------+----------+--------------------+----------+--------+----------------+-----------+-------------+
| username | password |       email        | rolename | status | approvalstatus | createdby | createdDate |
+----------+----------+--------------------+----------+--------+----------------+-----------+-------------+
| harry    | password | harry@yahoo.com.sg | Admin    | New    | Pending        | Barry     | 2016-09-20  |
+----------+----------+--------------------+----------+--------+----------------+-----------+-------------+
EN

回答 1

Stack Overflow用户

发布于 2017-06-16 00:14:03

这实际上取决于您如何与数据库交互。

如果您使用的是实体框架或NHibernate之类的对象关系管理,这取决于您如何映射表。

有关这方面的信息,请查看:

  1. Entity Framework
  2. NHibernate

如果您直接对SQL Server执行此操作,则可以使用以下命令:

  1. 存储过程-在这种情况下,您将在DB服务器上调用单个存储过程,该存储过程将根据您的输入执行三次插入。
  2. 您可以使用一个连接对DB执行三个操作。

无论您是否选择存储的进程。或手动语句,您的插入将如下所示:

代码语言:javascript
复制
INSERT INTO ROLE (RoleID, RoleName) VALUES (newID(), 'Your Role Name'); --If you have auto increment on your PK you can ignore inserting into RoleID. Most Systems I work with now use GUID's for ID's so this is just an example.

INSERT INTO User (RoleID, UserID, TrackingID, UserName, Password, Email) Values (....)

INSERT INTO Tracking (TrackingID, ApprovalStatus, Status, CreatedBy, CreatedDate) values (....)

一旦你的数据库中有了一个条目,你就可以使用以下命令更新它:

代码语言:javascript
复制
UPDATE Tracking SET ApprovalStatus = 'whatever you want here' where id = X

如果您需要维护跟踪历史,而不是更新跟踪,则需要插入新行,并始终确保在选择数据时,根据DateTime戳获得最新的数据。

您问题中的表格具有误导性。您将连接三个表来获得这些结果,这可能是您希望在我们的输出中得到的结果。

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/44572221

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档