Jump to content

Recommended Posts

Hey!

 

I know i'm full of questions today. And I really appreciate all the help. But here's another... :) (Wasn't sure if I should put this in PHP or SQL forum, but it has PHP in it so I chose this one).

 

I'm having a bit of trouble formatting the date in an SQL insert statement. The date being inserted is from a variable, and is in the DD/MM/YYYY format. Do I need to format it to the default MySQL format?

 

I've tried the following:

 

INSERT INTO database(date) VALUES(DATE_FORMAT('$dateStore','%Y %m %d'))

 

Is this on the right track?

 

Cheers.

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/
Share on other sites

it should be DATETIME or DATE in your mysql    ;)

 

explained here

 

http://dev.mysql.com/doc/refman/5.1/en/datetime.html

 

Hmm.. I read the article but i'm still confused as how to actually change to way the date is formatted..

 

Do I still use this kind of format:

 

INSERT INTO database(date) VALUES(DATE('$dateStore','%Y %m %d'))?

                                                     

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889403
Share on other sites

Make the Database Column Type a DATETIME in your PHPMYADMIN, also dont use Date_Format, theres another way

 

You can make $datestore a timestamp and use


mysql> SELECT FROM_UNIXTIME('$datestore',
    ->                      '%Y %D %M');
        -> '2007 30th November 10:30:59 2007'

 

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889406
Share on other sites

Make the Database Column Type a DATETIME in your PHPMYADMIN, also dont use Date_Format, theres another way

 

You can make $datestore a timestamp and use


mysql> SELECT FROM_UNIXTIME('$datestore', '%Y %D %M');
        -> '2007 30th November 10:30:59 2007'

 

 

Hmm.. Not too sure I understand that. Sorry, i'm still learning when it comes to PHP and SQL. I'm getting better but some things still confuse the crap outta me, haha.

 

You able to give a brief explanation to how that works? :)

 

Thanks :P

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889410
Share on other sites

<?php
$datestore = time(); // time will generate a UNIX TIMESTAMP 1199167200
$sql = mysql_query("INSERT INTO table_name (`date`) VALUES (FROM_UNIXTIME('$datestore', '%Y %D %M'))");
?>

 

As you can see it converts the Timestamp we generated using the time() function into your own format. Now this will go into your DATABASE in a column called "date", the TYPE of column for the date must be DATETIME (Y M D HH:MM:SS) or DATE (Y M D) in order for it to function properly...

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889430
Share on other sites

Ok, understood. Thanks :)

 

However, the $dateStore variable actually has a date stored in it which needs to be kept. So i'm not needing to actually generate a time or date here, just change the format of the date that I already have.

 

Oh thats a different story then... Alright post your script for your $datestore, where you set the date. I want to see the format.

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889439
Share on other sites

Well the date is taken from a CSV file using the following script:

 

$file_handle = fopen("deliveries.csv", "rb");

while (!feof($file_handle) ) {

$line_of_text = fgets($file_handle);
$parts = explode(',', $line_of_text);

print $parts[0] . $parts[1]. $parts[2]. $parts[3]. $parts[4]. $parts[5]. $parts[6]. $parts[7]. "<BR>";

 

Date is stored in $parts[0] (I used $dateStore in above post for clarity).

 

In the CSV file itself, the date is in a simple DD/MM/YYYY format.

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889447
Share on other sites

alright try this then

 

<?php

$datestore = strtotime(str_replace("/","-",$datestore));
$sql = mysql_query("INSERT INTO table_name (`date`) VALUES (FROM_UNIXTIME('$datestore', '%Y %D %M'))");

?>

 

What part of that do I need to incorporate my already stored date into ($parts[0])?

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889457
Share on other sites

theres a missing single quote before the $parts[0]

 

here try this now

 

$datestore = strtotime(str_replace("/","-",$parts[0]));
$sql="INSERT INTO deliveryInformation(deliveryDate,psNumber,numItems,volume)
VALUES('$datestore','$parts[2]','$parts[3]','$parts[7]')";

 

Hmm it's inserting the records, but all the dates are 0000-00-00.

 

I suspect it's something to do with my code rather than yours.

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889465
Share on other sites

hoping you changed the data type to DATE, yuo can actually just do this

 

$datestore = str_replace("/","-",$parts[0]);
$sql="INSERT INTO deliveryInformation(deliveryDate,psNumber,numItems,volume)
VALUES('$datestore','$parts[2]','$parts[3]','$parts[7]')";

 

 

the DATE type requires this format 0000-00-00

 

so 08/20/09 lets say would convert to 2008-20-09

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889472
Share on other sites

hoping you changed the data type to DATE, yuo can actually just do this

 

$datestore = str_replace("/","-",$parts[0]);
$sql="INSERT INTO deliveryInformation(deliveryDate,psNumber,numItems,volume)
VALUES('$datestore','$parts[2]','$parts[3]','$parts[7]')";

 

 

the DATE type requires this format 0000-00-00

 

so 08/20/09 lets say would convert to 2008-20-09

 

Yep, the database field is set to DATE type.

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889479
Share on other sites

Hmmm now i'm really confused. In the CVS file, there's 8 different pieces of data that are seperated by commas. The script puts them into $parts[0] through $parts[7] ($parts[0] being the date). But when I try to echo them out to the page, it comes back blank. Yet the SQL statements are putting everything in the database correctly except for the date, so the data is definitely in the $parts variable as it should be.

 

Quite confused now... any ideas as to why this would be?

 

Here's the entire script:

 

<?php
$con = mysql_connect("localhost","root","password");
if (!$con)
  {
  die('Could not connect: ' . mysql_error());
  }

mysql_select_db("database", $con);

$file_handle = fopen("deliveries.csv", "rb");

while (!feof($file_handle) ) {
$line_of_text = fgets($file_handle);
$parts = explode(',', $line_of_text);
//Seperate parts of CSV file where there is a comma

$sql="INSERT INTO customer (customerName, address1, address2, address3)
VALUES
('$parts[1]','$parts[4]','$parts[5]','$parts[6]')";
//The above works correctly

$datestore = strtotime(str_replace("/","-",$parts[0]));
$sql="INSERT INTO deliveryInformation(deliveryDate,psNumber,numItems,volume)
VALUES('$datestore','$parts[2]','$parts[3]','$parts[7]')";
//$parts 2,3,7 are inserted correctly, but date shows as 0000-00-00

mysql_query($sql);
}

fclose($file_handle);

if (!mysql_query($sql,$con))
  {
  die('Error: ' . mysql_error());
  }
else
{
echo "Records submitted.";
}
   
   mysql_close($con);
   
?>

 

Sample line of CVS file:

16/07/2009,CUSTOMER,170932,2,ADDRESS1,ADDRESS2,ADDRESS3,1.42

 

By the way, thanks for all the help phpSensei, I really appreciate it :) Off to bed now, but i'll check back in the morning.

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-889537
Share on other sites

change

$line_of_text = fgets($file_handle);
$parts = explode(',', $line_of_text);

 

to

 

$line_of_text = fgets($file_handle);
$parts = explode(',', $line_of_text);
print_r($partS);

 

whats the output?

 

Array ( [0] => 16/07/2009 [1] => CUSTOMER [2] => 170372 [3] => 2 [4] => ADDRESS1 [5] => ADDRESS2 [6] => ADDRESS3 [7] => 0.33 => [8]

 

(have censored out address and customer for obvious reasons)

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-890136
Share on other sites

change

$line_of_text = fgets($file_handle);
$parts = explode(',', $line_of_text);

 

to

 

$line_of_text = fgets($file_handle);
$parts = explode(',', $line_of_text);
print_r($partS);

 

whats the output?

 

Array ( [0] => 16/07/2009 [1] => CUSTOMER [2] => 170372 [3] => 2 [4] => ADDRESS1 [5] => ADDRESS2 [6] => ADDRESS3 [7] => 0.33 => [8]

 

(have censored out address and customer for obvious reasons)

 

$parts[0] is 16/07/2009, I dont understand why its not printing out to the page...

 

did you do print $parts[0]?

Link to comment
https://forums.phpfreaks.com/topic/168610-formatting-date/#findComment-890157
Share on other sites

This thread is more than a year old. Please don't revive it unless you have something important to add.

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.

Guest
Reply to this topic...

×   Pasted as rich text.   Restore formatting

  Only 75 emoji are allowed.

×   Your link has been automatically embedded.   Display as a link instead

×   Your previous content has been restored.   Clear editor

×   You cannot paste images directly. Upload or insert images from URL.

×
×
  • Create New...

Important Information

We have placed cookies on your device to help make this website better. You can adjust your cookie settings, otherwise we'll assume you're okay to continue.