mqDeleteItem
The mqDeleteItem call removes one or more user items from a bag.
Syntax for mqDeleteItem
- mqDeleteItem (Bag, Selector, ItemIndex, CompCode, Reason)
Parameters for mqDeleteItem
- Hbag (MQHBAG) - input
- Handle of the bag to be modified.
This must be the handle of a bag created by the user, and not the handle of a system bag; MQRC_SYSTEM_BAG_NOT_ALTERABLE results if it is a system bag.
- Selector (MQLONG) - input
- Selector identifying the user item to be deleted.
If the selector is less than zero (that is, a system selector), MQRC_SELECTOR_OUT_OF_RANGE results.
The following special values are valid:- MQSEL_ANY_SELECTOR
- The item to be deleted is a user item identified by the ItemIndex parameter, the index relative to the set of items that contains both user and system items.
- MQSEL_ANY_USER_SELECTOR
- The item to be deleted is a user item identified by the ItemIndex parameter, the index relative to the set of user items.
If an explicit selector value is specified, but the selector is not present in the bag, the call succeeds if MQIND_ALL is specified for ItemIndex, and fails with reason code MQRC_SELECTOR_NOT_PRESENT if MQIND_ALL is not specified.
- ItemIndex (MQLONG) - input
- Index of the data item to be deleted.
The value must be zero or greater, or one of the following special values:
- MQIND_NONE
- This specifies that there must be one occurrence only of the selector in the bag. If there is more than one occurrence, MQRC_SELECTOR_NOT_UNIQUE results. If MQIND_NONE is specified with one of the MQSEL_XXX_SELECTOR values, MQRC_INDEX_ERROR results.
- MQIND_ALL
- This specifies that all occurrences of the selector in the bag are to be deleted. If MQIND_ALL is specified with one of the MQSEL_XXX_SELECTOR values, MQRC_INDEX_ERROR results. If MQIND_ALL is specified when the selector is not present within the bag, the call succeeds.
If MQSEL_ANY_SELECTOR is specified for the Selector parameter, the ItemIndex parameter is the index relative to the set of items that contains both user items and system items, and must be zero or greater. If ItemIndex identifies a system selector MQRC_SYSTEM_ITEM_NOT_DELETABLE results. If MQSEL_ANY_USER_SELECTOR is specified for the Selector parameter, the ItemIndex parameter is the index relative to the set of user items, and must be zero or greater.
If an explicit selector value is specified, ItemIndex is the index relative to the set of items that have that selector value, and can be MQIND_NONE, MQIND_ALL, zero, or greater.
If an explicit index is specified (that is, not MQIND_NONE or MQIND_ALL) and the item is not present in the bag, MQRC_INDEX_NOT_PRESENT results.
- CompCode (MQLONG) - output
- Completion code.
- Reason (MQLONG) - output
- Reason code qualifying CompCode.
The following reason codes indicating error conditions can be returned from the mqDeleteItem call:
- MQRC_HBAG_ERROR
- Bag handle not valid.
- MQRC_INDEX_ERROR
- MQIND_NONE or MQIND_ALL specified with one of the MQSEL_ANY_XXX_SELECTOR values.
- MQRC_INDEX_NOT_PRESENT
- No item with the specified index is present within the bag.
- MQRC_SELECTOR_NOT_PRESENT
- No item with the specified selector is present within the bag.
- MQRC_SELECTOR_NOT_UNIQUE
- MQIND_NONE specified when more than one occurrence of the specified selector is present in the bag.
- MQRC_SELECTOR_OUT_OF_RANGE
- Selector not within valid range for call.
- MQRC_STORAGE_NOT_AVAILABLE
- Insufficient storage available.
- MQRC_SYSTEM_BAG_NOT_ALTERABLE
- System bag is read only and cannot be altered.
- MQRC_SYSTEM_ITEM_NOT_DELETABLE
- System item is read only and cannot be deleted.
Usage notes for mqDeleteItem
- Either a single occurrence of the specified selector can be removed, or all occurrences of the specified selector.
- The call cannot remove system items from the bag, or remove items from a system bag. However, the call can remove the handle of a system bag from a user bag. This way, a system bag can be deleted.
C language invocation for mqDeleteItem
mqDeleteItem (Bag, Selector, ItemIndex, &CompCode, &Reason)Declare the parameters as follows:
MQHBAG Hbag; /* Bag handle */ MQLONG Selector; /* Selector */ MQLONG ItemIndex; /* Index of the data item */ MQLONG CompCode; /* Completion code */ MQLONG Reason; /* Reason code qualifying CompCode */
Visual Basic invocation for mqDeleteItem
(Supported on Windows only.)
mqDeleteItem Bag, Selector, ItemIndex, CompCode, ReasonDeclare the parameters as follows:
Dim Bag As Long 'Bag handle' Dim Selector As Long 'Selector' Dim ItemIndex As Long 'Index of the data item' Dim CompCode As Long 'Completion code' Dim Reason As Long 'Reason code qualifying CompCode'