MySQL select into 和 SQL select into

现在有张表为student,我想将这个表里面的数据复制到一个为dust的新表中去,虽然可以用以下语句进行复制,总觉得不爽,希望各位帮助下我,谢谢。

answer 01: 
create table dust select * from student;//用于复制前未创建新表dust的情况下 
answer 02: 
insert into dust select * from student;//已经创建了新表dust的情况下

现在请各位用select..into..语句实现以上东东,谢谢支持,再次感谢!
网友回复:该回复于2008-09-29 06:37:03被版主删除
网友回复:sqlserver可以那樣寫,但是mySql中貌似不行哦,另外樓主你說的那兩種寫法,應該是最常見的啊
网友回复:create table dust select * from student;
网友回复:楼上的写的是我发的里面的啊,我要的是 select into 语句的啊?

请各位大侠帮忙,谢谢!
网友回复: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 oktable2 > ok_db.sql

2.修改备份表的名字 
3.登录MySQL 
4.选择数据库 
5.执行: Source 备份表的路径 如:Source d:/ok_db.sql 回车即可。 
6.完成.

MySQL Select into outfile用于导出指定的查询数据到文件如下:

1.导出表中所有数据到C盘根目录outfile.txt中如下: 
Select * into outfile ‘c://outfile.txt‘ from test;

2.导出表中指定查询条件2005-06-08号的数据到C盘根目录outfile1.txt中如下: 
Select * into outfile ‘c://outfile.txt‘ from test where beginDate=‘2008-06-08‘;

mysql> load data local infile "d:/gpsdata.txt" into table positiondata fields terminated by ‘;‘ (userid,latitude,longitude,altitude,speed,innerid,repo 
rttime,status);

LOAD DATA [LOW_PRIORITY CONCURRENT] [LOCAL] INFILE ’file_name.txt’ 
[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

MySQL select into 和 SQL select into

标签: mysqlsqltable数据库sqlserversql server

2008-10-31 15:23 70131人阅读 评论(2) 收藏 举报

 分类:

mysql(30) 

现在有张表为student,我想将这个表里面的数据复制到一个为dust的新表中去,虽然可以用以下语句进行复制,总觉得不爽,希望各位帮助下我,谢谢。 
answer 01: 
create table dust select * from student;//用于复制前未创建新表dust的情况下 
answer 02: 
insert into dust select * from student;//已经创建了新表dust的情况下

现在请各位用select..into..语句实现以上东东,谢谢支持,再次感谢!
网友回复:该回复于2008-09-29 06:37:03被版主删除
网友回复:sqlserver可以那樣寫,但是mySql中貌似不行哦,另外樓主你說的那兩種寫法,應該是最常見的啊
网友回复:create table dust select * from student;
网友回复:楼上的写的是我发的里面的啊,我要的是 select into 语句的啊?

请各位大侠帮忙,谢谢!
网友回复: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 oktable2 > ok_db.sql

2.修改备份表的名字 
3.登录MySQL 
4.选择数据库 
5.执行: Source 备份表的路径 如:Source d:/ok_db.sql 回车即可。 
6.完成.

MySQL Select into outfile用于导出指定的查询数据到文件如下:

1.导出表中所有数据到C盘根目录outfile.txt中如下: 
Select * into outfile ‘c://outfile.txt‘ from test;

2.导出表中指定查询条件2005-06-08号的数据到C盘根目录outfile1.txt中如下: 
Select * into outfile ‘c://outfile.txt‘ from test where beginDate=‘2008-06-08‘;

mysql> load data local infile "d:/gpsdata.txt" into table positiondata fields terminated by ‘;‘ (userid,latitude,longitude,altitude,speed,innerid,repo 
rttime,status);

LOAD DATA [LOW_PRIORITY CONCURRENT] [LOCAL] INFILE ’file_name.txt’ 
[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

0
时间: 2024-10-24 15:30:14

MySQL select into 和 SQL select into的相关文章

MYSQL 强制使用某个索引 select count(*) from t_audit_operate_log use index(indx_ctime) where Fuser='CY6016

MYSQL 强制使用某个索引 select count(*) from t_audit_operate_log use index(indx_ctime) where Fuser='CY6016 http://blog.163.com/li_hx/blog/static/18399141320147212521455/ 单表扫描,MySQL索引选择不正确 并 详细解析OPTIMIZER_TRACE格式 2014-08-21 15:07:05|  分类: 数据库 |  标签:查询优化  mysql

C++类库:OTL连接MySQL ODBC数据库(insert, update, select)

一. 简介 OTL是一个纯C++的通用数据库连接模板库,可以支持各种当下流行的数据库,如Oracle,Sybase, MySQL, PostgreSQL, EnterpriseDB, SQLite,  MS ACCESS, Firebird等等.它是一个跨平台类库,在MS Windows, Linux/Unix/Mac OS X 都可以使用. OTL使用简单, 只要头文件中包含有: #include "otlv4.h" 就可,实际上整个OTL就一个.H的文件,使用起来极为的方便. 我的

SQL SELECT TOP 语句

SELECT TOP 子句用于规定要返回的记录的数目. SELECT TOP 子句对于拥有数千条记录的大型表来说,是非常有用的. 注释:并非所有的数据库系统都支持 SELECT TOP 子句. SQL Server / MS Access 语法 SELECT TOP number|percent column_name(s) FROM table_name; MySQL 和 Oracle 中的 SQL SELECT TOP 是等价的 MySQL 语法 SELECT column_name(s)

从多表连接后的select count(*)看待SQL优化

从多表连接后的select count(*)看待SQL优化 一朋友问我,以下这SQL能直接改写成select count(*) from a吗? SELECT COUNT(*) FROM a LEFT JOIN b ON a.a1 = b.b1 LEFT JOIN c ON b.b1 = c.c1 废话不多说,直接上实验. 1. 准备数据 创建测试表a,b,c,并插入数据,a有重复数据,b是唯一数据,c是唯一数据,d有重复数据. 1) 创建a表 create table a (a1 int);

Oracle 基本SQL SELECT语句

SELECT  *  |    {   [ DISTINCT  ]    column   |    expression   [   alias   ]  ,   ...    } FROM  table; ?SELECT  标识 选择哪些列. ?FROM    标识从哪个表中选择. column后面加上空格,同时跟上别名(alias),或者 as 别名,到下一行的内容时,要用逗号隔开, 默认的别名是小写的,如果想要让它是大写的,使用 "别名" 如果别名有多个单词的时候,用双引号别名

SQL SELECT INTO 语句

SQL SELECT INTO 语句可用于创建表的备份复件. SELECT INTO 语句 SELECT INTO 语句从一个表中选取数据,然后把数据插入另一个表中. SELECT INTO 语句常用于创建表的备份复件或者用于对记录进行存档. SQL SELECT INTO 语法 您可以把所有的列插入新表: SELECT * INTO new_table_name [IN externaldatabase] FROM old_tablename 或者只把希望的列插入新表: SELECT colu

SQL SELECT DISTINCT 语句

SQL SELECT DISTINCT 语句 在表中,可能会包含重复值.这并不成问题,不过,有时您也许希望仅仅列出不同(distinct)的值. 关键词 DISTINCT 用于返回唯一不同的值. 语法: SELECT DISTINCT 列名称 FROM 表名称 使用 DISTINCT 关键词 如果要从 "Company" 列中选取所有的值,我们需要使用 SELECT 语句: SELECT Company FROM Orders "Orders"表: Company

SQL SELECT 语句

SQL SELECT 语句 SELECT 语句用于从表中选取数据. 结果被存储在一个结果表中(称为结果集). SQL SELECT 语法 SELECT 列名称 FROM 表名称 以及: SELECT * FROM 表名称 注释:SQL 语句对大小写不敏感.SELECT 等效于 select. SQL SELECT 实例 如需获取名为 "LastName" 和 "FirstName" 的列的内容(从名为 "Persons" 的数据库表),请使用类似

sql SELECT时的with(nolock)选项说明

I used to see my senior developers use WITH (NOLOCK) when querying in SQL Server and wonder why they use. Now i explored it and found that it's useful to improve the performance in executing the query . However there is a disadvantage in using it. Th