{"id":2513,"date":"2010-10-19T06:16:53","date_gmt":"2010-10-18T20:16:53","guid":{"rendered":"http:\/\/nsrd.info\/blog\/?p=2513"},"modified":"2018-12-11T18:30:26","modified_gmt":"2018-12-11T08:30:26","slug":"mminfo-and-not-queries","status":"publish","type":"post","link":"https:\/\/nsrd.info\/blog\/2010\/10\/19\/mminfo-and-not-queries\/","title":{"rendered":"mminfo and NOT queries"},"content":{"rendered":"<p>A question that&#8217;s just come up on the NetWorker mailing list again (it&#8217;s a periodic one) is, &#8220;how do I query mminfo to return all savesets that don&#8217;t belong to a particular group?&#8221; or &#8220;how do I return all savesets except those belonging to a single client?&#8221;<\/p>\n<p>The part of mminfo here that causes the confusion is the bang operator \u2013 otherwise known as the exclamation mark (!).<\/p>\n<p>In a lot of programming languages, an exclamation mark is typically equated with &#8220;not&#8221;. For instance, if we look at Perl:<\/p>\n<p><strong><em> if ($a != b)<\/em><\/strong><\/p>\n<p>Means &#8220;If the value of $a is not equal to the value of $b&#8221;. It&#8217;s a similar story in other languages that make use of the exclamation mark. Indeed, making it perhaps a little more confusion to the uninitiated is that in mminfo, ! does indeed mean &#8220;not&#8221;; the trick though is that it&#8217;s not available for all possible usages, just a subset.<\/p>\n<p>In particular, you can only use the exclamation mark within an mminfo query when against a <em>flag<\/em> field. Not a string field, nor a numeric field, etc. Just a flag field. The &#8220;catch&#8221; is that if you use it against a non-flag field, mminfo won&#8217;t abort the query, but will instead ignore the <em>not <\/em>component specified. This means that if you specify, say:<\/p>\n<pre># <strong>mminfo -q \"!client=archon,savetime&gt;=24 hours ago\"<\/strong><\/pre>\n<p>The query actually executed will be:<\/p>\n<pre># <strong>mminfo -q \"client=archon,savetime&gt;=24 hours ago\"<\/strong><\/pre>\n<p>There&#8217;s clearly a big difference between the two, and it&#8217;s brought a few people unstuck.<\/p>\n<p>As it currently stands in NetWorker, if you want to retrieve mminfo details for strings that <em>don&#8217;t<\/em> match particular patterns, your only option is to use an external filter, such as:<\/p>\n<ul>\n<li>A command line utility, such as grep;<\/li>\n<li>Writing the output to a text file and manually extracting;<\/li>\n<li>Writing a custom filter programme;<\/li>\n<li>Writing the output to a CSV file and filtering in a spreadsheet.<\/li>\n<\/ul>\n<p>It would certainly be highly desirable for NetWorker&#8217;s mminfo command to be updated to fully support the not\/&#8217;!&#8217; syntax; until then however keep in mind that it will be ignored for non-flag fields, and you&#8217;ll avoid getting into trouble with it.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>A question that&#8217;s just come up on the NetWorker mailing list again (it&#8217;s a periodic one) is, &#8220;how do I&hellip;<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"jetpack_post_was_ever_published":false,"_jetpack_newsletter_access":"","_jetpack_dont_email_post_to_subs":false,"_jetpack_newsletter_tier_id":0,"_jetpack_memberships_contains_paywalled_content":false,"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":false,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[16,20],"tags":[28,594,643],"class_list":["post-2513","post","type-post","status-publish","format-standard","hentry","category-networker","category-scripting","tag-28","tag-mminfo","tag-not"],"aioseo_notices":[],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack_shortlink":"https:\/\/wp.me\/pKpIN-Ex","jetpack_sharing_enabled":true,"jetpack_likes_enabled":true,"_links":{"self":[{"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/posts\/2513","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/comments?post=2513"}],"version-history":[{"count":1,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/posts\/2513\/revisions"}],"predecessor-version":[{"id":7541,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/posts\/2513\/revisions\/7541"}],"wp:attachment":[{"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/media?parent=2513"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/categories?post=2513"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/nsrd.info\/blog\/wp-json\/wp\/v2\/tags?post=2513"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}