Ich habe ein Experiment zum Umgang mit den Leerzeichen zwischen Oracle und SQL Server durchgeführt, weil ich den Unterschied bei der Verwendung von Oracle für meine Arbeit bemerkt habe.
(Die Version von Oracle ist Oracle 19c und die Version von SQL Server ist SQL Server 2019, da diese bereits auf meinem PC installiert waren.)
Experimentieren
Orakel
Ich habe ein Experiment unter der folgenden Tabelle und den Daten durchgeführt.
CREATE TABLE CompareTestTable
(
Seq NUMBER
,ColCHAR CHAR(10)
,ColVARCHAR VARCHAR2(10)
);
INSERT INTO CompareTestTable VALUES( 1, 'aaa', 'bbb' ); -- No space
INSERT INTO CompareTestTable VALUES( 2, 'aaa ', 'bbb ' ); -- A space after a string
INSERT INTO CompareTestTable VALUES( 3, ' aaa', ' bbb' ); -- A space before a string
INSERT INTO CompareTestTable VALUES( 4, ' aaa ', ' bbb ' ); -- Spaces after and before a string
select * from CompareTestTable where ColCHAR = 'aaa'; -- Hit SEQ=1,2 records
select * from CompareTestTable where ColCHAR = 'aaa '; -- Hit SEQ=1,2 records
select * from CompareTestTable where ColCHAR = ' aaa'; -- Hit SEQ=3,4 records
select * from CompareTestTable where ColCHAR = ' aaa '; -- Hit SEQ=3,4 records
select * from CompareTestTable where ColVARCHAR = 'bbb'; -- Hit SEQ=1 record
select * from CompareTestTable where ColVARCHAR = 'bbb '; -- Hit SEQ=2 record
select * from CompareTestTable where ColVARCHAR = ' bbb'; -- Hit SEQ=3 record
select * from CompareTestTable where ColVARCHAR = ' bbb '; -- Hit SEQ=4 record
Das Leerzeichen nach der Zeichenfolge scheint ignoriert zu werden, wenn der Spaltentyp Char ist.
Im Fall von Varchar2 scheint das Leerzeichen nach oder vor der Zeichenfolge jedoch nicht ignoriert zu werden.
Das Detail folgt
https://docs.oracle.com/cd/B13789_01/server.101/b10759/sql_elements002.htm#:~:text=Nonpadded%20Comparison%20Semantics,-Oracle%20compares%20two&text=If%20two%20values%20of% 20anders,die%20Werte%20werden%20als%20gleich angesehen.
SQL-Server
Als derselbe Fall für Oracle habe ich ein Experiment unter der folgenden Tabelle und den Daten auf SQL Server durchgeführt.
CREATE TABLE CompareTestTable
(
Seq INT
,ColCHAR CHAR(10)
,ColVARCHAR VARCHAR(10)
)
INSERT INTO CompareTestTable VALUES( 1, 'aaa', 'bbb' ); -- No space
INSERT INTO CompareTestTable VALUES( 2, 'aaa ', 'bbb ' ); -- A space after a string
INSERT INTO CompareTestTable VALUES( 3, ' aaa', ' bbb' ); -- A space before a string
INSERT INTO CompareTestTable VALUES( 4, ' aaa ', ' bbb ' ); -- Spaces after and before a string
select * from CompareTestTable where ColCHAR = 'aaa'; -- Hit SEQ=1,2 records
select * from CompareTestTable where ColCHAR = 'aaa '; -- Hit SEQ=1,2 records
select * from CompareTestTable where ColCHAR = ' aaa'; -- Hit SEQ=3,4 records
select * from CompareTestTable where ColCHAR = ' aaa '; -- Hit SEQ=3,4 records
select * from CompareTestTable where ColVARCHAR = 'bbb'; -- Hit SEQ=1,2 records
select * from CompareTestTable where ColVARCHAR = 'bbb '; -- Hit SEQ=1,2 records
select * from CompareTestTable where ColVARCHAR = ' bbb'; -- Hit SEQ=3,4 records
select * from CompareTestTable where ColVARCHAR = ' bbb '; -- Hit SEQ=3,4 records
Das Ergebnis von Char ist das gleiche wie bei Oracle.
Im Fall von Varchar ist das Ergebnis jedoch zwischen Oracle und SQL Server unterschiedlich, die Leerzeichen nach oder vor dem String scheinen ignoriert zu werden.
Daher sollte bei der Verwendung von varchar auf Grund des Unterschieds zwischen Oracle und SQL Server als solchem oben hingewiesen werden.