id int,
name1 varchar(16),
name2 varchar(16)
)
alter table test_change_column modify column name1 varchar(16) after name2
以上是一个例子,可以一试。注意在改变字段顺序时要指定这个字段的类型。
SQL的要点是中抽象应用程序以避免数据存储格式。你应该总是以你想要检索数据的意愿指定顺序。例如:SELECT col_name1, col_name2, col_name3 FROM tbl_name
将以col_name1、col_name2、col_name3的顺序返回列,而:
SELECT col_name1, col_name3, col_name2 FROM tbl_name
将以col_name1、col_name3、col_name2的顺序返回列。
在一个应用程序中,你应该决不基于他们的位置使用SELECT * 检索列,因为被返回的列的顺序永远不能保证;对你的数据库的一个简单改变可能导致你的应用程序相当有戏剧性地失败。
不管怎样,如果你想要改变列的顺序,你可以这样做:
以正确的列顺序创建一张新表。
执行INSERT INTO new_table SELECT fields-in-new_table-order FROM old_table.
删除或改名old_table。
ALTER TABLE new_table RENAME old_table。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)