blob: 430bb193b9d8ebde144584ad81d5da0f72f804c3 (
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
|
// file : oracle/custom/test.hxx
// copyright : Copyright (c) 2009-2018 Code Synthesis Tools CC
// license : GNU GPL v2; see accompanying LICENSE file
#ifndef TEST_HXX
#define TEST_HXX
#include <vector>
#include <odb/core.hxx>
// Map Numbers VARRAY Oracle type to std::vector<int>. This type is defined
// in the custom.sql file along with two helper functions that convert
// between Numbers and its string representation. The other half of this
// mapping is in traits.hxx (value_traits<std::vector<int>, id_string>).
//
#pragma db map type("Numbers") \
as("VARCHAR2(1500)") \
to("CAST(string_to_numbers((?)) AS Numbers)") \
from("numbers_to_string((?))")
#pragma db object
struct object
{
object () {}
object (unsigned long id_) : id (id_) {}
#pragma db id
unsigned long id;
#pragma db type("Numbers")
std::vector<int> iv;
bool
operator== (const object& y) const
{
return id == y.id && iv == y.iv;
}
};
#endif // TEST_HXX
|