SQL插入 - 仅在此条件下插入

时间:2014-04-24 17:37:33

标签: sql sql-server database insert

我有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检查(如果用户存在,则进行一次插入),但我确定有更好的方法

3 个答案:

答案 0 :(得分:3)

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

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

答案 1 :(得分:2)

在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 server

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

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

答案 2 :(得分:1)

假设您的insert ... select ...列为自动增量,您可能希望使用ID来实现此目的:

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