0

我尝试从 SQL Fiddle HERE中看到的 SELECT 在 PHP 中插入。

我的代码:

$sql2 .= "INSERT INTO $tableBackup (Fahrer, Datum, Baustelle, Arbeitsbeginn, Arbeitsende, Projektbeginn, Projektende, Arbeitszeit, Projektzeit, Pausenzeit, Reine AZ, Sonntag, Feiertag, Urlaub, Krank, Stundensatz, Auslöse, Gesamt)";
        $sql2 .= "SELECT t.*,";
        $sql2 .= "sum(HOUR(TIMEDIFF(STR_TO_DATE(Arbeitsbeginn, '%d.%m.%Y %H:%i:%s'), STR_TO_DATE(Arbeitsende, '%d.%m.%Y %H:%i:%s')))) AS ARBEITSZEIT, sum(HOUR(TIMEDIFF(STR_TO_DATE(Projektbeginn, '%d.%m.%Y %H:%i:%s'), STR_TO_DATE(Projektende, '%d.%m.%Y %H:%i:%s')))) AS Projektzeit";
        $sql2 .= "FROM (SELECT DriverName AS Fahrer, Datum,Baustelle,Arbeitsbeginn,Arbeitsende,Projektbeginn,Projektende";
        $sql2 .= "FROM (SELECT DRIVERNAME,left(`datetime`, 10) as Datum,,GROUP_CONCAT(IF(ACTIONTEXT = 'PB', AREA, NULL)) AS 'Baustelle',GROUP_CONCAT(IF(ACTIONTEXT = 'Arbeitsbeginn', DATETIME, NULL)) AS 'Arbeitsbeginn',GROUP_CONCAT(IF(ACTIONTEXT = 'Arbeitsende', DATETIME, NULL)) AS 'Arbeitsende',GROUP_CONCAT(IF(ACTIONTEXT = 'PB', DATETIME, NULL)) AS 'Projektbeginn',GROUP_CONCAT(IF(ACTIONTEXT = 'PE', DATETIME, NULL)) AS 'Projektende'";
        $sql2 .= "FROM geoImportRoot GROUP BY DRIVERNAME) A CROSS JOIN (SELECT 1 AS n UNION ALL SELECT 2) n) t";
        $sql2 .= "GROUP BY Fahrer, Datum;";
        $this->DB->Execute($sql2);

以及新表的结构:

`geoEdit` (
`ID` int(255) NOT NULL AUTO_INCREMENT,
`Fahrer` text NOT NULL,
`Datum` text NOT NULL,
`Baustelle` text NOT NULL,
`Arbeitsbeginn` text NOT NULL,
`Arbeitsende` text NOT NULL,
`Projektbeginn` text NOT NULL,
`Projektende` text NOT NULL,
`Arbeitszeit` text NOT NULL,
`Projektzeit` text NOT NULL,
`Pausenzeit` smallint(10) NOT NULL DEFAULT '1',
`Reine AZ` int(255) DEFAULT NULL,
`Sonntag` text,
`Feiertag` text,
`Urlaub` text,
`Krank` text,
`Stundensatz` int(10) NOT NULL DEFAULT '10',
`Auslöse` int(255) DEFAULT NULL,
`Gesamt` int(255) DEFAULT NULL,
PRIMARY KEY (`ID`)
)  ENGINE=InnoDB DEFAULT CHARSET=utf8 AUTO_INCREMENT=1 ;

这没用。在触发此脚本之前,我将数据插入到根表 geoImportRoot 中。

4

1 回答 1

2

此处空格会在您的查询中产生问题,请在其周围使用反引号

 Pausenzeit, Reine AZ, Sonntag,
                  ^

 Pausenzeit, `Reine AZ`, Sonntag,
于 2013-06-24T05:27:49.483 回答