File: updating.rst

package info (click to toggle)
python-pyodata 1.11.2-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 1,280 kB
  • sloc: python: 7,170; xml: 947; makefile: 67; sh: 15
file content (47 lines) | stat: -rw-r--r-- 1,585 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
Updating
========

To update an entity, you must create an updated request, set properties to the
values you want and execute the request. The library will send an HTTP PATCH
request to the remote service.

.. code-block:: python

    import pyodata
    import requests

    SERVICE_URL = 'http://services.odata.org/V2/Northwind/Northwind.svc/'

    northwind = pyodata.Client(SERVICE_URL, requests.Session())

    update_request = northwind.entity_sets.Customers.update_entity(CustomerID='ALFKI')
    update_request.set(CompanyName='Alfons Kitten')
    update_request.execute()


In the case the service you are dealing with requires PUT method, you have two options.

The first option allows you to change the used HTTP method for a single call via
the key word parameter *method* of the method *update_entity*.

.. code-block:: python

    update_request = northwind.entity_sets.Customers.update_entity(CustomerID='ALFKI', method='PUT')

If you need to run more update requests for different entity sets and all of them must be *PUT*,
then you can consider setting the default service's update method to *PUT*.

.. code-block:: python

    northwind.config['http']['update_method'] = 'PUT'

Encode OData URL Path
-------------------------------------------

By default the resource paths of requests are percent encoded. However if this is not what your API expects, 
you can disable the encoding with the variable encode_path by setting it to False.


.. code-block:: python

    update_request = northwind.entity_sets.Customers.update_entity(CustomerID='ALFKI', encode_path=False)