MySQL存储过程[复制表1 - >表2]

时间:2013-12-18 12:44:25

标签: php mysql

除了简单的CRUD操作之外,我对MySQL / SQL的了解是基本的。

如果我必须使用存储过程将某些属性(不是按特定顺序)移动到另一个表,那该怎么办呢?

以下是表格。我想从第1张桌子移到第2张桌子。

正如您所看到的,某些列的数据类型大小不同。

CREATE TABLE IF NOT EXISTS `source_cdr` (
  `callstart` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  `src` varchar(80) NOT NULL DEFAULT '',
  `dst` varchar(80) NOT NULL DEFAULT '',
  `accountcode` varchar(50) NOT NULL,
  `uniqueid` varchar(100) NOT NULL,
  `ID` int(11) NOT NULL AUTO_INCREMENT,
  `callanswer` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  `callend` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',
  `disposition` varchar(50) NOT NULL,
  `cdr_id` int(11) unsigned NOT NULL DEFAULT '0',
  `pin_code` varchar(4) NOT NULL,
  `provider` int(11) NOT NULL,
  PRIMARY KEY (`ID`),
  KEY `calldate_idx` (`callstart`) USING BTREE,
  KEY `idx_acc_code_calldate` (`accountcode`,`callstart`) USING BTREE,
  KEY `uniqueid` (`uniqueid`),
  KEY `cdr_id` (`cdr_id`),
  KEY `idx_uniqueid_cdr_id` (`uniqueid`,`cdr_id`)
) ENGINE=MyISAM;

-

CREATE TABLE IF NOT EXISTS `destination_cdr` (
  `id` bigint(20) NOT NULL AUTO_INCREMENT,
  `calldate` datetime NOT NULL,
  `source` varchar(80) NOT NULL,
  `destination` varchar(80) NOT NULL,
  `account_code` varchar(30) DEFAULT NULL,
  `pincode` varchar(45) NOT NULL,
  `duration_call` bigint(20) NOT NULL DEFAULT '0',
  `duration_talk` bigint(20) NOT NULL,
  `disposition` varchar(255) NOT NULL,
  `clid` varchar(80) DEFAULT NULL,
  `cdr_id` bigint(20) DEFAULT NULL,
  `vxcdr_id` bigint(20) DEFAULT NULL,
  `provider` int(11) NOT NULL DEFAULT '0'
  PRIMARY KEY (`id`)
) ENGINE=MyISAM;

编辑1

行的示例

    ('2012-03-18 20:54:49', '5796', '0761100866', '103f0124ad510516f33cab132c0a695b', 'call-F1884808-6753-2F10-181C-3A@10.217.164.33', 308006367, '2012-03-18 20:55:05', '2012-03-18 20:55:51', '200 OK', 2, '', 0),

由于

1 个答案:

答案 0 :(得分:0)

您可以使用MySQL: INSERT ... SELECT Syntax将数据从一个表格复制到另一个表格 确定两者中的公共字段并复制相同的字段。

示例

INSERT INTO TABLE2( COL1, COLx, ... ) SELECT colM, colY FROM TABLE1;

如果列大小不匹配,则会发生数据截断,您无法克服此问题,但重新定义目标表列。