1
0
mirror of https://github.com/jbranchaud/til synced 2026-01-03 15:18:01 +00:00
Files
til/postgres/escaping-string-literals-with-dollar-quoting.md

28 lines
781 B
Markdown

# Escaping String Literals With Dollar Quoting
String literals in PostgreSQL are defined by surrounding the content with
the `'` character. For string literals that contain the `'` character, you
may have seen it escaped with a preceding `'`.
```sql
> select 'Isn''t this nice?';
?column?
------------------
Isn't this nice?
```
This is easy enough to do, but can be error prone and doesn't work well if
SQL is being programmatically generated. A great workaround is to escape
string literals using what is called dollar quoting.
```sql
> select $$Isn't this even nicer?$$;
?column?
------------------------
Isn't this even nicer?
```
Just wrap both ends in `$$` instead of `'`.
[source](https://www.postgresql.org/docs/current/static/sql-syntax-lexical.html)