User not logged in - login - register
Home Calendar Books School Tool Photo Gallery Message Boards Users Statistics Advertise Site Info
go to bottom | |
 Message Boards » » SQL query help thread... Page [1] 2 3 4 5 6 7, Next  
bous
All American
11215 Posts
user info
edit post

i'll start it off

say i have multiple rows of data and each have the following numbers in a column:

0.125
0.050
-0.025
-0.125


how do i find the one closest to zero? if 2 are just as close to zero, take the positive one...

limit 1 closest to zero ... if a positive and negative are just as close to zero, take the positive...

7/8/2007 2:36:03 PM

Lowjack
All American
10491 Posts
user info
edit post

min(abs(col_name)) order desc by col_name limit 1

7/8/2007 3:21:15 PM

synapse
play so hard
60935 Posts
user info
edit post

nice thread, i'll be posting in it soon

7/8/2007 3:40:16 PM

ScHpEnXeL
Suspended
32613 Posts
user info
edit post

me too

7/8/2007 3:50:16 PM

bous
All American
11215 Posts
user info
edit post

Quote :
"min(abs(col_name)) order desc by col_name limit 1"


select DISTINCT a,b,min(abs(c)) from table where 91 < this and 75 > that group by a order by c desc;


that worked and actually let me select the one closest to zero for each 'a' (group by did that).


PROBLEM:

by selecting the absolute value of c ... it returns that so i don't know which results are positive or negative...

PROBLEM 2:

looks like it's actually still selecting the most negative 'c' and not comparing which is closest to zero absolutely

[Edited on July 8, 2007 at 8:02 PM. Reason : ]

7/8/2007 7:36:40 PM

bous
All American
11215 Posts
user info
edit post

absolute isn't actually working... if i remove absolute it returns the same results just w/o the absolute value returned....

so it's not actually comparing which is closest to zero absolutely




what if i wanted to find results closest to the number 1?


[Edited on July 8, 2007 at 8:16 PM. Reason : ]

7/8/2007 8:06:38 PM

Stein
All American
19842 Posts
user info
edit post

Giving us actually SQL queries that don't involve "this" and "that", along with actual ideas of the data you're using is a good way to actually get help.

7/9/2007 12:25:20 AM

DirtyMonkey
All American
4269 Posts
user info
edit post

Given a table with those 4 values you originally posted, this (similar to what Lowjack posted) worked for me in MySQL.

SELECT MIN(ABS(num)), num FROM test GROUP BY ABS(num) ORDER BY num ASC LIMIT 1;

I added the second field so you get the actual value and grouped on ABS(num).

As for how to get values close to 1, that is tricky. I will get back to you... probably after someone else does

7/9/2007 12:32:36 AM

Lowjack
All American
10491 Posts
user info
edit post

^yes, that's the idea. Not sure what the group by is for there.

Quote :
"select DISTINCT a,b,min(abs(c)) from table where 91 < this and 75 > that group by a order by c desc;


that worked and actually let me select the one closest to zero for each 'a' (group by did that).
"


No one knows wtf this means.

Quote :
"
PROBLEM:

by selecting the absolute value of c ... it returns that so i don't know which results are positive or negative...
"


That's why you sort by c (as dirtymonkey shows, you might have to include that in the selected fields to sort by it).

Quote :
"PROBLEM 2:

looks like it's actually still selecting the most negative 'c' and not comparing which is closest to zero absolutely
"


That's weird. You can also just square c instead of absolute value.

7/9/2007 12:47:38 AM

DirtyMonkey
All American
4269 Posts
user info
edit post

^ the group is there only because it wouldn't let me select the abs and the original value without it - it threw an error.

7/9/2007 12:52:55 AM

Lowjack
All American
10491 Posts
user info
edit post

I see. I will try it out at work tomorrow. Does squaring eliminate the need to do the group by?

7/9/2007 1:10:23 AM

ScHpEnXeL
Suspended
32613 Posts
user info
edit post

i'll solve this shit for you in the morning if it's still not fixed.. too tired right now

7/9/2007 2:52:55 AM

LeGo
All American
3916 Posts
user info
edit post

Quote :
"As for how to get values close to 1, that is tricky. I will get back to you... probably after someone else does "



SELECT top 1 ABS(num - 1) as diffNum, num FROM test ORDER BY diffNum ASC ;


something like that?

7/9/2007 11:46:55 AM

DirtyMonkey
All American
4269 Posts
user info
edit post

while trying to figure out the "close to 1" problem I found an error in my previous query that i didn't notice until adding more test rows. this one is simpler and doesn't require any grouping. plus, it works


SELECT ABS(num), num FROM test ORDER BY ABS(num) ASC LIMIT 1;


also you may notice that it is pretty much the same as lowjacks original, but without the MIN(), which is why we don't need the group by any more.

[Edited on July 9, 2007 at 6:49 PM. Reason : credit where it is due.]

7/9/2007 6:48:15 PM

LeGo
All American
3916 Posts
user info
edit post

the close to 1 was easy to do. since you know how to find the closest to 0. You subtract one from each and you can do basically the same query.

from this you can find the closest to x, by adding the inverse of the number you want to find.

depending on what you want to accomplish/the end goal and the database you are using there might be easier ways to do these things. but for a query this will work.

any other ones?

7/9/2007 8:18:25 PM

Spar
Veteran
205 Posts
user info
edit post

What's the proper way to run a query by dates? Like I want all entries before 1/1/1972... But I get a data mismatch error.

7/12/2007 3:01:38 PM

qntmfred
retired
40723 Posts
user info
edit post

are you formatting it correctly? YYYY-MM-DD HH:MM:SS for datetimes, YYYY-MM-DD for dates

[Edited on July 12, 2007 at 3:16 PM. Reason : ie use 1972-01-01 not 1/1/1972]

7/12/2007 3:15:51 PM

Spar
Veteran
205 Posts
user info
edit post

I think it has the damn dates stored as a string.

7/12/2007 3:17:17 PM

qntmfred
retired
40723 Posts
user info
edit post

d'oh

7/12/2007 3:33:44 PM

Spar
Veteran
205 Posts
user info
edit post

Yeah. All the date fields are stored as a string. I don't have write access. Only read to run queries for data mining. WTF do I so. I need to stratify the data into date ranges.

7/12/2007 3:52:16 PM

BigMan157
no u
103354 Posts
user info
edit post

what's the date format?

like is it a string like '12/4/03' or a string like 'December 4th, 2003'?

7/12/2007 4:13:52 PM

Spar
Veteran
205 Posts
user info
edit post

stored like 12/23/1986

7/12/2007 4:30:25 PM

LeGo
All American
3916 Posts
user info
edit post

what db are you using...

something like this could work


SELECT * FROM DataBaseTable WHERE CONVERT(DATETIME, theDateColumnThatIsStoredAsString) > '19720101'

but ofcourse the proper way is to store dates as dates, not strings does that work?

[Edited on July 12, 2007 at 5:27 PM. Reason : t]

7/12/2007 5:26:51 PM

Lowjack
All American
10491 Posts
user info
edit post

Migrate the database to modernity.

7/12/2007 10:28:18 PM

Spar
Veteran
205 Posts
user info
edit post

Ok.. decided not to deal with this shit in MS Access. How do I export 137k rows of data into Excel? Excel sheets have 65k limits, trying to selectively extract 60k (in batches) crashes Access.

7/16/2007 1:05:03 PM

LeGo
All American
3916 Posts
user info
edit post

mysql.com

7/16/2007 1:09:16 PM

qntmfred
retired
40723 Posts
user info
edit post

you could export it to a tab-delimited file and use a text editor to copy/paste your rows to excel

thought whats the point in involving excel if it can't handle all your rows in one sheet anyways

7/16/2007 1:09:48 PM

LeGo
All American
3916 Posts
user info
edit post

are you trying to export the whole db (assuming there is more than the dates)? if so just create a unique key (if it doesn't exist) and export those two columns if they can fit into excel. then sort in excel... figure out which you need and then you have those keys to link back into access.

do you have access to visdata?

7/16/2007 5:06:29 PM

Noen
All American
31346 Posts
user info
edit post

Update to Office 2007.

It lets you have something like 6 million rows and 65k columns.

7/16/2007 6:04:00 PM

bous
All American
11215 Posts
user info
edit post

Quote :
"SELECT ABS(num), num FROM test ORDER BY ABS(num) ASC LIMIT 1;"


thanks that worked great!

7/16/2007 9:56:03 PM

Spar
Veteran
205 Posts
user info
edit post

no... just query results...137k, entire database is much much bigger

7/16/2007 10:10:52 PM

Spar
Veteran
205 Posts
user info
edit post

Okay.. i got TOAD installed.

It connects to the database but it cannot find the tables. Do I need to setup a ODBC driver for TOAD?

7/23/2007 1:06:32 PM

Lowjack
All American
10491 Posts
user info
edit post

Does anyone here run MySQL Cluster?

7/23/2007 11:16:53 PM

Spar
Veteran
205 Posts
user info
edit post

Is this right? It's a subselect.... Basically the first statement returns around 26k entries. Second statement returns 13k entries that overlaps with the 26k from first. I want a list of unique entries that is the difference between the two statements.

Quote :
"
SELECT DISTINCT B.BOX_ID
FROM RIMS.BOXES B
WHERE (((B.BOX_LOCATOR) Is Null) AND ((B.BOXLOC)='WESTPTRC'))
AND B.box_id NOT IN
(SELECT DISTINCT B.BOX_ID
FROM RIMS.BOXES B, RIMS.FOLDERS f
WHERE (((B.BOX_LOCATOR) Is Null) AND ((B.BOXLOC)='WESTPTRC'))
AND f.box_id = B.box_id);
"

7/27/2007 1:39:35 PM

msb2ncsu
All American
14033 Posts
user info
edit post

If I understand what you are asking for then this should do it...

SELECT B.BOX_ID FROM RIMS.BOXES B LEFT JOIN RIMS.FOLDERS f ON B.box_id=f.box_id WHERE (B.BOX_LOCATOR IS NULL) AND (B.BOXLOC='WESTPTRC');

However, were you asking for unique entries in B only or unique entries in both B and f?

7/27/2007 2:26:53 PM

Spar
Veteran
205 Posts
user info
edit post

unique entries in B.. let me try that, thanks

Okay... tried it, did not return what I wanted...

Quote :
"SELECT DISTINCT B.BOX_ID
FROM RIMS.BOXES B LEFT JOIN RIMS.FOLDERS f ON B.box_id=f.box_id
WHERE (B.BOX_LOCATOR IS NULL) AND (B.BOXLOC='WESTPTRC');"

I added DISTINCT to the code you suggested to get unique results.
It returns the samething as
Quote :
"
SELECT B.BOX_ID
FROM RIMS_BOXES B
WHERE (((B.BOX_LOCATOR) Is Null) AND ((B.BOXLOC)='WESTPTRC'));"


[Edited on July 27, 2007 at 2:43 PM. Reason : edit]

7/27/2007 2:38:29 PM

Spar
Veteran
205 Posts
user info
edit post

Quote :
"SELECT DISTINCT B.BOX_ID
FROM RIMS.BOXES B
WHERE (((B.BOX_LOCATOR) Is Null) AND ((B.BOXLOC)='WESTPTRC'))
AND B.box_id NOT IN

(SELECT DISTINCT B.BOX_ID
FROM RIMS.BOXES B, RIMS.FOLDERS f
WHERE (((B.BOX_LOCATOR) Is Null) AND ((B.BOXLOC)='WESTPTRC'))
AND f.box_id = B.box_id);
"


That's what I wrote...

First part (before subselect) has less conditions... it doesn't have:
Quote :
"AND f.box_id = B.box_id"


So the results returned were around 26k. The second part (sub-select) is:

Quote :
"(SELECT DISTINCT B.BOX_ID
FROM RIMS.BOXES B, RIMS.FOLDERS f
WHERE (((B.BOX_LOCATOR) Is Null) AND ((B.BOXLOC)='WESTPTRC'))
AND f.box_id = B.box_id);"


That has the added condition of:
Quote :
"AND f.box_id = B.box_id"


Which looks up the B.box_id against f.box_id and only returns the matches. So it cuts the 26k from the first part down to around 13k.

With:
Quote :
"AND B.box_id NOT IN
"


I want to find the entries of [Part1] - [Part2].

And I am having trouble getting the query to run... (yes the columns are indexed).

7/27/2007 2:50:00 PM

msb2ncsu
All American
14033 Posts
user info
edit post

Is BOX_ID not a unique key in BOXES? If it is then you shouldn't need DISTINCT. DISTINCT is greatly overused.

SELECT DISTINCT B.BOX_ID
FROM RIMS.BOXES B LEFT JOIN RIMS.FOLDERS f ON B.BOX_ID=f.BOX_ID
WHERE (f.BOX_ID IS NULL) AND (B.BOXLOC='WESTPTRC') AND (B.BOX_LOCATOR IS NULL)

Sorry, forgot the f NULL.

7/27/2007 2:53:30 PM

Spar
Veteran
205 Posts
user info
edit post

Okay... that worked.... can you explain why my code didn't work (beside the fact that I suck @ SQL).

7/27/2007 2:57:03 PM

msb2ncsu
All American
14033 Posts
user info
edit post

When you do SELECT FROM A WHERE A.ID=asdasd AND NOT IN (SELECT FROM B WHERE B.ID=fdgdfg)
the SELECT FROM B is done first. In your case, the inner SELECT involving FOLDERS is done first, then the outer SELECT is performed. It is possible to get a result in the manner you have constructed it but the LEFT JOIN is much more efficient. It is creating a join based upon the box_id's in common that is weighted to the "left" (BOXES). This means it returns all items in B and f that match plus all items in B that fit the query but don't have an f matching pair. By adding the WHERE f.box_id IS NULL requirement you eliminate all the portions of the query that have both B and f so you only get records that fit the query but are unique to B. Look at tyhe LEFT JOIN example: on this page
http://www.w3schools.com/sql/sql_join.asp
If you added "Orders.Employee_ID IS NULL" you would only return the 2 records without a Product (Svendson, Tove and Pettersen, Kari)

7/27/2007 3:05:05 PM

msb2ncsu
All American
14033 Posts
user info
edit post

FYI, I learned how to do this from a guy on http://www.dbforums.com/
I was trying to write synch routines for a distributed database (laptops workng in the field with a connection that would later be plugged in). I had to find records that were on the remote DB that were not on the central server DB and vice versa for inserting and deleting. I just happen to have the same problem you did in the past. I HIGHLY recommend you get legit answers from http://www.dbforums.com/forumdisplay.php?f=11 next time you need help with SQL statements. The guys name was r937. He's a professional SQL consultant.

7/27/2007 3:09:18 PM

Ernie
All American
45943 Posts
user info
edit post

TABLE 1 has columns: name1, date, score

TABLE 2 has columns: name1, date, name2

i need a query that gives me a table with rows of: name1, date, name2, and score

i assume that i need a join but i suck at sql

help

----

the query

SELECT t2.name1, t2.date, t2.name2, t1.score
FROM t2
LEFT JOIN t1
ON t2.name1 = t1.name1 AND t2.date = t1.date;


gives me a table with name1, date, and name2, but a blank score column

RIGHT JOIN and INNER JOIN just give me blank tables



[Edited on September 21, 2007 at 4:56 PM. Reason : ]

9/21/2007 4:40:27 PM

ScHpEnXeL
Suspended
32613 Posts
user info
edit post

don't you have to put FROM t1,t2 for it to use both tables? i could be wrong tho

9/21/2007 4:45:54 PM

Ernie
All American
45943 Posts
user info
edit post

i would certainly think so

access gives me a 'syntax error in JOIN operation' message when i try

9/21/2007 4:48:29 PM

msb2ncsu
All American
14033 Posts
user info
edit post

SELECT t2.name1, t2.date, t2.name2, t1.score
FROM t1
INNER JOIN t2
ON t1.name1 = t2.name1 AND t1.date = t2.date;

Inner join is for exact matches only, left join emphasizes the left table plus the matches

9/21/2007 5:12:27 PM

Ernie
All American
45943 Posts
user info
edit post

that gives me a blank table

---

i guess i should mention that there are multiple entries of name1, date, and name2 in each table, but there are no duplicate rows

[Edited on September 21, 2007 at 5:19 PM. Reason : ]

9/21/2007 5:18:06 PM

msb2ncsu
All American
14033 Posts
user info
edit post

t1:

name1	date	score
fred 1 55
tom 2 44
mike 3 33

t2:
name1 date name2
fred 1 asdsd
mike 2 dfgdfg
tom 5 asd
mike 3 tgdf
fred 4 qaaaa


SELECT t2.name1, t2.date, t2.name2, t1.score FROM t1 INNER JOIN t2 ON t1.name1 = t2.name1 AND t1.date = t2.date;

returns:

name1	date	name2	score
fred 1 asdsd 55
mike 3 tgdf 33

Is that not the sort of result you are looking for? Either an issue with data or simply a misunderstanding.

[Edited on September 21, 2007 at 5:54 PM. Reason : will check back later if I remember, heading home]

9/21/2007 5:53:11 PM

Ernie
All American
45943 Posts
user info
edit post

yeah that's exactly what i have and exactly what i need

and that query should do exactly that

but it isn't

fucking a

---

so i created two dummy tables and the query works, must be the data

[Edited on September 21, 2007 at 6:15 PM. Reason : ]

9/21/2007 6:00:19 PM

synapse
play so hard
60935 Posts
user info
edit post

heres a good site for beginning-intermediate sql users: http://sqlzoo.net/

9/21/2007 6:25:04 PM

Ernie
All American
45943 Posts
user info
edit post

finally got it working

apparently one of the tables was built from a query that was built from another query

don't really know why that would be a problem, but i cleaned it up a bit and everything is working

9/21/2007 6:48:31 PM

 Message Boards » Tech Talk » SQL query help thread... Page [1] 2 3 4 5 6 7, Next  
go to top | |
Admin Options : move topic | lock topic

© 2024 by The Wolf Web - All Rights Reserved.
The material located at this site is not endorsed, sponsored or provided by or on behalf of North Carolina State University.
Powered by CrazyWeb v2.39 - our disclaimer.