|   |   |   | ||||
| Welcome to the GoFuckYourself.com - Adult Webmaster Forum forums. You are currently viewing our boards as a guest which gives you limited access to view most discussions and access our other features. By joining our free community you will have access to post topics, communicate privately with other members (PM), respond to polls, upload content and access many other special features. Registration is fast, simple and absolutely free so please, join our community today! If you have any problems with the registration process or your account login, please contact us. | 
|    | 
| 
 | |||||||
| Discuss what's fucking going on, and which programs are best and worst. One-time "program" announcements from "established" webmasters are allowed. | 
|  | Thread Tools | 
|  03-23-2007, 09:37 AM | #1 | 
| Confirmed User Join Date: Dec 2003 Location: 1123,6536,5231 
					Posts: 3,397
				 | 
				
				MySQL / PHP gurus help with this code?
			 I have tried a couple help forums and #php but no luck so far. I have a varchar field (date) with a date in MM-DD-YYYY format. I need to convert this to my (date2) field which is DATE in the YYYY-MM-DD format. Here is the sql statement I have so far - and it doesn't work: UPDATE b1datefix t1, b1datefix t2 SET t1.date2 = DATE_FORMAT(t1.date,'%Y-%m-%d') WHERE t1.id=t2.id; Any ideas? | 
|   |           | 
|  03-23-2007, 09:41 AM | #2 | 
| Confirmed User Join Date: Jun 2006 
					Posts: 530
				 | i dont work with mysql, but i'd think it would have some sort of globalization stuff built in so that it can natively accept the mm-dd-yyyy date format? | 
|   |           | 
|  03-23-2007, 09:46 AM | #3 | 
| Confirmed User Join Date: Dec 2003 Location: 1123,6536,5231 
					Posts: 3,397
				 | The problem is that half of my DB is one format and half is the other. If sponsors used the same damn date format I wouldn't have this problem. So I am selecting queries based on a certain format and I don't want to run checks at the php level before running queries it just slows the process down. | 
|   |           | 
|  03-23-2007, 09:58 AM | #4 | 
| Registered User Join Date: Jul 2004 Location: Montreal 
					Posts: 40
				 | If you were to do it in PHP check out the strtotime() function, get the timestamp, then use date() to get it back into the format you need. Not the cleanest but it would work. | 
|   |           | 
|  03-23-2007, 10:00 AM | #5 | 
| Confirmed User Join Date: Apr 2002 Location: /root/ 
					Posts: 4,997
				 | You'll have to do it from the application. The date_format and other functions expect a date in the default format %Y-%m-%d | 
|   |           | 
|  03-23-2007, 10:11 AM | #6 | 
| Confirmed User Join Date: Dec 2003 Location: 1123,6536,5231 
					Posts: 3,397
				 | |
|   |           | 
|  03-23-2007, 10:13 AM | #7 | 
| Confirmed User Industry Role:  Join Date: Jun 2004 Location: New York, NY 
					Posts: 6,890
				 | Try something like this (I'm not awake yet so might have a typo in there heh) UPDATE b1datefix SET date2 = CONCAT(SUBSTRING(date,-4),'-',SUBSTRING(date,1,2),'-',SUBSTRING(date,FROM -7 FOR 2)); Enjoy  
				__________________ Skype variuscr - Email varius AT gmail | 
|   |           | 
|  03-23-2007, 10:30 AM | #8 | 
| Confirmed User Join Date: Dec 2003 Location: 1123,6536,5231 
					Posts: 3,397
				 | Keith I think that would work, only problem is I am getting a syntax error and this is too advanced for me to troubleshoot: #1064 - You have an error in your SQL syntax. Check the manual that corresponds to your MySQL server version for the right syntax to use near 'FROM -7 FOR 2))' at line 1 | 
|   |           | 
|  03-23-2007, 10:48 AM | #9 | |
| Confirmed User Industry Role:  Join Date: Jun 2004 Location: New York, NY 
					Posts: 6,890
				 | Quote: 
  - Damn comma. Try this: UPDATE b1datefix SET date2 = CONCAT(SUBSTRING(date,-4),'-',SUBSTRING(date,1,2),'-',SUBSTRING(date FROM -7 FOR 2)); 
				__________________ Skype variuscr - Email varius AT gmail | |
|   |           | 
|  03-23-2007, 10:48 AM | #10 | |
| Confirmed User Industry Role:  Join Date: Aug 2005 Location: Costa Rica 
					Posts: 465
				 | Quote: 
 he wrote that he wasn't fully awake ;) there is some garbage in the sql, (FROM and FOR).. the sql should read: UPDATE b1datefix SET date2 = CONCAT(SUBSTRING(date,-4),'-',SUBSTRING(date,1,2),'-',SUBSTRING(date, -7,2)); let us know how it goes ;) peace 
				__________________ -- "You can't stop ingenuity, trust me.."   | |
|   |           | 
|  03-23-2007, 10:51 AM | #11 | |
| Registered User Join Date: Feb 2007 
					Posts: 21
				 |   Quote: 
  That method is actually quite common and is a good choice, IMO.  to RichCashMike | |
|   |           | 
|  03-23-2007, 10:54 AM | #12 | |
| Confirmed User Industry Role:  Join Date: Jun 2004 Location: New York, NY 
					Posts: 6,890
				 | Quote: 
  
				__________________ Skype variuscr - Email varius AT gmail | |
|   |           | 
|  03-23-2007, 11:05 AM | #13 | 
| Confirmed User Join Date: Dec 2003 Location: 1123,6536,5231 
					Posts: 3,397
				 | I ran the command and it affected all of the rows but it didn't pull in the date. All of the dates came in as: 0000-00-00 So something is wonky and I can't figure it out. | 
|   |           | 
|  03-23-2007, 11:12 AM | #14 | |
| Confirmed User Industry Role:  Join Date: Jun 2004 Location: New York, NY 
					Posts: 6,890
				 | Quote: 
 run that to see what comes out. 
				__________________ Skype variuscr - Email varius AT gmail | |
|   |           | 
|  03-23-2007, 11:15 AM | #15 | 
| Confirmed User Join Date: Dec 2003 Location: 1123,6536,5231 
					Posts: 3,397
				 | Keith, 10 rows of -02- | 
|   |           | 
|  03-23-2007, 11:39 AM | #16 | 
| Confirmed User Industry Role:  Join Date: Jun 2004 Location: New York, NY 
					Posts: 6,890
				 | What version of mysql are you using ? I don't see why the first/last substrings wouldn't work unless it's a version thing. I made a test case for oyu actually and on my server it works perfectly: mysql> desc datefix; +-------+-------------+------+-----+---------+-------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+-------+ | date1 | varchar(10) | YES | | NULL | | | date2 | date | YES | | NULL | | +-------+-------------+------+-----+---------+-------+ 2 rows in set (0.00 sec) mysql> select * from datefix; +------------+-------+ | date1 | date2 | +------------+-------+ | 03-23-2007 | NULL | +------------+-------+ 1 row in set (0.00 sec) mysql> SELECT CONCAT(SUBSTRING(date1,-4),'-',SUBSTRING(date1,1,2),'-',SUBSTRING(date1 FROM -7 FOR 2)) from datefix; +-----------------------------------------------------------------------------------------+ | CONCAT(SUBSTRING(date1,-4),'-',SUBSTRING(date1,1,2),'-',SUBSTRING(date1 FROM -7 FOR 2)) | +-----------------------------------------------------------------------------------------+ | 2007-03-23 | +-----------------------------------------------------------------------------------------+ 1 row in set (0.00 sec) 
				__________________ Skype variuscr - Email varius AT gmail | 
|   |           | 
|  03-23-2007, 11:40 AM | #17 | 
| Confirmed User Join Date: Nov 2005 Location: Seattle, WA 
					Posts: 510
				 | Or avoid mysql's functions, and just get the data then update the data PHP Code: 
			
				__________________ ICQ: 275335837 | 
|   |           | 
|  03-23-2007, 11:46 AM | #18 | |
| Confirmed User Industry Role:  Join Date: Jun 2004 Location: New York, NY 
					Posts: 6,890
				 | Quote: 
   However I think for Brad's purpose here doing it in mysql would be preferred instead of in the code...he could even use mysql's schedule feature to have it run every 5 mins or whatever he wishes, so no need to alter any code anywhere or even setup any cronjobs. 
				__________________ Skype variuscr - Email varius AT gmail | |
|   |           | 
|  03-23-2007, 11:48 AM | #19 | 
| Confirmed User Join Date: Dec 2003 Location: 1123,6536,5231 
					Posts: 3,397
				 | MySQL 4.0.26-standard  That's probably why there is a problem. :/ | 
|   |           | 
|  03-23-2007, 11:52 AM | #20 | 
| Confirmed User Join Date: Nov 2005 Location: Seattle, WA 
					Posts: 510
				 | Yah both ways work, would really depend on how often it needs to be done, if the source of the input could be switched/fixed. 
				__________________ ICQ: 275335837 | 
|   |           | 
|  03-23-2007, 11:54 AM | #21 | 
| Confirmed User Industry Role:  Join Date: Jun 2004 Location: New York, NY 
					Posts: 6,890
				 | I don't have any version 4.x around anymore so can't help you much there...I would say move to 5.1 the are a LOT of new features to like plus upgrading is like a 5-10 minute job if you know how to do it. Otherwise, yeah you are probably stuck doing it on the php end. Last try that might work for you since the middle one did work form your output: CONCAT(SUBSTRING(date,7,4),'-',SUBSTRING(date,1,2),'-',SUBSTRING(date,4,2)) 
				__________________ Skype variuscr - Email varius AT gmail | 
|   |           | 
|  03-23-2007, 11:56 AM | #22 | 
| Confirmed User Join Date: Dec 2003 Location: 1123,6536,5231 
					Posts: 3,397
				 | |
|   |           | 
|  03-23-2007, 12:01 PM | #23 | |
| Confirmed User Industry Role:  Join Date: Jun 2004 Location: New York, NY 
					Posts: 6,890
				 | Quote: 
   Guess this means I'm finally awake now and should head in to the office...later  
				__________________ Skype variuscr - Email varius AT gmail | |
|   |           | 
|  03-23-2007, 12:05 PM | #24 | |
| Confirmed User Join Date: Apr 2003 Location: Loveland, CO 
					Posts: 5,526
				 | Quote: 
 I would if I had an epiphany like that. BTW - fun thread to watch... thanks geeks.  
				__________________ Your post count means nothing. | |
|   |           |