首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >如何使用sql server2005中的sql查询更改表中的列顺序?

如何使用sql server2005中的sql查询更改表中的列顺序?
EN

Stack Overflow用户
提问于 2009-10-22 13:18:03
回答 18查看 336.5K关注 0票数 128

如何在SQL Server2005中使用SQL query更改表中的列顺序?

我想使用SQL查询重新排列表中的列顺序。

EN

回答 18

Stack Overflow用户

回答已采纳

发布于 2009-10-22 13:23:39

你不能。列顺序只是我们人类关心的一个“表面”的东西--对于SQL Server来说,它几乎总是完全无关紧要的。

当您更改列顺序时,SQL Server Management Studio在后台执行的操作是使用新的CREATE TABLE命令从头重新创建表,复制旧表中的数据,然后删除该表。

没有用于定义列排序的SQL命令。

票数 137
EN

Stack Overflow用户

发布于 2009-10-22 13:22:31

你必须按照你想要的返回顺序来显式地列出字段,而不是使用*来表示“默认”顺序。

原始查询:

代码语言:javascript
复制
select * from foobar

返回

代码语言:javascript
复制
foo bar
--- ---
  1   2

现在写下

代码语言:javascript
复制
select bar, foo from foobar

bar foo
--- ---
  2   1
票数 34
EN

Stack Overflow用户

发布于 2009-10-22 21:27:40

当然,您可以更改sql语句中列的顺序。然而,如果你想抽象表的物理列顺序,你可以创建一个视图。i.e

代码语言:javascript
复制
CREATE TABLE myTable(
    a int NULL,
    b varchar(50) NULL,
    c datetime NULL
);


CREATE VIEW vw_myTable
AS
SELECT c, a, b
  FROM myTable;

select * from myTable;
a  b  c
-  -  -

select * from vw_myTable
c  a  b
-  -  -
票数 11
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/1605144

复制
相关文章

相似问题

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