Metricula Squishie Enthusiast 4040 Posts user info edit post |
yeah, so in summary your problem could be solved by not writing shitty code in the first place.
9/21/2007 11:49:28 PM |
Ernie All American 45943 Posts user info edit post |
OH SNAP YOU TOLD ME 9/22/2007 3:05:22 AM |
qntmfred retired 40726 Posts user info edit post |
anybody know of or use a good PHP DAL for mysql?
[Edited on October 24, 2007 at 11:43 AM. Reason : comparable to subsonic for .net] 10/24/2007 11:42:42 AM |
qntmfred retired 40726 Posts user info edit post |
plz? 10/24/2007 5:15:05 PM |
BigMan157 no u 103354 Posts user info edit post |
you mean like phpMyAdmin?
http://www.phpmyadmin.net/home_page/index.php
[Edited on October 24, 2007 at 5:27 PM. Reason : i don't know what a DAL is ] 10/24/2007 5:27:20 PM |
LeGo All American 3916 Posts user info edit post |
http://en.wikipedia.org/wiki/Data_access_layer
phpmyadmin should be good... 10/24/2007 9:31:42 PM |
qntmfred retired 40726 Posts user info edit post |
not quite. a data-access layer is a toolset that provides object-relational mapping, or a way to turn your tables/rows into objects. an example of what a DAL does is say you have a table called employees with columns id, name, title, payrate - a DAL might generate a class called Employees with public fields Id, Name, Title and Payrate and methods to work with those. PHP has a built-in interface called PDO but it's meh]] 10/25/2007 11:40:55 AM |
GotYoNacho Veteran 280 Posts user info edit post |
Is it possible to have a field with multiple TIMESTAMPS (delimited by something) and then I do a query that returns a row where the current time is greater than any one of those times in that field.
ie
currently it's '2007-10-26 11:43:01'
and the field i want to compare could include (delimited by ||) 2007-10-26 11:40||2007-10-26 11:50||2007-10-26 12:00
I don't have to know which time caused the return to be true, but just that in this above case I would get the row because the current time is past the first time element in the field. 10/26/2007 11:44:48 AM |
DirtyMonkey All American 4269 Posts user info edit post |
If you HAD to do this, I think it is possible with a stored procedure (requires MySQL 5).
This works for the first time entry, but obviously that isn't very helpful.
SELECT NOW() > ( SUBSTR(fieldname, 1, LOCATE('||', fieldname) - 1) FROM tablename, );
You'd need to write a stored procedure to do something like the above for each timestamp, probably provided as a parameter.
But really, this is poor database design. I would avoid that if at all possible.10/26/2007 8:24:10 PM |
msb2ncsu All American 14033 Posts user info edit post |
He is right, that would be a very poor database design. You need a separate table that stores the primary key from your main table and a single TIMESTAMP in each row (if you have 6 delimited TIMESTAMPS now you want 6 rows in the new table). Once you have done that the query will be a snap (not to mention much quicker). String parsing is very slow, you lose the benefit of using a TIMESTAMP in the first place by storing it in a delimited text field. 10/27/2007 12:33:17 AM |
synapse play so hard 60939 Posts user info edit post |
11/14/2007 3:11:23 PM |
qntmfred retired 40726 Posts user info edit post |
11/14/2007 4:06:10 PM |
robster All American 3545 Posts user info edit post |
Is there a single query you can do to get the count like below:
So, table users... with usertype having an integer value.
I want to see the most popular userTypes(integer values) sorted from highest to lowest
So:
244 (55 users) 294 (23 users) ... get the point.
Anyone? THis is more for administrative viewing, and not something that I want to keep track of with increment/decrements
Thanks
[Edited on December 4, 2007 at 12:19 PM. Reason : .] 12/4/2007 12:19:15 PM |
DirtyMonkey All American 4269 Posts user info edit post |
SELECT userType, COUNT(userType) FROM users GROUP BY userType ORDER BY COUNT(userType) DESC 12/4/2007 12:26:19 PM |
robster All American 3545 Posts user info edit post |
sweet thanks 12/4/2007 12:35:10 PM |
Ernie All American 45943 Posts user info edit post |
this is more of a php question than an sql question but i couldn't find a good php thread
full disclosure: i suck equally with both
i'm pulling data from a table using php/mysql
the table is this:
DAY COLOR monday blue monday red tuesday orange wednesday blue thursday orange thursday red friday blue
my code is this:
$query = SELECT day, color, yes FROM table;
$result = mysql_query($query);
while($row = mysql_fetch_row($result)) { $day = $row[0]; $color = $row[1]; $yes = $row[2];
echo "<tr><td>day</td> <td>color</td></tr>";
}
which of course gives me a table that looks exactly like the table that holds the data
what i want is this:
monday blue red tuesday orange wednesday blue thursday orange red friday blue
for whatever reason, i've hit a block and can't figure how to get that to print
i'm sure it's an easy solution, so please help and tell me i'm a retard12/12/2007 7:47:33 PM |
qntmfred retired 40726 Posts user info edit post |
$previousDay = ""; echo "<table>"; while($row = mysql_fetch_row($result)) { $day = $row[0]; $color = $row[1]; $yes = $row[2];
echo "<tr>"; echo "<td>" . (!strcmp($day, $previousDay) ? "" : $day) . "</td>"; echo "<td>$color</td>"; echo "</tr>";
$previousDay = $day; } echo "</table>"; ]12/12/2007 9:44:07 PM |
Ernie All American 45943 Posts user info edit post |
strcmp!
yayayayay 12/12/2007 9:51:21 PM |
qntmfred retired 40726 Posts user info edit post |
¡strcmp!
jajajajaja 12/12/2007 10:22:44 PM |
DirtyMonkey All American 4269 Posts user info edit post |
Ernie: here is a handy group by function.
SELECT day, GROUP_CONCAT(color SEPARATOR ', ') FROM table GROUP BY day;
Of course you can make the SEPARATOR whatever you want. pipe, <br> tag, etc.
The result of the above query would be:
day | color ------------------------------------------ friday | blue monday | blue, red thursday | orange, red tuesday | orange wednesday | blue
[Edited on December 13, 2007 at 1:54 AM. Reason : formatting]12/13/2007 1:51:52 AM |
synapse play so hard 60939 Posts user info edit post |
using ms esql server 2005, is there any way to "simulate" the execution of commands? for example it could be cool to see the results of an update command, to see how many rows it returns before i actually run it. 12/18/2007 11:30:08 AM |
quagmire02 All American 44225 Posts user info edit post |
here y'all go, help this kid out: message_topic.aspx?topic=506667 12/18/2007 11:38:59 AM |
DirtyMonkey All American 4269 Posts user info edit post |
^^ can you not just write a SELECT statement that has the same conditions as your update statement? 12/18/2007 4:27:28 PM |
GotYoNacho Veteran 280 Posts user info edit post |
Table 1 --------------------------------------------------- job | computer_name | status | last_report* | weight --------------------------------------------------- a computer1 running time1 5 b computer2 done time2 2 c computer1 done time3 1 d computer3 done time4 7 e computer1 done time5 10
* assume time1 < time2 < etc.
Table 2 -------------------------------------------- computer_name | computer_status -------------------------------------------- computer1 online computer2 online computer3 offline
Want Results ---------------------------------------------------------------- computer_name | computer_status | SUM(weight)* | MAX(last_report)** ---------------------------------------------------------------- computer1 online 5 time3 computer2 online 0 time2 computer3 offline 0 time4
* only weight of running jobs ** latest time of any job on that computer
How do I get this wanted table?
[Edited on January 15, 2008 at 10:32 AM. Reason : format] 1/15/2008 10:31:20 AM |
DirtyMonkey All American 4269 Posts user info edit post |
^ try this, but i haven't tested it out or anything.
SELECT t2.computer_name, t2.computer_status, SUM(t1.weight), MAX(t1.last_report) FROM table2 t2 LEFT JOIN table1 t1 ON t1.computer_name = t2.computer_name GROUP BY t1.computer_name WHERE t1.status = 'running'
1/15/2008 12:25:45 PM |
Talage All American 5093 Posts user info edit post |
^ I think this might cause a problem. If a computer isn't running anything I dont' think it will show up on the results.
Quote : | "WHERE t1.status = 'running' " |
Do you need the results to return all computers GetYoNacho?
[Edited on January 15, 2008 at 12:33 PM. Reason : .]1/15/2008 12:31:47 PM |
GotYoNacho Veteran 280 Posts user info edit post |
^ that is the problem, and I do want all the computers in the results
basically, if there are jobs running, i want to sum of the weight for that job. if there are no jobs running, then the weight would be 0
[Edited on January 15, 2008 at 12:35 PM. Reason : .] 1/15/2008 12:32:33 PM |
Talage All American 5093 Posts user info edit post |
I think you could probably use a subselect to pull it off. I have to run to class now, but if there is still no solution when I get out I'll whip something up. 1/15/2008 12:42:50 PM |
DirtyMonkey All American 4269 Posts user info edit post |
sorry, i thought you mean only get computers with jobs. in that case, do this:
SELECT t2.computer_name, t2.status, SUM(IF(t1.status = 'running',t1.weight,0)) AS 'weight', MAX(t1.last_report) AS 'last_report' FROM table1 t1 LEFT JOIN table2 t2 ON t1.computer_name = t2.computer_name GROUP BY t1.computer_name
1/15/2008 1:10:49 PM |
GotYoNacho Veteran 280 Posts user info edit post |
^ That works great. Thanks.
I thought I had tried that earlier, but I was doing IF(SUM(...)). DOH
[Edited on January 15, 2008 at 1:20 PM. Reason : .] 1/15/2008 1:18:41 PM |
DirtyMonkey All American 4269 Posts user info edit post |
this may be impossible or the wrong way of doing it, but here's what i want to get...
i have a table with two columns: id and price. i want to get a list of the number of items that fall into a price range, say in groups of $100. it won't always be $100 and i wont' know the maximum range.
so if the table looks like this:
id | price --------------- 1 | 57 2 | 34 3 | 79 4 | 125 5 | 113 6 | 85
i would want a result of something like:
range | number_of_items ------------------------------ 0 - 50 | 1 50 - 100 | 3 100 - 150 | 2
i know i could do a bunch of selects with ... WHERE price BETWEEN x AND y ... unioned together, but i would rather this be more dynamic than that.
any ideas?4/9/2008 3:18:10 PM |
Stein All American 19842 Posts user info edit post |
GROUP BY FLOOR(price / 50)
then in your select you just multiply that out for the range -- it'll give you 0-49, 50-99 though 4/9/2008 3:22:46 PM |
DirtyMonkey All American 4269 Posts user info edit post |
thanks! that works great and much easier than what i was trying to do. 4/9/2008 3:49:02 PM |
synapse play so hard 60939 Posts user info edit post |
^^ hey thats pretty cool. i would have overcomplicated it with case statements 4/9/2008 3:53:01 PM |
DirtyMonkey All American 4269 Posts user info edit post |
How do you copy/rename an InnoDB database with relational restraints (with MySQL)? If I use phpmyadmin, it just tries to (in alphabetical order) copy table structure, copy table data, move to next table. Usually this fails very early with a foreign key constraint error. I had to manually copy each table over in order so that the restraints would hold up, but surely there is better way. Does anyone know it? 5/1/2008 12:04:22 PM |
philihp All American 8349 Posts user info edit post |
^^agreed 5/1/2008 3:13:18 PM |
jbtilley All American 12797 Posts user info edit post |
Smacks forehead - easy answer to the question I had - getting old I suppose.
[Edited on May 22, 2008 at 9:11 PM. Reason : -] 5/22/2008 9:04:13 PM |
qntmfred retired 40726 Posts user info edit post |
ok, say this is my table structure
fruit fruit_id name -------- ---- 1 apple 2 orange 3 banana
store store_id name -------- ---- 1 Food Lion 2 Harris Teeter 3 Lowe's 4 Piggly Wiggly
store_purchase purchase_id fruit_id store_id timestamp ----------- -------- -------- --------- 1 1 1 1-May 2 1 2 9-May 3 1 3 6-May 4 2 1 4-May 5 2 2 2-May 6 2 4 12-May 7 3 2 3-May 8 3 3 15-May 9 3 1 7-May 10 3 4 5-May
i want a query that will give me for each store, what was the last fruit bought and when like this
store name fruit name purchase timestamp ---- ----- --------- Food Lion banana 7-May Harris Teeter apple 9-May Lowe's banana 15-May Piggle Wiggly orange 12-May ]5/23/2008 9:58:28 AM |
Wolfmarsh What? 5975 Posts user info edit post |
Is the timestamp an actual datetime field, or is it text like that? 5/23/2008 10:12:33 AM |
qntmfred retired 40726 Posts user info edit post |
datetime
[Edited on May 23, 2008 at 10:15 AM. Reason : just typed it like that for readability]
btw, here's a sql server backup if anybody wants to play with it http://ken.kaisia.com/tww/stores.bak
[Edited on May 23, 2008 at 10:24 AM. Reason : i didn't bother doing foreign keys or anything since it's a small sample db] 5/23/2008 10:14:30 AM |
qntmfred retired 40726 Posts user info edit post |
i can do
select s.name, max(p.timestamp) from fruit f, store s, purchases p where p.fruit_id=f.fruit_id and p.store_id=s.store_id group by s.name order by max(p.timestamp) desc
and it works but i can't get f.name b/c i get "Column 'fruit.name' is invalid in the select list because it is not contained in either an aggregate function or the GROUP BY clause"
i have the feeling i have to do a left join or something but i'm just not seeing it 5/23/2008 10:33:16 AM |
qntmfred retired 40726 Posts user info edit post |
^ doesn't work as well as i thought. i need to do group by s.store_id, not s.name since name is not necessarily unique. so then i'll get the group by error on store name and fruit name 5/23/2008 10:52:19 AM |
OmarBadu zidik 25071 Posts user info edit post |
select top (select distinct count(*) from store) s.name, f.name, timestamp from fruit f, store s, purchases p where f.fruit_id = p.fruit_id and s.store_id = p.store_id group by s.name , f.name, timestamp order by timestamp desc 5/23/2008 10:52:42 AM |
qntmfred retired 40726 Posts user info edit post |
that works for the example, but the group by should be on s.store_id, f.fruit_id and that breaks it 5/23/2008 10:58:14 AM |
DirtyMonkey All American 4269 Posts user info edit post |
SELECT s.name, f.name, p.timestamp FROM store s LEFT JOIN store_purchase p ON p.store_id = s.store_id LEFT JOIN fruit f ON f.fruit_id = p.fruit_id GROUP BY p.store_id ORDER BY p.timestamp DESC
oops, i used the wrong table alias on line 4.
[Edited on May 23, 2008 at 11:34 AM. Reason : ALI] 5/23/2008 11:24:37 AM |
evan All American 27701 Posts user info edit post |
^ 5/23/2008 11:27:13 AM |
DirtyMonkey All American 4269 Posts user info edit post |
hmm, since the order by is getting applied after the group, it gives the wrong results. you can do this, but i'm not sure if it's the most efficient query...
SELECT t.store_name, t.fruit_name, t.ts FROM ( SELECT s.name AS 'store_name', s.store_id, f.name AS 'fruit_name', p.ts FROM store s LEFT JOIN store_purchase p ON p.store_id = s.store_id LEFT JOIN fruit f ON f.fruit_id = p.fruit_id ORDER BY p.ts DESC )t GROUP BY t.store_id
[Edited on May 23, 2008 at 11:47 AM. Reason : crazy code]5/23/2008 11:47:31 AM |
qntmfred retired 40726 Posts user info edit post |
here's the solution my coworker came up with, it works for the sample db, i'm about to see if it works for the real db
select store.name, fruit.name, table1.date_purchased from (select purchase_id, fruit_id, store_id, date_purchased from dbo.store_purchase p where purchase_id = (select top(1)purchase_id from dbo.store_purchase where store_id = p.store_id order by store_purchase.date_purchased desc)) as table1, dbo.fruit, dbo.store where table1.fruit_id = fruit.fruit_id and table1.store_id = store.store_id order by table1.date_purchased 5/23/2008 11:54:42 AM |
OmarBadu zidik 25071 Posts user info edit post |
stupid sorted example ]] 5/23/2008 12:00:49 PM |
qntmfred retired 40726 Posts user info edit post |
:p 5/23/2008 12:06:09 PM |