I am writing this blog to explain how to delete multiple data in m table in SAP UI5 application and also deleting multiple data in m table using Batch call consuming ODATA service.
The m table is also called as responsive table which contains a set of line items and is fully responsive. The control for m-table is sap.m.Table.
Step1: Create a new Project in VS Code. View—Command Palette —Open Application Generator—Template Type (SAP Fiori)—Select Basic —Click on Next
data:image/s3,"s3://crabby-images/06268/0626828c1b23db9b15109100dec1d848d1ed21e4" alt=""
Step 2: Data Source —Select None —Click on Next
data:image/s3,"s3://crabby-images/0f87a/0f87a7a8086eaaf7d9f29376a6773f2868ca7477" alt=""
Step 3: Give View name and Project name Click on Finish.
Step 4: Click on model — Create employee.json file.
data:image/s3,"s3://crabby-images/377bd/377bd828b8ac417d4cbd0eda1824f3b288abf24f" alt=""
Step 5: Configure in manifest.json
data:image/s3,"s3://crabby-images/badd6/badd63bbe3aa8e02dbcfc854ccec64896d46f8ce" alt=""
Step 6: In View, Create m table.
<mvc:View controllerName="multipledatadelete.controller.View1"
xmlns:mvc="sap.ui.core.mvc" displayBlock="true"
xmlns="sap.m">
<Page id="page" title="{i18n>title}">
<content>
<Table items="{emp>/data}" mode="MultiSelect" selectionChange="oSelectedItems" id="mytable" >
<columns>
<Column >
<Text text="Name"></Text>
</Column>
<Column >
<Text text="Id"></Text>
</Column>
<Column >
<Text text="City"></Text>
</Column>
</columns>
<ColumnListItem >
<cells>
<Text text="{emp>name}"></Text>
<Text text="{emp>id}"></Text>
<Text text="{emp>city}"></Text>
</cells>
</ColumnListItem>
<headerToolbar>
<OverflowToolbar >
<Bar >
<contentRight>
<Button text="Delete" type="Negative" press="oDelete" ></Button>
</contentRight>
</Bar>
</OverflowToolbar>
</headerToolbar>
</Table>
</content>
</Page>
</mvc:View>
Step 7: In Controller, Write Logic.
Based on selected keys, we can delete multiple data.
sap.ui.define([
"sap/ui/core/mvc/Controller"
],
/**
* {typeof sap.ui.core.mvc.Controller} Controller
*/
function (Controller) {
"use strict";
var oSelectedPath =[]
return Controller.extend("multipledatadelete.controller.View1", {
onInit: function () {
},
oSelectedItems:function(oEvent){
oSelectedPath = oEvent.getSource().getSelectedContextPaths()
},
oDelete:function(){
var oModel = this.getView().getModel("emp")
var aOldData = oModel.oData.data
var aTemp = []
for(let j=0;j<oSelectedPath.length;j++)
{
var index = oSelectedPath[j].split("/")[2]
for(let i=0; i<aOldData.length; i++)
{
if(aOldData[i].id == aOldData[index].id )
{
aTemp.push(aOldData[i])
}
}
}
for(let k=0;k<aTemp.length;k++)
{
for(let n=0; n<aOldData.length; n++)
{
if(aOldData[n].id == aTemp[k].id )
{
aOldData.splice(n,1)
}
}
}
oModel.refresh(true)
this.getView().byId("mytable").removeSelections(true)
}
});
});
Run the program — Open Integrated Terminal —npm run start.
Output look like this.
data:image/s3,"s3://crabby-images/711f0/711f0e97785a964b75b40af19d847cac05b110bd" alt=""
After deleting multiple data, Output look like this
data:image/s3,"s3://crabby-images/c3b0b/c3b0b20199c81bcac4575d513ca25716e632e2f2" alt=""
Multiple data delete using Batch call.
In some business scenarios multiple entity instances need to be handled together as a single logical unit of work. This is where $batch processing come into picture. $batch request means multiple operations bundled as a single request. Batch processing simple batches several independent OData service call to a single OData call. Batch call Reduce number of Api calls. In a single http request we can do multiple crud operation.
Step 1: Create a Database table in SE11.
data:image/s3,"s3://crabby-images/20fd0/20fd0452e7188c29b719bf967d25b1e25217839b" alt=""
Step 2: I have inserted some records. Output look like this.
data:image/s3,"s3://crabby-images/0ddcf/0ddcf857f4a1b25333a703e9bf478201b48d6be7" alt=""
Step3: After creating Database table. Go to T-Code SEGW. Create OData Project.
data:image/s3,"s3://crabby-images/c0e66/c0e6644019f8b278bc189e55c52d46bf4605b510" alt=""
Step 4: Import DDIC Structure and Generate Runtime Objects and Also Register Service to open SAP Gateway Client.
Step 5: Click on DPC_EXT.
data:image/s3,"s3://crabby-images/2f072/2f072967457de6cfaad11ea05cd256c6bc5a0462" alt=""
Step 6: Redefine GET_ENTITYSET and write logic.
data:image/s3,"s3://crabby-images/45b94/45b94e86f6a94c5f9d68cea5de305d95757e5e65" alt=""
Step 7: Redefine GET_ENTITY and write logic.
data:image/s3,"s3://crabby-images/53db4/53db443ff289fd18f44a181b1688f243c294755c" alt=""
Step 8: Redefine CREATE_ENTITY and write logic.
data:image/s3,"s3://crabby-images/c6ef6/c6ef6a8152f80bf801ab17142ede26ae58776570" alt=""
Step 9: Redefine UPDATE_ENTITY and write logic.
data:image/s3,"s3://crabby-images/f46c0/f46c0416c0cd0f2b103e0272c1fca893e0e3fb63" alt=""
Step 10: Redefine DELETE_ENTITY and write logic.
data:image/s3,"s3://crabby-images/559cf/559cf7a2d75003283c690a665c4232b257c35c50" alt=""
Step 11: Redefine CHANGESET_BEGIN AND CHANGESET_END without writing any logic.
data:image/s3,"s3://crabby-images/ae78a/ae78aada2c41d936509114bd5ac323096523e84a" alt=""
Step 12: Go to SAP Gateway Client and Check all crud operations and Batch Call service working or not through URI.
data:image/s3,"s3://crabby-images/12eb1/12eb1e04b6f08b95075a53dbc804f861635d7da5" alt=""
Front end:
Step 1: Create one SAP UI5 application based on Service created in Back-end. Metadata.xml file will be created.
Step 2: Home Page
<mvc:View controllerName="odatabatch.controller.View1"
xmlns:mvc="sap.ui.core.mvc" displayBlock="true"
xmlns="sap.m">
<Page id="page" title="{i18n>title}">
<content>
<Table items="{employee>/}" mode="MultiSelect" selectionChange="onRead" id="Tableid" >
<columns>
<Column >
<Text text="Employee ID"></Text>
</Column>
<Column >
<Text text="Employee Name"></Text>
</Column>
<Column >
<Text text="Employee Age"></Text>
</Column>
<Column >
<Text text="Employee City"></Text>
</Column>
</columns>
<items>
<ColumnListItem >
<cells>
<Text text="{employee>Employeeid}"></Text>
<Text text="{employee>Empname}"></Text>
<Text text="{employee>Empage}"></Text>
<Text text="{employee>Empcity}"></Text>
</cells>
</ColumnListItem>
</items>
</Table>
<Bar >
<contentRight>
<Button text="Delete" type="Negative" id="btnid" press="onMultipleDelete"></Button>
</contentRight>
</Bar>
</content>
</Page>
</mvc:View>
Step 3: Controller logic
onInit logic:
onInit: function () {
var oModel = new sap.ui.model.json.JSONModel();
this.getOwnerComponent().getModel().read("/zemployeeSet", {
success: function (oData, response) {
debugger
// Assuming that the data you want is in the 'results' property
oModel.setData(oData.results);
},
error: function (error) {
console.error("Error loading data: " + error);
}
});
this.getView().setModel(oModel, "employee");
}
onRead logic:
onRead:function(oEvent){
this.getOwnerComponent().getModel().read("/zemployeeSet", {
success: function (oData, response) {
},
error: function (error) {
console.error("Error loading data: " + error);
}
});
},
onMultipleDelete logic:
onMultipleDelete:function(oEvent){
var oTable = this.getView().byId('Tableid');
var selectItem = oTable.getSelectedItems();
var object = [];
for (var i = 0; i < selectItem.length; i++) {
var selectedrow = {
"Employeeid": selectItem[i].getBindingContext('employee').getObject().Employeeid,
"Empname": selectItem[i].getBindingContext('employee').getObject().Empname,
"Empage": selectItem[i].getBindingContext('employee').getObject().Empage,
"Empcity": selectItem[i].getBindingContext('employee').getObject().Empcity,
};
object.push(selectedrow);
}
var oModel = this.getView().getModel();
oModel.setUseBatch(true);
var jModel = this.getOwnerComponent().getModel();
for(var i = 0; i<object.length; i++){
var oEntry = object[i].Employeeid;
oModel.remove("/zemployeeSet('" + oEntry + "')",
{
method:"DELETE",
success:function(response){
sap.m.MessageToast.show("Employee Data is deleted");
}
}
);
}
oModel.submitChanges({
success: function(data, response){
},
error: function(e){
}
})
location.reload();
}
Step 4: Output before
data:image/s3,"s3://crabby-images/d43c0/d43c07b8ea644d9d2bd8a3314820d7209aa9cb2e" alt=""
data:image/s3,"s3://crabby-images/9214a/9214afaf9fd7a17b3e347d28bb3f34f18652ef9f" alt=""
Step 5: After deleting multiple data output look like this.
data:image/s3,"s3://crabby-images/9c910/9c910d806fc0106c995c2136bee296cf8e349e7a" alt=""
In Database table, Multiple data get deleted.
data:image/s3,"s3://crabby-images/40805/408051fe1d7366f30cf453e047237e4378b26ea1" alt=""