コンテンツへスキップ
メニュー
この質問にフラグが付けられました
1 返信
6427 ビュー

I am working on a meeting room reservation module on Odoo I am trying to compare the date that I am about the insert with the dates that I have in the database. i tried the search(), the browse() functions i also tried to iterate on the recordset but it always points on the record that i am about to insert. i was thinking about doint it through an SQL query but i can't find the table's name where the data is stored.

Here is the class definition:

class Reservation(models.Model):
    _name = 'module001.reservation'

    name = fields.Char(String="Reservation Number", required=True)
    start_date = fields.Datetime(default=fields.Date.today)
    room_number = fields.Many2one('module001.room', ondelete='cascade', string="Room", required=True)
    reserved_for = fields.Many2one('res.partner', string="Reserved for ")
    end_date = fields.Datetime(string="End Date", store=True)

Thank you in advance

アバター
破棄
最善の回答
def write(self, cr, uid, ids, values, context=None):
    print "NEW DATE:", values.get('start')
    print "OLD DATE:", self.browse(cr, uid, ids[0], context).start

Just tested, and it works !


Else, your table name should be module001_reservation... but it's better to use orm for it ...

アバター
破棄
著作者

i got it done using SQL, Thank you for your help !

関連投稿 返信 ビュー 活動
2
4月 23
39488
0
12月 21
3166
2
2月 19
10670
14
12月 17
102770
0
9月 17
3340