@loopback/docs
Version:
Documentation files rendered at [https://loopback.io](https://loopback.io)
83 lines (77 loc) • 3.48 kB
Markdown
---
lang: en
title: 'Working with data'
keywords: LoopBack 4.0, LoopBack 4, Node.js, TypeScript, OpenAPI
sidebar: lb4_sidebar
permalink: /doc/en/lb4/Working-with-data.html
---
In LoopBack 4, models describe the shape of data, repositories provide behavior
like CRUD operations, and controllers define routes (this is different from
LoopBack 3.x where models implement behavior too). LB4
[repositories](Repository.md) provide a couple of create, read, update, and
delete (CRUD) operations. Once you have defined these three artifacts, you can
add data to the model, manipulate the data, and query it through these CRUD
operations. The following is an overview of CRUD operations at different levels:
<table>
<thead>
<tr>
<th width="120">Operation</th>
<th width="360"><a href="https://loopback.io/doc/en/lb4/Routes.html">REST</a></th>
<th width="300">LoopBack model method<br>(Node.js API)*</th>
<th width="120">Corresponding SQL<br>Operation</th>
</tr>
</thead>
<tbody>
<tr>
<td>Create</td>
<td>
PUT /<em>modelName</em>
<br/>POST /<em>modelName</em>
</td>
<td><code><a href="https://loopback.io/doc/en/lb4/apidocs.repository.defaultcrudrepository.create.html" class="external-link" rel="nofollow">create()</a></code>
<br/><code><a href="https://loopback.io/doc/en/lb4/apidocs.repository.defaultcrudrepository.createall.html" class="external-link" rel="nofollow">createAll()</a></code>
</td>
<td>INSERT</td>
</tr>
<tr>
<td>Read (Retrieve)</td>
<td>GET /<em>modelName</em>?filter=...</td>
<td><code><a href="https://loopback.io/doc/en/lb4/apidocs.repository.defaultcrudrepository.find.html" class="external-link" rel="nofollow">find<sup>*</sup>()</a></code>
</td>
<td>SELECT</td>
</tr>
<tr>
<td>Update (Modify)</td>
<td>
POST /<em>modelName</em>
<br/>PUT /<em>modelName</em>
</td>
<td><code><a href="https://loopback.io/doc/en/lb4/apidocs.repository.defaultcrudrepository.update.html" class="external-link" rel="nofollow">update<sup>*</sup>()</a></code>
<br/><code><a href="https://loopback.io/doc/en/lb4/apidocs.repository.defaultcrudrepository.replacebyid.html" class="external-link" rel="nofollow">replaceById()</a></code>
</td>
<td>UPDATE</td>
</tr>
<tr>
<td>Delete (Destroy)</td>
<td>DELETE /<em>modelName</em>/<em>modelID</em></td>
<td><code><a href="https://loopback.io/doc/en/lb4/apidocs.repository.defaultcrudrepository.delete.html" class="external-link" rel="nofollow">delete<sup>*</sup>()</a></code>
</td>
<td>DELETE</td>
</tr>
</tbody>
</table>
(\*) Methods listed are just prominent examples; other methods may provide
similar functionality; for example: `findById()`, `findOne()`,
and `updateAll()`. See
[DefaultCrudRepository Methods API documentation](https://loopback.io/doc/en/lb4/apidocs.repository.defaultcrudrepository.html#methods)
for more information.
See the following articles for more information:
- [Querying data](Querying-data.md)
- [Fields filter](Fields-filter.md)
- [Include filter](Include-filter.md)
- [Limit filter](Limit-filter.md)
- [Order filter](Order-filter.md)
- [Skip filter](Skip-filter.md)
- [Where filter](Where-filter.md)
- [Using database transactions](guides/data-access/transactions.md)
- [Executing database commands](Executing-database-commands.md)