sql-servert-sqlsql-server-2019babelfish

REPLACE string with SUBSTRING function


Given input data:

Col1                                        
---------------------------------------
'-'::"varchar" COLLATE "default"            
'-1'::integer                               
'0'::smallint                               
'1'::"varchar" COLLATE "default"            
(get_val())::"timestamp"    
0                                           
0.0                                         
10                                          
210                                         
90000                                       
getdate()       

I'm trying to replace the part of the string(column Col1) to empty string ''.

Want to replace anything after :: with empty string as shown below in the expected result.

Expected Result:

Col1                                        Col2
------------------------------------------------------------------------
'-'::"varchar" COLLATE "default"            '-'
'-1'::integer                               '-1'
'0'::smallint                               '0'
'1'::"varchar" COLLATE "default"            '1'
(get_val())::"timestamp"                    (get_val())
0                                           0
0.0                                         0.0
10                                          10
210                                         210
90000                                       90000
8                                           8
getdate()                                   getdate()

My try:

SELECT Col1  REPLACE(REPLACE(Col1,SUBSTRING(Col1,CHARINDEX('::',Col1),LENGTH(Col1)),''),'(''','''') 
FROM  tbl_string_pattern;

But getting output like:

Col1                                        Col2
------------------------------------------------------------------------
'-'::"varchar" COLLATE "default"            '-'
'-1'::integer                               '-1'
'0'::smallint                               '0'
'1'::"varchar" COLLATE "default"            '1'
(get_val())::"timestamp"                    (get_val())
0                                           0
0.0                                         0
10                                          0
210                                         0
90000                                       0
8                                           8
getdate()                                   )

Solution

  • Try this:

    DECLARE @DataSource TABLE
    (
        [value] VARCHAR(128)
    );
    
    INSERT INTO @DataSource ([value])
    VALUES ('''-''::"varchar" COLLATE "default"')
          ,('''-1''::integer')
          ,('''0''::smallint')
          ,('''1''::"varchar" COLLATE "default"')
          ,('(get_val())::"timestamp" ')
          ,('0')
          ,('0.0')
          ,('10 ')
          ,('210')
          ,('90000')
          ,('8')
          ,(null)
          ,('')
          ,('getdate()');
    
    SELECT [value]
          ,REPLACE(REPLACE([value],SUBSTRING([value],CHARINDEX('::',[value]),LEN([value])),''),'(''','''') 
          ,IIF(CHARINDEX('::', [value]) > 0, SUBSTRING([value], 0, CHARINDEX('::', [value])), [value])
          -- John Cappellletti's idea
          ,left([value],charindex('::',[value]+'::')-1)
    FROM  @DataSource;
    

    enter image description here