Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Split varchar into separate columns

I've been asked to take in comments starting with a specific string from a database, and separate the result into separate columns.

For example -- if a returned value is this:

COLUMN_ONE
--------------------
'D7ERROR username'

The return needs to be:

COL_ONE    COL_TWO
--------------------
D7ERROR   username   

Is it even possible to define columns once the result set has been structured just for the sake of splitting a string into two?

like image 622
ryebr3ad Avatar asked Sep 06 '25 03:09

ryebr3ad


1 Answers

Depends on the consistency of the data - assuming a single space is the separator between what you want to appear in column one vs two:

SELECT SUBSTR(t.column_one, 1, INSTR(t.column_one, ' ')-1) AS col_one,
       SUBSTR(t.column_one, INSTR(t.column_one, ' ')+1) AS col_two
  FROM YOUR_TABLE t

Oracle 10g+ has regex support, allowing more flexibility depending on the situation you need to solve. It also has a regex substring method...

Reference:

  • SUBSTR
  • INSTR
like image 144
OMG Ponies Avatar answered Sep 07 '25 20:09

OMG Ponies