我有一个疑惑,希望有人能帮我解决
我有一个sql代码如下:
IF NOT EXISTS (
SELECT 1
)
BEGIN
SELECT TOP 0 sex
,convert(VARCHAR(30), '') AS sex
INTO student_log
FROM student
END
报错信息如下:
Msg 2705, Level 16, State 3, Line 6
Column names in each table must be unique. Column name 'sex' in table 'student_log' is specified more than once.
有一个地方我不是很理解,为什么BEGIN-END
内sql代码没有被执行的情况下,也会报错?
语法错误不需要真正执行
sql虽然是解释性的语言,但是执行前也要先判断一下语法是否有致命性的错误
解释器总要能解释它,才开始执行它
语法错误,根本解释不了,它就直接抛错了,而不会等执行到那才报错