aboutsummaryrefslogtreecommitdiff
path: root/container/driver.cxx
blob: 566f89e99f93846e85e3cb2acf9800c07ac3f8cb (plain)
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
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// file      : container/driver.cxx
// copyright : not copyrighted - public domain

#include <memory>   // std::auto_ptr
#include <iostream>

#include <odb/database.hxx>
#include <odb/transaction.hxx>

#include "database.hxx" // create_database

#include "person.hxx"
#include "person-odb.hxx"

using namespace std;
using namespace odb::core;

void
print (const person& p)
{
  cout << p.first () << " " << p.last () << endl;

  // Print nicknames.
  //
  for (names::const_iterator i (p.nicknames ().begin ());
       i != p.nicknames ().end (); ++i)
  {
    cout << "  nickname: " << *i << endl;
  }

  // Print emails.
  //
  for (emails::const_iterator i (p.emails ().begin ());
       i != p.emails ().end (); ++i)
  {
    cout << "  email: " << *i << endl;
  }

  // Print weights.
  //
  for (age_weight_map::const_iterator i (p.age_weight ().begin ());
       i != p.age_weight ().end (); ++i)
  {
    cout << "  weight at " << i->first << ": " << i->second << endl;
  }
}

int
main (int argc, char* argv[])
{
  try
  {
    auto_ptr<database> db (create_database (argc, argv));

    unsigned long id;

    // Create a persistent person object.
    //
    {
      person joe ("Joe", "Dirt");

      joe.nicknames ().push_back ("JD");
      joe.nicknames ().push_back ("Squeaky");

      joe.emails ().insert ("joe@example.com");
      joe.emails ().insert ("joe.dirt@example.com");

      joe.age_weight ()[5] = 15.6F;
      joe.age_weight ()[10] = 23.3F;
      joe.age_weight ()[15] = 29.8F;

      transaction t (db->begin ());
      id = db->persist (joe);
      t.commit ();
    }

    // Load the object and print what we've got. Then change some
    // information and update it in the database.
    //
    {
      transaction t1 (db->begin ());
      auto_ptr<person> j (db->load<person> (id));
      t1.commit ();

      print (*j);

      // Ann another nickname.
      //
      j->nicknames ().push_back ("Cleaner");

      // The joe@example.com email is no longer working.
      //
      j->emails ().erase ("joe@example.com");

      // Update a weight sample.
      //
      j->age_weight ()[15] = 28.8F;

      transaction t2 (db->begin ());
      db->update (*j);
      t2.commit ();
    }

    // Load and print the updated object.
    //
    {
      transaction t (db->begin ());
      auto_ptr<person> j (db->load<person> (id));
      t.commit ();

      print (*j);
    }
  }
  catch (const odb::exception& e)
  {
    cerr << e.what () << endl;
    return 1;
  }
}