Mercurial > hg > orthanc-databases
annotate Framework/Common/GenericFormatter.cpp @ 522:c49136b34891 large-queries
use a prepared statement for InsertOrUpdateMetadata
author | Alain Mazy <am@orthanc.team> |
---|---|
date | Fri, 05 Jul 2024 09:15:54 +0200 |
parents | 54d518dcd74a |
children |
rev | line source |
---|---|
0 | 1 /** |
2 * Orthanc - A Lightweight, RESTful DICOM Store | |
3 * Copyright (C) 2012-2016 Sebastien Jodogne, Medical Physics | |
4 * Department, University Hospital of Liege, Belgium | |
507
54d518dcd74a
updated copyright, as Orthanc Team now replaces Osimis
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
459
diff
changeset
|
5 * Copyright (C) 2017-2023 Osimis S.A., Belgium |
54d518dcd74a
updated copyright, as Orthanc Team now replaces Osimis
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
459
diff
changeset
|
6 * Copyright (C) 2024-2024 Orthanc Team SRL, Belgium |
459
ecd0b719cff5
update year to 2024
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
389
diff
changeset
|
7 * Copyright (C) 2021-2024 Sebastien Jodogne, ICTEAM UCLouvain, Belgium |
0 | 8 * |
9 * This program is free software: you can redistribute it and/or | |
10 * modify it under the terms of the GNU Affero General Public License | |
11 * as published by the Free Software Foundation, either version 3 of | |
12 * the License, or (at your option) any later version. | |
13 * | |
14 * This program is distributed in the hope that it will be useful, but | |
15 * WITHOUT ANY WARRANTY; without even the implied warranty of | |
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU | |
17 * Affero General Public License for more details. | |
18 * | |
19 * You should have received a copy of the GNU Affero General Public License | |
20 * along with this program. If not, see <http://www.gnu.org/licenses/>. | |
21 **/ | |
22 | |
23 | |
24 #include "GenericFormatter.h" | |
25 | |
152 | 26 #include <OrthancException.h> |
0 | 27 |
28 #include <boost/lexical_cast.hpp> | |
29 | |
30 namespace OrthancDatabases | |
31 { | |
304
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
32 Dialect GenericFormatter::GetDialect() const |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
33 { |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
34 if (autoincrementDialect_ != namedDialect_) |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
35 { |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
36 // The two dialects do not match because of a previous call to |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
37 // SetAutoincrementDialect() or SetNamedDialect() |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
38 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadSequenceOfCalls); |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
39 } |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
40 else |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
41 { |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
42 return namedDialect_; |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
43 } |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
44 } |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
45 |
dd4b0edd1661
GenericFormatter::GetDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
303
diff
changeset
|
46 |
0 | 47 void GenericFormatter::Format(std::string& target, |
48 const std::string& source, | |
49 ValueType type) | |
50 { | |
51 if (source.empty()) | |
52 { | |
302
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
53 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
54 } |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
55 else if (source == "AUTOINCREMENT") |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
56 { |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
57 if (GetParametersCount() != 0) |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
58 { |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
59 throw Orthanc::OrthancException(Orthanc::ErrorCode_BadSequenceOfCalls, |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
60 "The AUTOINCREMENT argument must always be the first"); |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
61 } |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
62 |
303
495b6f325e35
GenericFormatter::SetNamedDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
302
diff
changeset
|
63 switch (autoincrementDialect_) |
0 | 64 { |
65 case Dialect_PostgreSQL: | |
302
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
66 target = "DEFAULT, "; |
0 | 67 break; |
68 | |
69 case Dialect_MySQL: | |
70 case Dialect_SQLite: | |
302
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
71 target = "NULL, "; |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
72 break; |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
73 |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
74 case Dialect_MSSQL: |
3a52e27a2d80
in GenericFormatter, replaced ${} by ${AUTOINCREMENT}
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
299
diff
changeset
|
75 target.clear(); // The IDENTITY field must not be filled in MSSQL |
0 | 76 break; |
77 | |
78 default: | |
79 throw Orthanc::OrthancException(Orthanc::ErrorCode_NotImplemented); | |
80 } | |
81 } | |
82 else | |
83 { | |
303
495b6f325e35
GenericFormatter::SetNamedDialect()
Sebastien Jodogne <s.jodogne@gmail.com>
parents:
302
diff
changeset
|
84 switch (namedDialect_) |
0 | 85 { |
86 case Dialect_PostgreSQL: | |
87 target = "$" + boost::lexical_cast<std::string>(parametersName_.size() + 1); | |
88 break; | |
89 | |
90 case Dialect_MySQL: | |
91 case Dialect_SQLite: | |
297 | 92 case Dialect_MSSQL: |
0 | 93 target = "?"; |
94 break; | |
95 | |
96 default: | |
97 throw Orthanc::OrthancException(Orthanc::ErrorCode_NotImplemented); | |
98 } | |
99 | |
100 parametersName_.push_back(source); | |
101 parametersType_.push_back(type); | |
102 } | |
103 } | |
104 | |
105 | |
106 const std::string& GenericFormatter::GetParameterName(size_t index) const | |
107 { | |
108 if (index >= parametersName_.size()) | |
109 { | |
110 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); | |
111 } | |
112 else | |
113 { | |
114 return parametersName_[index]; | |
115 } | |
116 } | |
117 | |
118 | |
119 ValueType GenericFormatter::GetParameterType(size_t index) const | |
120 { | |
121 if (index >= parametersType_.size()) | |
122 { | |
123 throw Orthanc::OrthancException(Orthanc::ErrorCode_ParameterOutOfRange); | |
124 } | |
125 else | |
126 { | |
127 return parametersType_[index]; | |
128 } | |
129 } | |
130 } |