Splunk Enterprise Security

Coalesce two fields with null values

lxm30
New Member

I have two fields and if field1 is empty, I want to use the value in field2. (i.e. I never want to use field2 unless field1 is empty).

I was trying to use a coalesce function but it doesn't work well with null values.

Do I have any options beyond using fillnull for field2 with a value of *, coalescing the two and then using rtrim to get rid of the star?

0 Karma
1 Solution

martinpu
Communicator

Try this

|eval field3=case(isNotNull(field1),field1,isNotNull(field2),field2,1=1, NULL)

should return field 3 as field1 if it isnt null,field2 if that isnt null and field1 is null and NULL if both are NULL

View solution in original post

0 Karma

martinpu
Communicator

Try this

|eval field3=case(isNotNull(field1),field1,isNotNull(field2),field2,1=1, NULL)

should return field 3 as field1 if it isnt null,field2 if that isnt null and field1 is null and NULL if both are NULL

0 Karma

lxm30
New Member

This works great - thanks so much for the quick response!

0 Karma

lxm30
New Member

(By * I mean some value, not necessarily the character "*").

0 Karma
Got questions? Get answers!

Join the Splunk Community Slack to learn, troubleshoot, and make connections with fellow Splunk practitioners in real time!

Meet up IRL or virtually!

Join Splunk User Groups to connect and learn in-person by region or remotely by topic or industry.

Get Updates on the Splunk Community!

[Puzzles] Solve, Learn, Repeat: Character substitutions with Regular Expressions

This challenge was first posted on Slack #puzzles channelFor BORE at .conf23, we had a puzzle question which ...

Splunk Community Badges!

  Hey everyone! Ready to earn some serious bragging rights in the community? Along with our existing badges ...

[Puzzles] Solve, Learn, Repeat: Matching cron expressions

This puzzle (first published here) is based on matching timestamps to cron expressions.All the timestamps ...