sql将查询结果建⽴为新表1.sqlserver中,使⽤:
select * into tab_new from tab_old
SELECT * into anzhiresult from (select * from factdownloads_new where storename='anzhi') b
复制表结构句型,跨数据库
--复制结构+数据
select * into 数据库名.dbo.新表名 from 数据库名.dbo.原表名
--只复制结构
select * into 数据库名.dbo.新表名 from 数据库名.dbo.原表名 where 1=0
--复制到临时表
select * into #temptablename from 数据库名.dbo.原表名 where 1=0
create table tab_new like tab_old (使⽤旧表创建新表)
create table tab_new as select col1,col2… from tab_old definition only
3.MYSQL不⽀持上⾯语法
⽅法1:
Select * Into new_table_name from old_table_name;
替代⽅法:
Create table new_table_name (Select * from old_table_name);
CREATE table anzhi_result
(SELECT * from factdownloads_new where storename='anzhi')
mysql中select⽅法2:
1.先备份表结构和数据
#导出命令 -u⽤户名 -p密码 -h主机IP地址数据库名表名1 > 导出⽂件.sql
mysqldump -uroot -proot -h192.168.0.88 ok_db oktable2 > ok_db.sql
2.修改备份表的名字
3.登录MySQL
4.选择数据库
5.执⾏: Source 备份表的路径如:Source d:/ok_db.sql 回车即可。
6.完成.
要复制⼀张表中的部分字段到⼀张新表中去,并在新表中新增⼀个字段id,⾃动增加。
1.⾸先想到的是⽤select into,但是MYSQL不⽀持这⼀语法
MYSQL不⽀持:
Select * Into new_table_name from old_table_name;
替代⽅法:
Create table new_table_name (Select * from old_table_name);
Create table `sina20090712` (SELECT `title` , `time` , `original` , `content` , `author`
FROM `sinapl_article`
ORDER BY `sinapl_article`.`time` ASC);
2.然后将这⼀表备份为sql⽂件,然后修改这⼀sql⽂件头部建⽴表结构的语句,增加⼀句
DROP TABLE IF EXISTS `sina20090712`;
CREATE TABLE `sina20090712` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`title` varchar(100) NOT NULL,
`time` varchar(20) DEFAULT NULL,
`original` varchar(20) DEFAULT NULL,
`content` text,
`author` varchar(100) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
注:红⾊部分为新增加的
MySQL Select into outfile⽤于导出指定的查询数据到⽂件如下:
1.导出表中所有数据到C盘根⽬录中如下:
Select * into outfile 'c://' from test;
2.导出表中指定查询条件2005-06-08号的数据到C盘根⽬录中如下:
Select * into outfile 'c://' from test where beginDate='2008-06-08';
mysql> load data local infile "d:/" into table positiondata fields terminated by ';'
(userid,latitude,longitude,altitude,speed,innerid,repo
rttime,status);
LOAD DATA [LOW_PRIORITY CONCURRENT] [LOCAL] INFILE ’’
[REPLACE IGNORE]
INTO TABLE tbl_name
[FIELDS
[TERMINATED BY ’string’]
[[OPTIONALLY] ENCLOSED BY ’char’]
[ESCAPED BY ’char’ ]
]
[LINES
[STARTING BY ’string’]
[TERMINATED BY ’string’]
]
[IGNORE number LINES]
[(col_name_or_user_var,...)]
[SET col_name = eXPr,...)]
fields和lines在前⾯,(col_name_or_user_var,…)在后⾯如果你使⽤的时候直接把要写的这些属性放在表名后⾯,这样是不正确的,⼀定要写到fields和lines的后⾯!
⽹友回复:引⽤ 5 楼 wufongming 的回复:
MySQL不⽀持Select Into语句直接备份表结构和数据,⼀些种⽅法可以代替, 也有其它⽅法可以处理,总结如下:
⽅法1:
MYSQL不⽀持:
Select * Into new_table_name from old_table_name;
替代⽅法:
Create table new_table_name (Select * from old_table_name);
⽅法2:
1.先备份表结构和数据
#导出命令 -u⽤户名 -p密码 -h主机IP地址数据库名表名1 > 导出⽂件.sql
mysqldump -uroot -proot -h192.168.0.88 ok_db okt…
5楼的朋友把上⾯楼主对在mysql中的select into语句的疑惑做了说明,在mysql中不⽀持Select Into语句直接备份表结构和数据。
我认为⽅法1还是⽐⽅法⼆灵活很多,因为这⾥楼上朋友提出的解决⽅法是创建⼀个新的表,⽽且是表的字段名和结构和原来的表都⼀样,要是已经有⼀个新表被建⽴,只是表⾥⾯没有数据,⽽新表的字段名和原表不同但类型相同,这时第⼆种⽅法就不适⽤了。
所以我认为⽅法⼀稍微好点,有修改的余地,但5楼朋友能把问题说得这么好已经很不容易了!
楼主根据⾃⼰的需要选择吧!
⽹友回复:对了,楼主要是在SQL SERVER数据库下⽤select into语句来实现表的数据的复制是个不错的选择!
⽹友回复:有收获!
⽹友回复:感谢了,⼩弟佩服!
⽹友回复:引⽤ 5 楼 wufongming 的回复:
MySQL不⽀持Select Into语句直接备份表结构和数据,⼀些种⽅法可以代替, 也有其它⽅法可以处理,总结如下:
⽅法1:
MYSQL不⽀持:
Select * Into new_table_name from old_table_name;
替代⽅法:
Create table new_table_name (Select * from old_table_name);
⽅法2:
1.先备份表结构和数据
#导出命令 -u⽤户名 -p密码 -h主机IP地址数据库名表名1 > 导出⽂件.sql mysqldump -u…
补充⼀点,A表数据复制到B表,B表不能有⾃增ID
如果有⾃增ID,则不插⼊⾃增
insert into B (title) select title from A