What is the difference between single and double quotes in SQL?
Asked Answered
B

7

327

What is the difference between single quotes and double quotes in SQL?

Beilul answered 2/1, 2010 at 18:18 Comment(1)
What type/vendor of Sql?Gavrah
D
217

Single quotes are used to indicate the beginning and end of a string in SQL. Double quotes generally aren't used in SQL, but that can vary from database to database.

Stick to using single quotes.

That's the primary use anyway. You can use single quotes for a column alias — where you want the column name you reference in your application code to be something other than what the column is actually called in the database. For example: PRODUCT.id would be more readable as product_id, so you use either of the following:

  • SELECT PRODUCT.id AS product_id
  • SELECT PRODUCT.id 'product_id'

Either works in Oracle, SQL Server, MySQL… but I know some have said that the TOAD IDE seems to give some grief when using the single quotes approach.

You do have to use single quotes when the column alias includes a space character, e.g., product id, but it's not recommended practice for a column alias to be more than one word.

Dorcy answered 2/1, 2010 at 18:22 Comment(9)
Double quotes are usually used to object names (e.g. column name "First name"). That is part of SQL-92 standard.Maximalist
@LukLed: You mean a column alias? If you say so - I've only ever seen and/or used the AS column_name notation, or where you supply the alias in single quotes after the column reference. Have to enclose the alias in single quotes if there is a space character (which I don't recommend) in the column alias.Dorcy
No. I meant column names, but it concerns aliases too. I would advise to use double quotation marks for aliases and names with unusual characters, because of SQL-92 standard. SELECT * FROM USERS 'Users' doesn't work in SQL Server, but SELECT * FROM USERS "Users" does.Maximalist
I always get this wrong until I realised a simple rule: [S]ingle quote for [S]trings, [D]ouble quote for things in the [D]atabasePostmeridian
You should use double quotes for identifiers. Single quotes goe against the standard.Straightlaced
SELECT PRODUCT.id 'product_id' will not work in Oracle. Single quotes are only for character literals. They can not be used for identifiers in (standard) SQL (although some DBMS just ignore the SQL standard when it comes to quoted identifiers)Extortionate
I think it would help to add to this answer that ' and " are seen as the same thing in terms of language, where using one or the other is a matter of convention. I came here to double check that " doesn't pre-process the string, because in some languages the single and double quotes are processed differently (like Php or something). The answer wasn't directly clear on that, but more insinuated and I think it would help to directly add that to the answer. +1 anywaysWeeping
In PostgreSQL, double quotes are used for column names. https://mcmap.net/q/100758/-escaping-keyword-like-column-names-in-postgresAttalanta
In PostgreSQL you have to use double quotes if you want DB identifiers to be case sensitive: #1992814 , e.g. MYTABLE without quotes is the same as mytable, the upper case version if "MYTABLE" with quotes. So I just tend to Always use quotes. Also as linked to by ceruleus, you need the double quotes if the name is a reserved identifier, one more reason to always use them.Neuman
S
195

A simple rule for us to remember what to use in which case:

  • [S]ingle quotes are for [S]trings Literals (date literals are also strings);
  • [D]ouble quotes are for [D]atabase Identifiers;

Examples:

INSERT INTO "USERS" ("LOGIN", "PASSWORD", "DT_BIRTH") VALUES ('EDUARDO', '12345678', '1980-09-06');

In MySQL and MariaDB, the ` (backtick) symbol is the same as the " symbol. And note that you can't use " for literal strings when your SQL_MODE has ANSI_QUOTES enabled.

Southerland answered 26/10, 2012 at 15:0 Comment(2)
To clarify, backtick (`) can be used to delimit identifiers whether or not ANSI_QUOTES is enabled, but if ANSI_QUOTES is enabled, then "you cannot use double quotation marks to quote literal strings, because it is interpreted as an identifier." (source). (This all assumes you're talking about MySQL, mind.)Reynold
But [S]ingle quotes are also for [D]ate literals. :-/Thursby
T
76

Single quotes delimit a string constant or a date/time constant.

Double quotes delimit identifiers for e.g. table names or column names. This is generally only necessary when your identifier doesn't fit the rules for simple identifiers.

See also:

You can make MySQL use double-quotes per the ANSI standard:

SET GLOBAL SQL_MODE=ANSI_QUOTES

You can make Microsoft SQL Server use double-quotes per the ANSI standard:

SET QUOTED_IDENTIFIER ON
Thursby answered 2/1, 2010 at 18:42 Comment(0)
B
46

In ANSI SQL, double quotes quote object names (e.g. tables) which allows them to contain characters not otherwise permitted, or be the same as reserved words (Avoid this, really).

Single quotes are for strings.

However, MySQL is oblivious to the standard (unless its SQL_MODE is changed) and allows them to be used interchangably for strings.

Moreover, Sybase and Microsoft also use square brackets for identifier quoting.

So it's a bit vendor specific.

Other databases such as Postgres and IBM actually adhere to the ansi standard :)

Beatrisbeatrisa answered 2/1, 2010 at 18:40 Comment(2)
MySql uses backtick ` for identifier quoting. (just for completion)Irony
Example: If you want to name a Postgres column "date" (which is reserved), you'll need to double quote it.Ozmo
T
12

I use this mnemonic:

  • Single quotes are for strings (one thing)
  • Double quotes are for tables names and column names (two things)

This is not 100% correct according to the specs, but this mnemonic helps me (human being).

Tezel answered 1/3, 2017 at 14:5 Comment(3)
human being As opposed to other animals who use SQL. :DStockholm
What quotes should be used for identifiers used as pseudonyms for tables? (For example, in join queries we write, .... from "table_name" as t1 JOIN ......) What should t1 be encosed in?Untread
Does every string require quotes?Gavrah
T
3

Two Things To Remember :

Single Qutoes(') : String Or Text

select * from employees where room_name = 'RobinCapRed';

where RobinCapRed is a string or a text.

Double Quotes(") : Column Names or Table Names

select "first_name" from "employees";

where first_Name is a column name from employees table

Testator answered 17/10, 2021 at 20:32 Comment(0)
G
1

The difference lies in their usage. The single quotes are mostly used to refer a string in WHERE, HAVING and also in some built-in SQL functions like CONCAT, STRPOS, POSITION etc.

When you want to use an alias that has space in between then you can use double quotes to refer to that alias.

For example

(select account_id,count(*) "count of" from orders group by 1)sub 

Here is a subquery from an orders table having account_id as Foreign key that I am aggregating to know how many orders each account placed. Here I have given one column any random name as "count of" for sake of purpose.

Now let's write an outer query to display the rows where "count of" is greater than 20.

select "count of" from 
(select account_id,count(*) "count of" from orders group by 1)sub where "count of" >20;

You can apply the same case to Common Table expressions also.

Gudrunguelderrose answered 7/1, 2019 at 7:41 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.