sql server-sql插入-仅在此条件下插入



我有Table 1:

ID    UserString   Date     
-------------------------
 1    KRBS         4/25/2014    
 2    WEFG         4/24/2014

Table 2:

ID  UserString + Other user info 
----------------------------------
 1  KRBS    +  . . .. . 

我正在表1中预形成插入,但我想设置一个条件,仅在用户已经在表2中可用的情况下插入(如果用户已经存在于表2中,则仅在表1中插入行)

我目前正在进行两次独立的SQL检查(如果用户存在,则进行一次插入),但我相信有更好的方法

实现这一点的最佳方法是在表上定义一个FOREIGN KEY。这是最简单、最隐含的方法,可以在MSDN上找到一些参考资料。这意味着您将永远无法a)如果不存在相应的FK,则向该表插入条目;b)如果存在具有外键的条目,则从基表中删除(在您的情况下,如果用户已经具有设置,则删除该用户)。它看起来像:

ALTER TABLE NameOfTheTable
ADD CONSTRAINT FK_SomeNameForTheKey FOREIGN KEY (nameOfColFromThisTable)
    REFERENCES NameOfTheOtherTable (NameOfTheCOlumnYouAreReferencing);

在mysql:上试试这个

if {{ userId }} in (select UserString from Table2 where UserString = {{ userId }}) then
    insert into Table1 (ID, UserString, Date) values ({{ id }}, {{ userId }}, '{{ date }}')
end if

或者这个在sql服务器上

if {{ userId }} in (select UserString from Table2 where UserString = {{ userId }})
    insert into Table1 (ID, UserString, Date) values ({{ id }}, {{ userId }}, '{{ date }}')

将{{var}}更改为实际值

您可能想要使用insert ... select ...来实现这一点,假设您的ID列是自动递增的:

insert into
    table1 (
        UserString,
        Date
    )
select
    table2.UserString,
    @yourDateVariableHere
from
    table2
where
    table2.UserString = @yourUserStringVariableHere

最新更新