Skip ke Konten
Odoo Menu
  • Login
  • Uji coba gratis
  • Aplikasi
    Keuangan
    • Akuntansi
    • Faktur
    • Pengeluaran
    • Spreadsheet (BI)
    • Dokumen
    • Tanda Tangan
    Sales
    • CRM
    • Sales
    • POS Toko
    • POS Restoran
    • Langganan
    • Rental
    Website
    • Website Builder
    • eCommerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Rantai Pasokan
    • Inventaris
    • Manufaktur
    • PLM
    • Purchase
    • Maintenance
    • Kualitas
    Sumber Daya Manusia
    • Karyawan
    • Rekrutmen
    • Cuti
    • Appraisal
    • Referensi
    • Armada
    Marketing
    • Social Marketing
    • Email Marketing
    • SMS Marketing
    • Acara
    • Otomatisasi Marketing
    • Survei
    Layanan
    • Project
    • Timesheet
    • Layanan Lapangan
    • Meja Bantuan
    • Planning
    • Appointment
    Produktivitas
    • Diskusi
    • Approval
    • IoT
    • VoIP
    • Pengetahuan
    • WhatsApp
    Aplikasi pihak ketiga Odoo Studio Platform Odoo Cloud
  • Industri-Industri
    Retail
    • Toko Buku
    • Toko Baju
    • Toko Furnitur
    • Toko Kelontong
    • Toko Hardware
    • Toko Mainan
    Makanan & Hospitality
    • Bar dan Pub
    • Restoran
    • Fast Food
    • Rumah Tamu
    • Distributor Minuman
    • Hotel
    Real Estate
    • Agensi Real Estate
    • Firma Arsitektur
    • Konstruksi
    • Estate Management
    • Perkebunan
    • Asosiasi Pemilik Properti
    Konsultansi
    • Firma Akuntansi
    • Mitra Odoo
    • Agensi Marketing
    • Firma huku
    • Talent Acquisition
    • Audit & Sertifikasi
    Manufaktur
    • Tekstil
    • Logam
    • Perabotan
    • Makanan
    • Brewery
    • Corporate Gift
    Kesehatan & Fitness
    • Sports Club
    • Toko Kacamata
    • Fitness Center
    • Wellness Practitioners
    • Farmasi
    • Salon Rambut
    Perdagangan
    • Handyman
    • IT Hardware & Support
    • Sistem-Sistem Energi Surya
    • Pembuat Sepatu
    • Cleaning Service
    • Layanan HVAC
    Lainnya
    • Organisasi Nirlaba
    • Agen Lingkungan
    • Rental Billboard
    • Fotografi
    • Penyewaan Sepeda
    • Reseller Software
    Browse semua Industri
  • Komunitas
    Belajar
    • Tutorial-tutorial
    • Dokumentasi
    • Sertifikasi
    • Pelatihan
    • Blog
    • Podcast
    Empower Education
    • Program Edukasi
    • Game Bisnis 'Scale Up!'
    • Kunjungi Odoo
    Dapatkan Softwarenya
    • Download
    • Bandingkan Edisi
    • Daftar Rilis
    Kolaborasi
    • Github
    • Forum
    • Acara
    • Terjemahan
    • Menjadi Partner
    • Layanan untuk Partner
    • Daftarkan perusahaan Akuntansi Anda.
    Dapatkan Layanan
    • Temukan Mitra
    • Temukan Akuntan
    • Temui penasihat
    • Layanan Implementasi
    • Referensi Pelanggan
    • Bantuan
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Dapatkan demo
  • Harga
  • Bantuan

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Akuntansi
  • Inventaris
  • PoS
  • Project
  • MRP
All apps
Anda harus terdaftar untuk dapat berinteraksi di komunitas.
Semua Post Orang Lencana-Lencana
Label (Lihat semua)
odoo accounting v14 pos v15
Mengenai forum ini
Anda harus terdaftar untuk dapat berinteraksi di komunitas.
Semua Post Orang Lencana-Lencana
Label (Lihat semua)
odoo accounting v14 pos v15
Mengenai forum ini
Help

[SOLVED] How to do a 'where' in self.env[].search() ?

Langganan

Dapatkan notifikasi saat terdapat aktivitas pada post ini

Pertanyaan ini telah diberikan tanda
envsearch()
2 Replies
28693 Tampilan
Avatar
Quentin Villanova

Hi !

I'm new to Odoo 13 and Python so everything is a bit confusing at the moment.

My problem is that I need to do a request like "SELECT ... FROM ... WHERE ...", but I don't understand how I should do it here.

I have the first part which looks like that "self.env['my.table'].search([('the_this_i_want')])".

I would like to add something like "self.env['my.table'].search([('the_thing_i_want')]).where([('id','=',self.id)])".

Thanks.


0
Avatar
Buang
Avatar
Răzvan Anastasescu
Jawaban Terbai

What you put in search parameter (called domain) it's your where criteria.

You really should read the ORM documentation about domain search

The domain it's written in Polish Notation system, because you can normalize (stringify) the search string (useful from client-side) - more in this post.

For your example:

self.env['my.model'].search([('id', '=', self.id)])

The same (searching by id or a list of ids) can also be done using special browse method like this

self.env['my.model'].browse(self.id)
self.env['my.model'].browse([1, 2, 3])

You have to be careful because browse doesn't check if the record really exists in the DataBase, if you want to be sure it exists, you can use exists() method after it, like this:

self.env['my.model'].browse([1, 2, 3]).exists()

By default, if you write multiple conditions, they are treated as AND

self.env['my.model'].search([('my_field', '=', 'value'), ('my_other_field', '!=', False)])

To build more complex searches, you really have to check documentation, understand how to write complex domains using RPN (with ORs and ANDs) and look in Odoo code for more examples

3
Avatar
Buang
Ray Carnes (ray)

Great answer! I updated it to add a link to a post explaining Polish Notation as it applies to Odoo domains.

Avatar
Quentin Villanova
Penulis Jawaban Terbai

Hi, thanks a lot for your reply.

Ok so it gives me some ligth on my problem. So I put my criteria in "search()", but if I do that it returns me an id, but it's not the thing I want.

I should give you a more precise example.

I want a date stored in my DB, in a table called 'ticket'. But it want this date depends on a specifique id.

So I should do something like : "self.env['ticket'].search([('id','=',self.id)])"

But where do I say that I want the "date" and not the id ?

In SQL it would looks like : "SELECT date FROM ticket WHERE id = self.id.

Thanks a lot for your help.

1
Avatar
Buang
Marcos Oitabén

It returns a ticket object, not only the id. (But if you try to print it, you will only get the id printed)
ticket = self.env['ticket'].search([('id','=',self.id)])
ticket.name_of_field
eg: ticket.name, ticket.date, ticket.id

Quentin Villanova
Penulis

I didn't know that ! OMG tanks a lot, you save me precious time !

Menikmati diskusi? Jangan hanya membaca, ikuti!

Buat akun sekarang untuk menikmati fitur eksklufi dan agar terlibat dengan komunitas kami!

Daftar
Post Terkait Replies Tampilan Aktivitas
How do I set environment variables when Odoo Upgrade fails?
upgrading env
Avatar
2
Sep 24
44
Multicompany Issue
multicompany env
Avatar
Avatar
Avatar
2
Agu 24
1953
Object has no attribute 'env' error when trying to use self.env. I want to run code on module install (via init). What's the best approach? Diselesaikan
init env
Avatar
Avatar
Avatar
6
Agu 18
21051
I want to create new self.env.<something>
env v15 v17
Avatar
0
Des 23
17
How to trigger onchange when creating records through server in V13 Diselesaikan
onchange env v13
Avatar
1
Apr 24
8007
Komunitas
  • Tutorial-tutorial
  • Dokumentasi
  • Forum
Open Source
  • Download
  • Github
  • Runbot
  • Terjemahan
Layanan
  • Odoo.sh Hosting
  • Bantuan
  • Peningkatan
  • Custom Development
  • Pendidikan
  • Temukan Akuntan
  • Temukan Mitra
  • Menjadi Partner
Tentang Kami
  • Perusahaan kami
  • Aset Merek
  • Hubungi kami
  • Tugas
  • Acara
  • Podcast
  • Blog
  • Pelanggan
  • Hukum • Privasi
  • Keamanan
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo adalah rangkaian aplikasi bisnis open source yang mencakup semua kebutuhan perusahaan Anda: CRM, eCommerce, akuntansi, inventaris, point of sale, manajemen project, dan seterusnya.

Mudah digunakan dan terintegrasi penuh pada saat yang sama adalah value proposition unik Odoo.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now