Sqlserver
 sql >> Baza danych >  >> RDS >> Sqlserver

Wyrażenie ścieżki XML zawierające znaki specjalne

Przetestowałem to ze znakami ASCII 0-255 i okazało się, że pojawia się ten błąd dla znaków:0x0000, 0x0001, 0x0002, 0x0003, 0x0004, 0x0005, 0x0006, 0x0007, 0x0008, 0x000B, 0x000C, 0x000E, 0x000F, 0x0010, 0x0011, 0x0012, 0x0013, 0x0014, 0x0015, 0x0016, 0x0017, 0x0018, 0x0019, 0x001A, 0x001B, 0x001C, 0x001D, 0x001E, 0x001F .

Jednym z obejść jest usunięcie , TYPE z wyciągu XML.

Innym sposobem jest usunięcie tych znaków w instrukcji select:

REPLACE( REPLACE( REPLACE( REPLACE( REPLACE( 
REPLACE( REPLACE( REPLACE( REPLACE( REPLACE( 
REPLACE( REPLACE( REPLACE( REPLACE( REPLACE( 
REPLACE( REPLACE( REPLACE( REPLACE( REPLACE( 
REPLACE( REPLACE( REPLACE( REPLACE( REPLACE( 
REPLACE( REPLACE( REPLACE( REPLACE( 
    < YOUR EXPRESSION TO BE CLEANED >
,char(0x0000),'') ,char(0x0001),'') ,char(0x0002),'') ,char(0x0003),'') ,char(0x0004),'') 
,char(0x0005),'') ,char(0x0006),'') ,char(0x0007),'') ,char(0x0008),'') ,char(0x000B),'') 
,char(0x000C),'') ,char(0x000E),'') ,char(0x000F),'') ,char(0x0010),'') ,char(0x0011),'') 
,char(0x0012),'') ,char(0x0013),'') ,char(0x0014),'') ,char(0x0015),'') ,char(0x0016),'') 
,char(0x0017),'') ,char(0x0018),'') ,char(0x0019),'') ,char(0x001A),'') ,char(0x001B),'') 
,char(0x001C),'') ,char(0x001D),'') ,char(0x001E),'') ,char(0x001F),'')

Możesz również utworzyć funkcję za pomocą tych instrukcji replace.



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Zadanie skryptu SSIS C# 2012 odwołujące się do pliku WinSCPnet.dll kończy się niepowodzeniem po uruchomieniu z programu SQL Server Agent z wyjątkiem zostało zgłoszone przez obiekt docelowy wywołania

  2. Usuwanie 1 miliona wierszy w SQL Server

  3. Funkcje bezpieczeństwa w SQL Server 2017

  4. Jak wstawić rekord z tylko wartościami domyślnymi?

  5. Zrozumienie diagramu zakleszczeń programu SQL Server