簡體   English   中英

上載CSV文件,PHP / MySQL查詢

[英]Uploading CSV File, PHP/MySQL Query

我有一個看起來像這樣的.csv文件...

     Name            AC-No.      Time                State        Exception   Operation

Johnny Starks Depp   1220    4/12/2013 12:45:18 AM  Check In        OK   
Johnny Starks Depp   1220    4/12/2013 5:46:58 AM   Out             Out 
Johnny Starks Depp   1220    4/12/2013 6:22:41 AM   Out Back        Out  
Johnny Starks Depp   1220    4/12/2013 10:42:17 AM  Check Out       Repeat   
Johnny Starks Depp   1220    4/12/2013 10:42:19 AM  Check Out       OK

我已經可以將此上傳到我的數據庫了。 我的問題是,結果顯示在表格中。 在mysql數據庫中,我有一個帶有列( 名稱,ACNo。,日期,CheckIn,Breakout,Breakin,CheckOut )的表。 我想做的是我無法正確處理的..具有相同DATE (在TIME Column中顯示)的.csv文件中的記錄將與Check In,BreakOut,在表中的BreakIn和CheckOut不會導致多條記錄。 像這樣..

     Name         |ACNo |     Date  | CheckIn     |  Breakout  |   Breakin  | Checkout
                  |     |           |             |            |            |
Johnny Starks Depp|1220 | 4/12/2013 | 12:45:18 AM | 5:46:58 AM | 6:22:41 AM | 10:42:19 AM

現在..我已經做了上面要在表中發生的上述示例,但是...當我檢查表時,是的,每行有不同的日期,但是(CheckIn,Breakout,Brekin,Checkout)中的時間是錯誤的。 錯誤,因為例如DATE 4/12/2013中的時間記錄在DATE 4/13/2013中。 我使用的代碼有什么問題? 還是我還有其他方法可以做到這一點? 這些是我的代碼:

<?php

$conn = mysql_connect("localhost","root","") or die(mysql_error());
mysql_select_db("dtrlogs",$conn);

$datehere ="";

if(isset($_POST['Submit']))
{

$file = $_FILES['file']['tmp_name'];

if($file == "")
{
    ?>
    <script type="text/javascript">
    alert('No File Selected!');
    </script>
    <?php
}

else
{
$handle = fopen($file,"r");
while(($fileop = fgetcsv($handle,1000,";")) !==false)
{
    $Name = $fileop[0];
    $ACNo = $fileop[1];
    $Time = $fileop[2];
    $State = $fileop[3];
    $NewState = $fileop[4];
    $Exception = $fileop[5];
    $Operation = $fileop[6];

    //i separated time/date in the Column TIME in the .csv file
    $date = date('m/d/Y', strtotime($Time));
    $hours = date('H:i:s A', strtotime($Time));


    //this is what i used to prevent multiple dates
    if($datehere != $date) {

        $datehere = $date;
    }
    else{

        $date = "";
    }







    //this is to insert the name and acno to the other table. 
    //(this is for the lists of employee)

    $sql=mysql_query("SELECT * FROM employee Where ACNo = '$ACNo'");
    $row=mysql_fetch_array($sql);
    if($row == 0) {

       $sql1 = mysql_query("INSERT INTO employee(ACNo, Name) VALUES('$ACNo','$Name')");
    }



    //Inserts record if Date is not yet recorded and if already has just updates 
    //the row's column (Checkin, breakout, breakin and Checkout) 
    //with its correct time according to the date

    $query = mysql_query("SELECT * FROM dtrs Where ACNo = '$ACNo' AND Date = '$date'");
    $rows = mysql_fetch_array($query);
    if($rows == 0) {

    $sql2 = mysql_query("INSERT INTO dtrs(Name, ACNo, Date, CheckIn, BreakOut, 
    BreakIn,CheckOut) 
    VALUES('$Name','$ACNo','$date','$CheckIn','$Breakout','$Breakin','$Checkout')");

    }
    else{

    $sql2 = mysql_query("Update dtrs Set CheckIn = '$CheckIn', BreakOut = 
    '$Breakout', BreakIn = '$Breakin', CheckOut = '$Checkout'");
    }







    //this is my conditions to identify whether the TIME/HOUR is 
    //Stated as CheckIn, Breakout, Breakin, or Checkout

    if($NewState == "Check In" || $State == 'Check In' && $Exception == "OK") {

        if($Exception == "Invalid" || $Exception == "Repeat")
        {}
        else {
            $CheckIn = $hours;
        }
    }
    if($State == 'Out' && $Exception == "Out") {

        if($Exception == "Invalid" || $Exception == "Repeat")
        {}
        else {
            $Breakout = $hours;
        }
    }
    if($State == 'Out Back' && $Exception == "Out") {

        if($Exception == "Invalid" || $Exception == "Repeat")
        {}
        else {
            $Breakin = $hours;
        }
    }
    if($NewState == "Check Out" || $State == "Check Out" && $Exception == "OK") {

        if($NewState == "Check In")
        {}
        else {
            $Checkout = $hours;
        }
     }


}


if($sql2)
{
if($sql2)
{


?>
    <script type="text/javascript">
    alert('File Upload Successful!');
    </script>
<?php
}
}
}

}

?>

我建議可能加載到臨時表中,然后從中提取詳細信息以用於填充實際表。

例如,如果將CSV文件加載到名為LoadTable的表(不是臨時表,因為在一個SQL中只能使用一個臨時表),則可以提取唯一的名稱和帳號,然后將其與子選擇可獲取每個相關事件的最大事件時間。

像這樣的東西:

SELECT DerivMain.Name, 
    DerivMain.ACNo, 
    DerivMain.EventDate, 
    DATE_FORMAT(DerivCheckIn.EventDateTime, '%l:%i:%s %p'), 
    DATE_FORMAT(DerivBreakout.EventDateTime, '%l:%i:%s %p'),  
    DATE_FORMAT(DerivBreakin.EventDateTime, '%l:%i:%s %p'), 
    DATE_FORMAT(DerivCheckout.EventDateTime, '%l:%i:%s %p')
FROM (SELECT DISTINCT Name, ACNo, DATE(STR_TO_DATE(Date,'%c/%e/%Y %l:%i:%s %p')) As EventDate FROM LoadTable) DerivMain
LEFT OUTER JOIN (SELECT Name, ACNo, MAX(STR_TO_DATE(Date,'%c/%e/%Y %l:%i:%s %p') AS EventDateTime) FROM LoadTable WHERE State = 'Check In' GROUP BY Name, ACNo) DerivCheckIn
ON DerivMain.Name = DerivCheckIn Name AND DerivMain.ACNo = DerivCheckIn.ACNo 
LEFT OUTER JOIN (SELECT Name, ACNo, MAX(STR_TO_DATE(Date,'%c/%e/%Y %l:%i:%s %p') AS EventDateTime) FROM LoadTable WHERE State = 'Out' GROUP BY Name, ACNo) DerivBreakout
ON DerivMain.Name = DerivBreakout Name AND DerivMain.ACNo = DerivBreakout.ACNo 
LEFT OUTER JOIN (SELECT Name, ACNo, MAX(STR_TO_DATE(Date,'%c/%e/%Y %l:%i:%s %p') AS EventDateTime) FROM LoadTable WHERE State = 'Out Back' GROUP BY Name, ACNo) DerivBreakin
ON DerivMain.Name = DerivBreakin Name AND DerivMain.ACNo = DerivBreakin.ACNo 
LEFT OUTER JOIN (SELECT Name, ACNo, MAX(STR_TO_DATE(Date,'%c/%e/%Y %l:%i:%s %p') AS EventDateTime) FROM LoadTable WHERE State = 'Check Out' GROUP BY Name, ACNo) DerivCheckout
ON DerivMain.Name = DerivCheckout Name AND DerivMain.ACNo = DerivCheckout.ACNo 

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM