Skip to content
DataMiner DoJo

More results...

Generic selectors
Exact matches only
Search in title
Search in content
Post Type Selectors
Search in posts
Search in pages
Search in posts
Search in pages
Log in
Menu
  • Blog
  • Questions
  • Learning
    • E-learning Courses
    • Open Classroom Training
    • Certification
      • DataMiner Fundamentals
      • DataMiner Configurator
      • DataMiner Automation
      • Scripts & Connectors Developer: HTTP Basics
      • Scripts & Connectors Developer: SNMP Basics
      • Visual Overview – Level 1
      • Verify a certificate
    • Tutorials
    • Video Library
    • Books We Like
    • >> Go to DataMiner Docs
  • Expert Center
    • Solutions & Use Cases
      • Solutions
      • Use Case Library
    • Markets & Industries
      • Media production
      • Government & defense
      • Content distribution
      • Service providers
      • Partners
      • OSS/BSS
    • DataMiner Insights
      • Security
      • Integration Studio
      • System Architecture
      • DataMiner Releases & Updates
      • DataMiner Apps
    • Agile
      • Agile Webspace
      • Everything Agile
        • The Agile Manifesto
        • Best Practices
        • Retro Recipes
      • Methodologies
        • The Scrum Framework
        • Kanban
        • Extreme Programming
      • Roles
        • The Product Owner
        • The Agile Coach
        • The Quality & UX Coach (QX)
    • DataMiner DevOps Professional Program
  • Downloads
  • More
    • Feature Suggestions
    • Climb the leaderboard!
    • Swag Shop
    • Contact
      • General Inquiries
      • DataMiner DevOps Support
      • Commercial Requests
    • Global Feedback Survey
  • PARTNERS
    • All Partners
    • Technology Partners
    • Strategic Partner Program
    • Deal Registration
  • >> Go to dataminer.services

Custom operator to merge two columns into one not working

Solved519 views26th April 2024GQI custom operator
1
Jonas Kockx [SLC] [DevOps Enabler]203 26th April 2024 0 Comments

Hi

I'm trying to create a simple custom operator to process the result of an outer join in GQI.

I basically want to use the value of the first column if not empty or the second column when the first column is empty.

I have this code, but it's difficult to debug where things go wrong in GQI:
using System;
using Skyline.DataMiner.Analytics.GenericInterface;
using Skyline.DataMiner.Net.Messages;

[GQIMetaData(Name = "Merge Outer Join Keys")] public class MergeOuterJoinKeys : IGQIColumnOperator, IGQIInputArguments
{
// Arguments
private readonly GQIColumnDropdownArgument _columnArg1;
private readonly GQIColumnDropdownArgument _columnArg2;
private readonly GQIStringArgument _newNameArg;

// Argument values
private GQIColumn _column1;
private GQIColumn _column2;

private string _newName;

// variables
private GQIColumn _mergedColumn;

public MergeOuterJoinKeys()
{
_columnArg1 = new GQIColumnDropdownArgument("Column 1") { IsRequired = true };
_columnArg2 = new GQIColumnDropdownArgument("Column 2") { IsRequired = true };
_newNameArg = new GQIStringArgument("Name of merged column") { IsRequired = true };
}

public GQIArgument[] GetInputArguments()
{
return new GQIArgument[] {
_columnArg1,
_columnArg2,
_newNameArg,
};
}

public OnArgumentsProcessedOutputArgs OnArgumentsProcessed(OnArgumentsProcessedInputArgs args)
{
_column1 = args.GetArgumentValue(_columnArg1);
_column2 = args.GetArgumentValue(_columnArg2);
_newName = args.GetArgumentValue(_newNameArg);

return default;
}

public void HandleColumns(GQIEditableHeader header)
{
_mergedColumn = new GQIStringColumn(_newName);
header.AddColumns(_mergedColumn);
}

public void HandleRow(GQIEditableRow row)
{

if (!row.TryGetValue(_column1, out string column1String))
{
throw new Exception("Column 1 not found");
}
if (!row.TryGetValue(_column2, out string column2String))
{
throw new Exception("Column 2 not found");
}

GenerateInformationEvent($"Column 1: {column1String}");
GenerateInformationEvent($"Column 2 {column2String}");

string mergedString;
if (column1String.Length > 0)
{
mergedString = column1String;
}
else
{
mergedString = column2String;
}

row.SetValue(_mergedColumn, mergedString);
}
}

Ben Vandenberghe [SLC] [DevOps Enabler] Selected answer as best 26th April 2024

1 Answer

  • Active
  • Voted
  • Newest
  • Oldest
5
Jens Vandewalle [SLC] [DevOps Enabler]9.44K Posted 26th April 2024 1 Comment

Hi Jonas,

Can you try again by adding interface IGQIRowOperator to your class?

Ben Vandenberghe [SLC] [DevOps Enabler] Selected answer as best 26th April 2024
Jonas Kockx [SLC] [DevOps Enabler] commented 26th April 2024

That was it, overlooked it. Now it’s working fine, thanks!

You are viewing 1 out of 1 answers, click here to view all answers.
Please login to be able to comment or post an answer.

My DevOps rank

DevOps Members get more insights on their profile page.

My user earnings

0 Dojo credits

Spend your credits in our swag shop.

0 Reputation points

Boost your reputation, climb the leaderboard.

Promo banner DataMiner DevOps Professiona Program
DataMiner Integration Studio (DIS)
Empower Katas

Recent questions

Web Applications exception in Cube due to invalid certificate 0 Answers | 0 Votes
Redundancy Groups and Alarming – Duplicate Alarms 0 Answers | 0 Votes
Correlation Engine: “Test rule” doesn’t result in a hit, despite functional rule 1 Answer | 3 Votes

Question Tags

adl2099 (115) alarm (62) Alarm Console (82) alarms (100) alarm template (83) Automation (223) automation scipt (111) Automation script (167) backup (71) Cassandra (180) Connector (109) Correlation (69) Correlation rule (52) Cube (151) Dashboard (194) Dashboards (188) database (83) DataMiner Cube (57) DIS (81) DMS (71) DOM (140) driver (65) DVE (56) Elastic (83) Elasticsearch (115) elements (80) Failover (104) GQI (159) HTTP (76) IDP (74) LCA (152) low code app (166) low code apps (93) lowcodeapps (75) MySQL (53) protocol (203) QAction (83) security (88) SNMP (86) SRM (337) table (54) trending (87) upgrade (62) Visio (539) Visual Overview (345)
Privacy Policy • Terms & Conditions • Contact

© 2025 Skyline Communications. All rights reserved.

DOJO Q&A widget

Can't find what you need?

? Explore the Q&A DataMiner Docs

[ Placeholder content for popup link ] WordPress Download Manager - Best Download Management Plugin