we havesome passive checks in our old configuration, which we like to run against the database, but in our script, the arguments are necassary, so i have to find an sql statemant, where i can see the the display name, check_command_object_id from the icinga services, the host object_id from the icinga_hosts and the arguments from the icinga_services.
such a command definition is not considered best practice. Always use the arguments attribute and refine the specific arguments and parameters in there. Especially ARGx from the old world is not very readable, use the proposed long and telling names.
Since there’s also the tcp CheckCommand object available inside the Icinga Template Library, I highly recommend that you’re going this route.
I’m not sure about ARG2 here, since it is a standalone parameter - my guesses are either -4/-6 or -S for enabling TLS.
As you can see, a telling name for that attribute also would allow others to better understand the meaning
Once you have those better names, it is far more easy to search for them inside the database as well. The custom vars are stored in an extra table and require some more joins.
select * from icinga_objects so join icinga_customvariables cvs on so.object_id=cvs.object_id where so.name1='hostname' and so.name2='servicename' and cvs.varname='tcp_port';