首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >使用SQSH在名称中包含空格的表上选择查询

使用SQSH在名称中包含空格的表上选择查询
EN

Stack Overflow用户
提问于 2012-01-19 21:19:31
回答 4查看 65.8K关注 0票数 10

我在Ubuntu 10.04上使用SQSH (2.1版)连接到MSSQL数据库,命令如下:

代码语言:javascript
复制
sqsh -S server -U user -P password -D database

我有一个名为My Table的表,但我找不到对其运行SELECT查询的方法。这就是我到目前为止所尝试的:

代码语言:javascript
复制
SELECT * FROM 'My Table'
go

输出:“My Table”附近的语法不正确。(对于双引号,我得到了相同的结果)

代码语言:javascript
复制
\set t="My Table"
SELECT * FROM $t
go

输出:无效的对象名称'My‘。(这很奇怪,因为如果我回显\ $t,我会得到完整的表名)

代码语言:javascript
复制
SELECT * FROM My\\ Table
go

输出:无效的对象名称'My‘。

代码语言:javascript
复制
SELECT * FROM [My Table]
go

输出:无法使用DB-Library (如ISQL)或ODBC 3.7版或更早版本将仅Unicode排序规则中的Unicode数据或ntext数据发送到客户端。

最后一个命令适用于不带空格的表名。

更新:其他命令可以正常工作,例如,我可以使用以下命令获取表描述:

代码语言:javascript
复制
SELECT column_name,data_type FROM information_schema.columns WHERE table_name = 'My Table'
go
EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2012-01-20 02:20:24

终于找到the solution了。我必须将以下两行添加到/etc/freetds/freetds.conf中

代码语言:javascript
复制
tds version = 8.0
client charset = UTF-8
票数 2
EN

Stack Overflow用户

发布于 2012-01-20 04:49:23

在MS SQL Server中,将表名放在引号中不起作用。

正确的方法是使用[ ]

代码语言:javascript
复制
SELECT * FROM [My Table]
票数 15
EN

Stack Overflow用户

发布于 2015-03-10 03:37:56

我正在使用SQL 2008R2,下面的代码对我有效

代码语言:javascript
复制
['table name']
票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/8926673

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档