Kyle_Ping 2021-09-30 15:40 采纳率: 100%
浏览 17
已结题

关于#sqlserver#的问题:if函数

我有一个疑惑,希望有人能帮我解决
我有一个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代码没有被执行的情况下,也会报错?

  • 写回答

1条回答 默认 最新

  • 於黾 2021-09-30 16:25
    关注

    语法错误不需要真正执行
    sql虽然是解释性的语言,但是执行前也要先判断一下语法是否有致命性的错误
    解释器总要能解释它,才开始执行它
    语法错误,根本解释不了,它就直接抛错了,而不会等执行到那才报错

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 10月8日
  • 已采纳回答 9月30日
  • 创建了问题 9月30日

悬赏问题

  • ¥15 名为“Product”的列已属于此 DataTable
  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题