I have the following table in PostgreSQL:
id and grade are INTs, note and subject both VARCHARs
When I run the command:
SELECT * FROM grades
WHERE subject = "latin";
I get the following error:
In pgAdmin4: ERROR: column "latin" does not exist LINE 2: WHERE subject = "latin" ^ SQL state: 42703 Character: 37
And in cmd: ERROR: column "latin" does not exist LINE 1: SELECT * FROM upisi WHERE subject = "latin";
I'm coming from MySQL so I thought this would work. Works fine if I put grade = something in the WHERE clause. Any idea why this might be the case?
It's as simple as the wrong type of quote marks. You wanted:
To explain:
'latin'
, are the standard way to write a string in standard SQL, and should work on all DBMSes.SELECT * FROM grades WHERE "subject name" = 'latin'
-"subject name"
is the name of the column,'latin'
is a string.Although double quotes are in the SQL standard, other DBMSes use different syntax for quoting identifiers, so may treat double quotes as an alternative for writing strings.
But if you always use single quotes for strings, and avoid names that need quoting, you'll run into fewer problems.