mysql 从一个表中查数据,插入另一个表

不管是在网站开发还是在应用程序开发中,我们经常会碰到

需要将MySQL或MS SQLServer某个表的数据批量导入到另一个表的情况,甚至有时还需要指定导入字段。

本文就将以MySQL数据库为例,介绍如何通过SQL命令行将某个表的所有数据或指定字段的数据,导入到目标表中。此方法对于SQLServer数据库,也就是T-SQL来说,同样适用 。

类别一、 如果两张张表(导出表和目标表)的字段一致,并且希望插入全部数据,可以用这种方法:

INSERT INTO目标表SELECT  * FROM来源表 ;

例如,要将 articles 表插入到 newArticles 表中,则可以通过如下SQL语句实现:

INSERT  INTO  newArticles  SELECT   *  FROM    articles ;

类别二、 如果只希望导入指定字段,可以用这种方法:

INSERT   INTO  目标表 (字段1, 字段2, ...)  SELECT  字段1, 字段2, ...  FROM  来源表  ;

请注意以上两表的字段必须一致,否则会出现数据转换错误。

INSERT   INTO   TPersonnelChange   (UserId,  DepId,  SubDepId,  PostionType,  AuthorityId,  ChangeDateS,  InsertDate,  UpdateDate,  SakuseiSyaId  )

SELECT   UserId,DepId,   SubDepId,   PostionType,   AuthorityId,  DATE_FORMAT (EmployDate,  '%Y%m%d'  ),  NOW(),   NOW(),   1

FROM     TUserMst    WHERE    `Status` = 0    AND QuitFlg = 0    AND UserId < 2


    web开发中,我们经常需要将一个表的数据插入到另外一个表,有时还需要指定导入字段,设置只需要导入目标表中不存在的记录,虽然这些都可以在程序中拆分成简单sql来实现,但是用一个sql的话,会节省大量代码。下面我以mysql数据库为例分情况一一说明:

1.如果2张表的字段一致,并且希望插入全部数据,可以用这种方法:

INSERT     INTO    目标表    SELECT    *    FROM    来源表;

    insert    into    insert    Test    select    *    from    insertTest2;

2.如果只希望导入指定字段,可以用这种方法:

INSERT    INTO    目标表   (字段1, 字段2, ...)  SELECT   字段1, 字段2, ...   FROM   来源表; (这里的话字段必须保持一致)

  insert    into    insertTest2    (id)    select    id    from    insertTest2;

3.如果您需要只导入目标表中不存在的记录,可以使用这种方法:

INSERTINTO    目标表     (字段1,   字段2,   ...)   SELECT    字段1,   字段2,   ...   FROM    来源表    WHERE   notexists(select * from 目标表

where  目标表 . 比较字段 = 来源表 . 比较字段 );

 1>.插入多条记录:

insert   into     insertTest2( id,  name )    select   id,  name   from   insertTest 

 where   notexists (select  *  from  insertTest2  where  insertTest2.id  =  insertTest.id);

 2>.插入一条记录:

insert   into   insertTest  (id,   name)   SELECT  100,  'liudehua'    FROM   dual    WHERE   

notexists(select   *   from   insertTest    where   insertTest.id=100);


Mysql清空表(truncate)与删除表中数据(delete)的区别

为某基于wordpress搭建的博客长久未除草,某天升级的时候发现已经被插入了几万条垃圾留言,

如果一条条删除那可真是累人的活。遂考虑直接进入mysql直接清空表或者删除表中数据。

本文记录一下这2种操作模式的区别,目标对象是表wp_comments,里面的所有留言均是垃圾留言,均可删除。然后便有了以下2种方式(进入mysql操作界面后):

truncate   table   wp_comments;

delete   *    from   wp_comments;

其中truncate操作中的table可以省略,delete操作中的*可以省略。这两者都是将wp_comments表中数据清空,不过也是有区别的,如下:

truncate是整体删除(速度较快), delete是逐条删除(速度较慢)。

truncate不写服务器log,delete写服务器log,也就是truncate效率比delete高的原因。

truncate不激活trigger(触发器),但是会重置Identity(标识列、自增字段),相当于自增列会被置为初始值,又重新从1开始记录,而不是接着原来的ID数。

而delete删除以后,Identity依旧是接着被删除的最近的那一条记录ID加1后进行记录。

如果只需删除表中的部分记录,只能使用DELETE语句配合where条件。 DELETE   FROM   wp_comments   WHERE……

全文完。原创文章请随便转载。愿和大家分享,并且一起进步!

你可能感兴趣的:(mysql 从一个表中查数据,插入另一个表)