可以分别重命名来实现,
但是,如果担心在重命名过程中有 *** 作,导致数据写入失败,可以同时锁定2个表,不允许写入,然后对调表名。可以用下面的方法:
LOCK TABLES t1 WRITE, t2 WRITEALTER TABLE t1 RENAME TO t3
ALTER TABLE t2 RENAME TO t1
ALTER TABLE t3 RENAME TO t2
UNLOCK TABLES
如果只是结果集中交换两列:select name,id from 表名
如果更改表结构:
alter table 表名 modify column id int auto_increment after name
比如:
#建立测试表 t1
mysql>create table t1(id int auto_increment,name varchar(20),primary key(id))engine=innodb,default charset=utf8
Query OK, 0 rows affected (0.11 sec)
#插入3条数据
mysql>insert into t1(name) values ("aa"),("bb"),("cc")
Query OK, 3 rows affected (0.00 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql>select * from t1
+----+------+
| id | name |
+----+------+
| 1 | aa |
| 2 | bb |
| 3 | cc |
+----+------+
3 rows in set (0.00 sec)
#结果集中排列name到id前
mysql>select name,id from t1
+------+----+
| name | id |
+------+----+
| aa | 1 |
| bb | 2 |
| cc | 3 |
+------+----+
3 rows in set (0.00 sec)
#改变表结构,使name在id前
mysql>alter table t1 modify column id int auto_increment after name
Query OK, 3 rows affected (0.19 sec)
Records: 3 Duplicates: 0 Warnings: 0
mysql>select * from t1
+------+----+
| name | id |
+------+----+
| aa | 1 |
| bb | 2 |
| cc | 3 |
+------+----+
3 rows in set (0.00 sec)
mysql>desc t1
+-------+-------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+-------+-------------+------+-----+---------+----------------+
| name | varchar(20) | YES | | NULL | |
| id | int(11) | NO | PRI | NULL | auto_increment |
+-------+-------------+------+-----+---------+----------------+
参考运行下列更新查询语句就行了:
update t,t ts set t.b=ts.bwhere t.id<>ts.id and t.a=ts.b
测试实验:
drop table if exists t
-- 创建测试表
create table t(id varchar(10) primary key,a int,b int)
-- 插入测试数据
insert into t(id,a,b) values
('a01',1,2),
('a02',2,1),
('a03',3,5),
('a04',4,3),
('a05',5,4)
-- 查看t表未更新前的记录
select * from t
-- 如果其它记录行a的值与本行b的值相等,那么将该行b的值替换本行b的值
update t,t ts set t.b=ts.b
where t.id<>ts.id and t.a=ts.b
-- 查看t表更新后的记录
select * from t
-- 更新查新说明:
-- 1)id必须是唯一的否则数据库引擎弄不清楚哪行是哪行记录
-- 2)a最好是唯一的,如果a有重复,数据库引擎会选取第一条的b来更新,
-- 但是究竟哪行是重复中的第一条可能会比较随机
-- 这是在MySql测试的结果,由于更新查询是数据库“方言”重灾区,其他数据库不一定能通过,
-- 若不通过可参照上述语句的原理调整有关更新语句的写法,上述语句背后的原理没问题的。
实验截图:
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)