tags:

views:

69

answers:

4

Sorry because this is a noob question. I'm new with MySQL:

I wrote a query like this:

SELECT
    u.userid, u.alias, g.company_name,
 v.endtime - v.begintime AS duration, 
    u.status, u.service_starttime,
 u.service_expiretime, v.begintime, u.email
FROM
    company_users c, company_groups g INNER JOIN
    user_info u INNER JOIN vfon_log v 
    ON (u.userid = v.hostid) ON (g.company_id = u.company_id)

This query returns a syntax error:

Query : SELECT        u.userid, u.alias, g.company_name, v.endtime - v.begintime AS duration, u.status, u.service_starttime, u.service_ex...
Error Code : 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 'ON (g.company_id = u.company_id)
 LIMIT 0, 1000' at line 4
Execution Time : 00:00:00:000
Transfer Time  : 00:00:00:000
Total Time     : 00:00:00:000

I've spent 30 minutes looking, but I can't figure out what's wrong.

Thank you so much for your helps

A: 

I think it should b

 SELECT        u.userid, u.alias, g.company_name, v.endtime - vbegintime AS duration, 
u.status, u.service_starttime, u.service_expiretime, v.begintime, u.email
    FROM   company_users c, company_groups g 
                           INNER JOIN
                             (user_info u INNER JOIN vfon_log v  ON (u.userid = v.hostid)) 
                              ON g.company_id = u.company_id
Salil
I tried this, but:Error Code : 1054Unknown column 'vbegintime' in 'field list'Execution Time : 00:00:00:000Transfer Time : 00:00:00:000Total Time : 00:00:00:000In fact, I didn't write this query. Visual Studio automatically generated query based on the query I wrote
Vimvq1987
@Salil: Chris Diver's answer is probably closer to the desired result.
David Hedlund
+2  A: 
ON (g.company_id = u.company_id)

should be after INNER JOIN user_info u

So it becomes

SELECT
    u.userid, u.alias, g.company_name,
 v.endtime - v.begintime AS duration, 
    u.status, u.service_starttime,
 u.service_expiretime, v.begintime, u.email
FROM
    company_users c, company_groups g 
INNER JOIN user_info u ON (g.company_id = u.company_id)
INNER JOIN vfon_log v  ON (u.userid = v.hostid) 
Chris Diver
+1  A: 

You put the ON statements on the wrong place. The standard solution is to add it directly after the join:

SELECT *
  FROM company_users c, 
       company_groups g INNER JOIN
            user_info u ON (g.company_id = u.company_id) 
       INNER JOIN vfon_log v 
                 ON (u.userid = v.hostid)

Or you can use brackets to get the correct ON linked to the correct INNER JOIN:

SELECT *
  FROM company_users c, 
       company_groups g INNER JOIN
            (user_info u INNER JOIN vfon_log v 
                 ON (u.userid = v.hostid))
            ON (g.company_id = u.company_id)
Matijs
the second query works (I'm checking if it works fine, the first one fails :)
Vimvq1987
@Vimvq1987: The first query probably fails because there is an extra `)` at the end of the last `INNER JOIN`. Note also that the table `company_users` is referenced in the `FROM` clause, but not used elsewhere in your query.
Mike
Matijs
+2  A: 

Your field is not vbegintime but v.begintime

M42
Just saw it :). But after correcting that, the problem still exits
Vimvq1987
Mike's comment may solve your problem
M42