src/main/java/de/uapcore/lightpit/dao/Functions.java

Thu, 08 Oct 2020 20:38:43 +0200

author
Mike Becker <universe@uap-core.de>
date
Thu, 08 Oct 2020 20:38:43 +0200
changeset 110
9d0be0b1580f
parent 62
833e0385572a
child 138
e2aa673dd473
permissions
-rw-r--r--

adds indicators for version status

replaces table column "Status" with version tag
fixes New Version form button not overriding the session version ID

47
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
1 /*
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
2 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
3 *
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
4 * Copyright 2018 Mike Becker. All rights reserved.
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
5 *
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
6 * Redistribution and use in source and binary forms, with or without
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
7 * modification, are permitted provided that the following conditions are met:
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
8 *
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
9 * 1. Redistributions of source code must retain the above copyright
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
10 * notice, this list of conditions and the following disclaimer.
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
11 *
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
12 * 2. Redistributions in binary form must reproduce the above copyright
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
13 * notice, this list of conditions and the following disclaimer in the
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
14 * documentation and/or other materials provided with the distribution.
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
15 *
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
16 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
17 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
18 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
19 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
20 * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
21 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
22 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
23 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
24 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
25 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
26 * POSSIBILITY OF SUCH DAMAGE.
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
27 *
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
28 */
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
29 package de.uapcore.lightpit.dao;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
30
62
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
31 import java.sql.Date;
47
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
32 import java.sql.PreparedStatement;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
33 import java.sql.SQLException;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
34 import java.sql.Types;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
35 import java.util.Optional;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
36 import java.util.function.Function;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
37
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
38 /**
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
39 * Some DAO utilities.
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
40 */
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
41 public final class Functions {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
42
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
43 public static void setStringOrNull(PreparedStatement stmt, int index, String str) throws SQLException {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
44 if (str == null || str.isBlank()) {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
45 stmt.setNull(index, Types.VARCHAR);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
46 } else {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
47 stmt.setString(index, str);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
48 }
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
49 }
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
50
62
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
51 public static void setDateOrNull(PreparedStatement stmt, int index, Date date) throws SQLException {
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
52 if (date == null) {
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
53 stmt.setNull(index, Types.DATE);
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
54 } else {
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
55 stmt.setDate(index, date);
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
56 }
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
57 }
833e0385572a adds data model for issues
Mike Becker <universe@uap-core.de>
parents: 47
diff changeset
58
47
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
59 public static <T> void setForeignKeyOrNull(PreparedStatement stmt, int index, T instance, Function<? super T, Integer> keyGetter) throws SQLException {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
60 Integer key = Optional.ofNullable(instance).map(keyGetter).orElse(null);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
61 if (key == null) {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
62 stmt.setNull(index, Types.INTEGER);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
63 } else {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
64 stmt.setInt(index, key);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
65 }
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
66 }
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
67
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
68 private Functions() {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
69
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
70 }
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
71 }

mercurial