在程序中, 我要对一个器材表(Equipment)进行录入新器材的操作。现在的做法是使用数据库中的一个临时器材表(TempEquip),在其中一次性生成一台或多台器材记录、然后编辑、修改之后,将TempEquip导入正式表,如果用户放弃录入,则清空TempEquip,不导入正式表。现在可能有多个用户使用该模块进行录入,如何才能保证各用户只能够看自己添加的器材。并编辑或是撤销(删除)它们,而不影响其它人录入的内容呢?我原想在TempEquip加入用户ID字段,来区别录入的数据,但可能有同ID的用户使用(比如两个人同时使用A的身份). 或是使用临时表(#TempEquip)但似乎临时表只在一个存储过程中有效,出去就找不到了。大家有什么好的办法,多多指点,谢谢啦! ^^
与服务器或者是其他用户没有什么关联的临时性缓存不应该放在服务端
我个人更喜欢直接在主表中Insert数据,当然也是以用户ID,Computer Name,Time,客户端进程号为主键,如果担心并发冲突,可以使用IsolationLeavel(事务的隔离级别)
Union all
select 'B器材' as Name, 1200 as Amount,22345.65 as Price增加一个记录就增加一段Union all select ...语句组成一个记录集,更新数据时把这个记录集更新到表,如以上的数据集插入一个新表里就是
select a.* into NewTable from (select 'A器材' as Name, 1000 as Amount,12345.65 as Price Union all
select 'B器材' as Name, 1200 as Amount,22345.65 as Price) A
正解!
'我原想在TempEquip加入用户ID字段'
楼主的思路是正确的,不过,不能简单的加ID,要根据用户ID+MAC或者直接用GUID,根据唯一主健来确定一个单据的唯一.