Skip to Content
Odoo Meniu
  • Autentificare
  • Try it free
  • Aplicații
    Finanțe
    • Contabilitate
    • Facturare
    • Cheltuieli
    • Spreadsheet (BI)
    • Documente
    • Semn
    Vânzări
    • CRM
    • Vânzări
    • POS Shop
    • POS Restaurant
    • Abonamente
    • Închiriere
    Site-uri web
    • Constructor de site-uri
    • eCommerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Lanț Aprovizionare
    • Inventar
    • Producție
    • PLM
    • Achiziție
    • Maintenance
    • Calitate
    Resurse Umane
    • Angajați
    • Recrutare
    • Time Off
    • Evaluări
    • Referințe
    • Flotă
    Marketing
    • Social Marketing
    • Marketing prin email
    • SMS Marketing
    • Evenimente
    • Automatizare marketing
    • Sondaje
    Servicii
    • Proiect
    • Foi de pontaj
    • Servicii de teren
    • Centru de asistență
    • Planificare
    • Programări
    Productivitate
    • Discuss
    • Aprobări
    • IoT
    • VoIP
    • Knowledge
    • WhatsApp
    Aplicații Terțe Odoo Studio Platforma Odoo Cloud
  • Industrii
    Retail
    • Book Store
    • Magazin de îmbrăcăminte
    • Magazin de Mobilă
    • Magazin alimentar
    • Magazin de materiale de construcții
    • Magazin de jucării
    Food & Hospitality
    • Bar and Pub
    • Restaurant
    • Fast Food
    • Guest House
    • Distribuitor de băuturi
    • Hotel
    Proprietate imobiliara
    • Real Estate Agency
    • Firmă de Arhitectură
    • Construcție
    • Estate Managament
    • Grădinărit
    • Asociația Proprietarilor de Proprietăți
    Consultanta
    • Firma de Contabilitate
    • Partener Odoo
    • Agenție de marketing
    • Law firm
    • Atragere de talente
    • Audit & Certification
    Producție
    • Textil
    • Metal
    • Mobilier
    • Mâncare
    • Brewery
    • Cadouri corporate
    Health & Fitness
    • Club Sportiv
    • Magazin de ochelari
    • Centru de Fitness
    • Wellness Practitioners
    • Farmacie
    • Salon de coafură
    Trades
    • Handyman
    • IT Hardware and Support
    • Asigurare socială de stat
    • Cizmar
    • Servicii de curățenie
    • HVAC Services
    Altele
    • Organizație nonprofit
    • Agenție de Mediu
    • Închiriere panouri publicitare
    • Fotografie
    • Închiriere biciclete
    • Asigurare socială
    Browse all Industries
  • Comunitate
    Învăță
    • Tutorials
    • Documentație
    • Certificări
    • Instruire
    • Blog
    • Podcast
    Empower Education
    • Program Educațional
    • Scale Up! Business Game
    • Visit Odoo
    Obține Software-ul
    • Descărcare
    • Compară Edițiile
    • Lansări
    Colaborați
    • Github
    • Forum
    • Evenimente
    • Translations
    • Devino Partener
    • Services for Partners
    • Înregistrează-ți Firma de Contabilitate
    Obține Servicii
    • Găsește un Partener
    • Găsiți un contabil
    • Meet an advisor
    • Servicii de Implementare
    • Referințe ale clienților
    • Suport
    • Actualizări
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Obține un demo
  • Prețuri
  • Ajutor

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

  • CRM
  • e-Commerce
  • Contabilitate
  • Inventar
  • PoS
  • Proiect
  • MRP
All apps
Trebuie să fiți înregistrat pentru a interacționa cu comunitatea.
All Posts Oameni Insigne
Etichete (View all)
odoo accounting v14 pos v15
Despre acest forum
Trebuie să fiți înregistrat pentru a interacționa cu comunitatea.
All Posts Oameni Insigne
Etichete (View all)
odoo accounting v14 pos v15
Despre acest forum
Suport

remove time from datetime field odoo 15

Abonare

Primiți o notificare când există activitate la acestă postare

Această întrebare a fost marcată
datetimesqlconstraints
3 Răspunsuri
6827 Vizualizări
Imagine profil
Ghassen

Hi Guys, In my Medical Lab project I wanted to use SQL CONSTRAINTS to prevent the same patient of having two appointments in the same day however the appointment_date field is a datetime field which means the validation of SQL constraints works only if the patient would have more than one appointment in the same exact date and the same exact time along with seconds.

but I want the validation to be based on the day month year only.


_sql_constraints = [
('name_code_unique', 'unique (patient_id, appointment_date)', 'An Appointment For the Same Patient Has Already Been Booked On The Same Date'),
]


any one would help please




0
Imagine profil
Abandonează
Imagine profil
Arian Shariat
Cel mai bun răspuns

Approach 1:

change your field from date = fields.Datetime to fields.Date

you can override the field by inheriting the model.

Approach 2:

override create and write functions to validate date field.

The "create" function example comes below. You have to override the "write" method as well.

from odoo import models, api

import dateutil.parser
from dateutil.relativedelta import relativedelta
from odoo.exceptions import ValidationError


class YourClass(models.Model):
_name = 'module.name'

@api.model
def create
(self, vals_list):
date = vals_list.get('date', None)
if date:
date = dateutil.parser.parse(date).date()
record = self.env['sale.order'].search([('date', '>=', date), ('date', ', date + relativedelta(days=1))])
if record:
raise ValidationError('An appointment is already set for this user on corresponding day.')
return super(YourClass, self).create(vals_list)


1
Imagine profil
Abandonează
Arian Shariat

EDIT:
record = self.env['sale.order'].search([('date', '>=', date), ('date', '<', date + relativedelta(days=1))])

Imagine profil
gitpruuu
Cel mai bun răspuns

Hello..

I think you could the attr date.date:

Suppose your variable its called date = fields.Datetime(), using date.date and you will get date only from this variable.

0
Imagine profil
Abandonează
Imagine profil
Cybrosys Techno Solutions Pvt.Ltd
Cel mai bun răspuns

Hi,

In Odoo we have fields DateTime and Date . You can use

field_without_time = fields.Date(string=" ")

for saving date only. In this method the database will only store date.So, you can easily get the date without time.
When we use sql constraints , it will directly check the values from the database. So, if you are using

field_name_with_datetime = fields.DateTime(string=" ")

you have to store the field with only date in the database. You can use the .date() function to get a date from datetime. It can be done just by using an onchange function. So , whenever you choose the first field, the second field will save with only a date. And you can add this field into sql constraints.

Example

@api.onchange('field_name_with_datetime')
def _onchange_field_name_with_datetime(self):
    if self.field_name_with_datetime:
    self.field_without_time = self.field_name_with_datetime.date()

And change sql constraints like this:

_sql_constraints = [('name_code_unique', 'unique (patient_id, field_without_time)', 'An Appointment For the Same Patient Has Already Been Booked On The Same Date'),]

Regards

0
Imagine profil
Abandonează
Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Înscrie-te
Related Posts Răspunsuri Vizualizări Activitate
See the SQL constraints section for further details?
sql constraints
Imagine profil
Imagine profil
Imagine profil
2
mar. 15
11715
Odoo12: SQL Constraint not working?!?
sql constraints Odoo12.0
Imagine profil
0
aug. 20
5346
How to create SQL Constraints in Wizard with models.TransientModel ?
wizard sql constraints
Imagine profil
1
iun. 17
1282
Need constraints for Customer name field doesn't allow "spaces"? Rezolvat
customer sql constraints
Imagine profil
Imagine profil
Imagine profil
2
nov. 15
7853
sql constraints exception Rezolvat
database sql constraints odoo12
Imagine profil
Imagine profil
2
sept. 21
4674
Comunitate
  • Tutorials
  • Documentație
  • Forum
Open Source
  • Descărcare
  • Github
  • Runbot
  • Translations
Servicii
  • Hosting Odoo.sh
  • Suport
  • Actualizare
  • Custom Developments
  • Educație
  • Găsiți un contabil
  • Găsește un Partener
  • Devino Partener
Despre Noi
  • Compania noastră
  • Active de marcă
  • Contactați-ne
  • Locuri de muncă
  • Evenimente
  • Podcast
  • Blog
  • Clienți
  • Aspecte juridice • Confidențialitate
  • Securitate
الْعَرَبيّة 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 este o suită de aplicații de afaceri open source care acoperă toate nevoile companiei dvs.: CRM, comerț electronic, contabilitate, inventar, punct de vânzare, management de proiect etc.

Propunerea de valoare unică a Odoo este să fie în același timp foarte ușor de utilizat și complet integrat.

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