Incorrect syntax near drop table(drop table 附近的语法不正确)
问题描述
我想编写以下 SQL 查询,但是 drop table @temp
和创建表@temp
,这是为什么呢?(使用 SQL Server 2015)
I want to write the following SQL query, however there are incorrect syntax errors with drop table @temp
and
create table @temp
, why is it that? (Using SQL Server 2015)
DECLARE @temp NVARCHAR(10)
SET @temp='sth'
IF OBJECT_ID(@temp, 'U') IS NOT NULL
DROP TABLE @temp
CREATE TABLE @temp
推荐答案
要回答 WHY 的问题,这是很久以前的句法约定.
DROP 语句是这样的:
To answer the question WHY, it is a syntactic convention from days long past.
The DROP statement goes like this:
DROP TABLE MyTable
和不是像这样:
DROP TABLE 'MyTable'
MyTable
是一个标识符,SQL 中的标识符不加引号.并且因为它不使用引号,所以它不接受变量.
MyTable
is an identifier, and identifiers in SQL are not quoted. And because it uses no quotes, it does not accept variables.
也与 WHERE
子句比较:
WHERE MyCol = 'abc'
-- MyCol is not quoted because it is an identifier.
-- 'abc' is quoted because it is a value, and so it can be replaced by a variable.
这篇关于drop table 附近的语法不正确的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:drop table 附近的语法不正确


- 在SQL中,如何为每个组选择前2行 2021-01-01
- 导入具有可变标题的 Excel 文件 2021-01-01
- 如何将 SonarQube 6.7 从 MySQL 迁移到 postgresql 2022-01-01
- 如何使用 pip 安装 Python MySQLdb 模块? 2021-01-01
- 使用 Oracle PL/SQL developer 生成测试数据 2021-01-01
- 更改自动增量起始编号? 2021-01-01
- 远程 mySQL 连接抛出“无法使用旧的不安全身份验证连接到 MySQL 4.1+"来自 XAMPP 的错误 2022-01-01
- 以一个值为轴心,但将一行上的数据按另一行分组? 2022-01-01
- SQL 临时表问题 2022-01-01
- 如何将 Byte[] 插入 SQL Server VARBINARY 列 2021-01-01