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

Sun, 17 May 2020 16:38:04 +0200

author
Mike Becker <universe@uap-core.de>
date
Sun, 17 May 2020 16:38:04 +0200
changeset 61
3e287f361c7a
parent 47
57cfb94ab99f
child 62
833e0385572a
permissions
-rw-r--r--

moves project index to separate sub path

unfortunately the current menu highlighting strategy sucks and this is the easiest way so that everything looks correct

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
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
31 import java.sql.PreparedStatement;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
32 import java.sql.SQLException;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
33 import java.sql.Types;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
34 import java.util.Optional;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
35 import java.util.function.Function;
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
36
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 * Some DAO utilities.
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
39 */
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
40 public final class Functions {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
41
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
42 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
43 if (str == null || str.isBlank()) {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
44 stmt.setNull(index, Types.VARCHAR);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
45 } else {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
46 stmt.setString(index, str);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
47 }
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 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
51 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
52 if (key == null) {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
53 stmt.setNull(index, Types.INTEGER);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
54 } else {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
55 stmt.setInt(index, key);
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
56 }
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
57 }
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
58
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
59 private Functions() {
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
60
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
61 }
57cfb94ab99f projects can now be added and updated
Mike Becker <universe@uap-core.de>
parents:
diff changeset
62 }

mercurial