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
|
// file : odb/oracle/statement.ixx
// license : ODB NCUEL; see accompanying LICENSE file
using namespace std;
namespace odb
{
namespace oracle
{
// bulk_statement
//
inline bulk_statement::
bulk_statement (connection_type& c,
const std::string& text,
statement_kind k,
const binding* process,
bool optimize,
std::size_t batch,
sb4* status)
: statement (c, text, k, process, optimize),
status_ (batch == 1 ? 0 : status)
{
}
inline bulk_statement::
bulk_statement (connection_type& c,
const char* text,
statement_kind k,
const binding* process,
bool optimize,
std::size_t batch,
sb4* status)
: statement (c, text, k, process, optimize),
status_ (batch == 1 ? 0 : status)
{
}
// insert_statement
//
inline void insert_statement::
fetch (sword r, sb4 code)
{
result_ = true;
if (r != 0 /*OCI_SUCCESS*/)
{
// An auto-assigned object id should never cause a duplicate primary
// key.
//
if (ret_ == 0)
{
// The Oracle error code ORA-00001 indicates unique constraint
// violation, which covers more than just a duplicate primary key.
// Unfortunately, there is nothing more precise that we can use.
//
if (code == 1)
result_ = false;
}
}
}
}
}
|