열 이름을 이스케이프하는 SQL 표준이 있습니까? mysql 및 sqlite에서 작동하지 않는 것은 무엇입니까? sqlserver에서도 작동합니까?
답변
인용 부호 "
SQL : 1999 표준 지정 따옴표는 ( “) (즉, 인용문 마크 )를 단락 식별자로 사용된다.
<delimited identifier> ::= <double quote> <delimited identifier body> <double quote>
Oracle, PostgreSQL, MySQL, MSSQL 및 SQlite는 모두 "
식별자 구분 기호로 지원 됩니다.
모두 "
‘기본값’으로 사용되지는 않습니다 . 예를 들어, ANSI 모드 에서 MySQL을 실행해야 하며 SQL Server QUOTED_IDENTIFIER
는 ON
.
답변
SQLite 에 따르면 ,
'foo'
SQL 문자열입니다."foo"
SQL 식별자 (열 / 테이블 / 기타)[foo]
MS SQL의 식별자입니다.`foo`
MySQL의 식별자입니다.
정규화 된 이름의 경우 구문은 "t"."foo"
또는 [t].[foo]
등입니다.
ANSI_QUOTES
옵션이 활성화 되면 MySQL은 표준 “foo”를 지원합니다 .
답변
MySQL의 경우 백틱`.
예를 들면 :
SELECT `column`, `column2` FROM `table`
답변
MS SQL의 경우 [및] 사용
SELECT [COLUMN], [COLUMN 2] FROM [TABLE]
답변
DBASE / DBF 사용 [
및]
SELECT [DATE], [TIME], [ANY_OTHER_TO_BE_ESCAPED_COLUMN] FROM [TABLE]
답변
몇 가지 답변을 모으기 :
MS SQL (일명 T-SQL), Microsoft Access SQL, DBASE / DBF : SELECT [COLUMN], [COLUMN2] FROM [TABLE]
MySQL : SELECT `COLUMN`, `COLUMN2` FROM `TABLE`
SQLite, Oracle, Postgresql : SELECT "COLUMN", "COLUMN2" FROM "TABLE"
추가 / 편집하십시오!
답변
