• MySql中把一个表的数据插入到另一个表中的实现代码


    小编今天在写一个 将一个数据库的表数据 导入到 另一个数据库的表的时候 我是这么写的

    <?php
     header("Content-type:text/html;charset=utf-8");
    $conn = mysql_connect("localhost","root","");
    mysql_select_db('nnd',$conn);
    mysql_select_db('ahjk',$conn);
    mysql_query("set names utf8");
    $sql = mysql_query("select content,partid from phpcms_c_disease order by contentid desc limit
    //我这里是查询出表的数据 然后循环插入 
    $sql1= "INSERT INTO `nnd`.`demo`(content,parid)  VALUES";
    while($row = mysql_fetch_assoc($sql)){
         $sql1.="('$row[content]','$row[partid]'),";
    }
    $sql1.=")";
    $sql2 .= str_replace(",)",";",$sql1);
    mysql_query($sql2);
    ?>

    没想到我会这么二 写出这么垃圾的代码。。

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

    1.如果2张表的字段一致,并且希望插入全部数据,可以用这种方法:
    INSERT INTO 目标表 SELECT * FROM 来源表;
        insert into insertTest select * from insertTest2;

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

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

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

    INSERT INTO 目标表  
     (字段1, 字段2, ...)  
     SELECT 字段1, 字段2, ...  
     FROM 来源表  
     WHERE not exists (select * from 目标表  
     where 目标表.比较字段 = 来源表.比较字段); 

     1>.插入多条记录:

    insert into insertTest2
    (id,name)
    select id,name
    from insertTest
    where not exists (select * from insertTest2
    where insertTest2.id=insertTest.id);

     2>.插入一条记录:

    insert into insertTest    
    (id, name)    
    SELECT 100, 'liudehua'    
    FROM dual    
    WHERE not exists (select * from insertTest    
    where insertTest.id = 100);

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

     

    为某基于wordpress搭建的博客长久未除草,某天升级的时候发现已经被插入了几万条垃圾留言,如果一条条删除那可真是累人的活。遂考虑直接进入mysql直接清空表或者删除表中数据。

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

    1. truncate table wp_comments;
    2. 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……

    全文完。

  • 相关阅读:
    DAY 179 在Flask中使用MongoDB:Flask-MongoEngine
    DAY 178 oracle基础
    DAY 177 mongoengine
    DAY 176 redis教程
    存储器
    cpu
    java 类文件类型
    线程池
    CopyOnWrite容器
    ConcurrentHashMap
  • 原文地址:https://www.cnblogs.com/jiangxiaobo/p/7722691.html
Copyright © 2020-2023  润新知