MySQL 複数のTIMESTAMP DEFAULT CURRENT_TIMESTAMP

SQL

昔、MySQL で、複数のTIMESTAMP で DEFAULT CURRENT_TIMESTAMP を宣言しようとして、 DELIMITER // DROP TABLE IF EXISTS branch; // CREATE TABLE branch ( id INT NOT NULL AUTO_INCREMENT , branch_name VARCHAR(64) NOT NULL , created_at TIMESTAMP NOT…

MySQL AUTO_INCREMENTエラーの時のエラーコード

SQL

MySQL AUTO_INCREMENT がMAXを超える時、どんなエラーコードだっけ? と忘れていたので、簡単に用意して実行した結果は、INSERT の発生させる AUTO_INCREMENT のエラー Error Code: 1062. Duplicate entry '2147483647' for key 'PRIMARY' INTのMAX 21474836…

@JsonAdapter >registerTypeAdapter

Google gson で、@JsonAdapter と、GsonBuilder の registerTypeAdapter で指定するアダプター どちらが優先されるか?@JsonAdapter が、優先される。 oboe2uran.hatenablog.com

gson のシリアライズ用アノテーション

@Expose GsonBuilder で、excludeFieldsWithoutExposeAnnotation() を指定すれば、 @Expose が付いたフィールドだけシリアライズする Gson gson = new GsonBuilder().excludeFieldsWithoutExposeAnnotation() .create(): @SerializedName フィールド名でなく…

LAST_INSERT_ID() の 0埋め

SQL

随分前に、MySQL の UNSIGNED ZEROFILL NOT NULL AUTO_INCREMENT のメモを書いていた。 https://oboe2uran.hatenablog.com/entry/2018/02/01/160016 CREATE TABLE branches ( id INT(4) UNSIGNED ZEROFILL NOT NULL AUTO_INCREMENT , branch_name VARCHAR(60…

無限Stream を limit でなく別の方法で STOP させる。

limit を使わずに Stream 止め方には、トリッキーではあるが、 filter(Predicate) 、findAny() で止めるか、anyMatch(Predicate) で、止める方法がある。 Stream.iterate(1, i->i+1) .peek(System.out::println) .filter(n->n > 9) .findAny(); これの findA…

Gson での Big JSON の出力

Google Gson の場合、大きなサイズの JSON を出力、gson の toJson では一度作成元 Object を持ってしまうので、 大きなサイズの JSON は toJsonでは不向きである。 大きなサイズのJSON を出力をする場合、JsonWriter を使う。例) OutputStream out = // TO…

double の値が、整数か小数点有りか調べる

Java で案外、これを問われると簡単なようですぐに出てこない。 結果、boolean 値とする。 文字列にして小数点(.)文字を検証する方法 double d = 13.02; boolean flg = Long.parseLong(String.valueOf(d).substring(String.valueOf(d).indexOf('.')+1))==0…

Big JSON を読み込みを汎用化

先日の「Big JSON を読み込む JsonReader の実践」より汎用化を考えました。。 以下、抜粋のコードです。 public void execute(JsonReader reader, Consumer<T> consumer){ boolean request = false; try{ while((reader.hasNext() || reader.peek().equals(Jso</t>…

Big JSON を読み込む JsonReader の実践

先日書いた「Big JSON を読み込む JsonReader」、 より実践的なサンプルを書いてみる。 JSON素材 { "category": "JsonReader テスト", "filename": "sample.json", "itemlist":[ { "name": "A", "flag": true, "time": "2020/06/05 22:14:25" }, { "name": "…

置換表、正規表現マッチ replace

前持って置換文字列の表を用意しておいて、正規表現で見つけて置換する処理を無駄なく 処理できるものがあったら良いだろうと考えました。 import java.util.Iterator; import java.util.Map; import java.util.Optional; import java.util.Spliterator; imp…

Big JSON を読み込む JsonReader

大きなJSON を Google gson で読込むとき、メモリ不足にならないように、fromJson ではなく JSONのトークンで読みだす JsonReader を実行するのだが、注意しなければならない点がある。以下のように、JsonReader の hasNext() 問い合わせだけでは、END_ARRAY…

yipuran-core から CSV処理機能を他に分岐する

長い間、CSV読み書きする処理を、yipuran-core ライブラリで抱えこんでいたが、 yipuran-core に様々な処理が増えてきた。 CSV書込み処理を強化したい。 という理由で、yipuran-core のバージョン 4.19 ( Ver 4.19 ) より、CSV読み書きの処理を、yip…

配列のマップのキー自動チェック登録

リストのケースに触発されて、配列の場合、、、 import java.io.Serializable; import java.lang.reflect.Array; import java.util.Map; import java.util.Optional; import java.util.function.Function; import java.util.function.UnaryOperator; /** * M…

Setコレクションのマップキーチェック add

リストMap の リストに要素を追加(3) - Oboe吹きプログラマの黙示録リストMap の リストに要素を追加(4) - Oboe吹きプログラマの黙示録を書いたので、Set の方も、、、Set の場合は、TreeSet や、HashSet を指定できた方が良いので、未指定→HashSet と…

リストMap の リストに要素を追加(4)

oboe2uran.hatenablog.comもっと短く書けるけど、メリットないか。。。 import java.io.Serializable; import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.Map; import java.util.Optional; import java.util.f…

Stream boolean を集計

Stream 処理して単に、boolean を集計したい時、 1つでも true が発生、または全てが true になるかを求める時など、 forEach で、AtomicBoolean をセットするのは直感的だが、賢くはない。map メソッドで、Boolean に変換して collect で集計するのがスマ…

リストMap の リストに要素を追加(3)

リストMap の リストに要素を追加する時、、 - Oboe吹きプログラマの黙示録リストMap の リストに要素を追加(2) - Oboe吹きプログラマの黙示録と書きましたが、、以下に落ち着きそうです。 import java.io.Serializable; import java.util.ArrayList; imp…

リストMap の リストに要素を追加(2)

昨日書いた、 oboe2uran.hatenablog.com の続きです。 昨日書いたもの。。。 public static <T> UnaryOperator<List<T>> listAddReturn(T t){ return l->{ l.add(t); return l; }; } Map<String, List<String>> map = new HashMap<>(); map.put("a", Optional.ofNullable(map.get("a")) .map(</string,></list<t></t>…

リストMap の リストに要素を追加する時、、

Map<String, List<String>> map; 結構、頻繁にこういう Key と、List のマップを用意して、Key の存在を確認して List を新しく生成して、put したり、マップから取得して add して 再びマップに put するのを記述するのは、いつもなんとかならないかと思ってました。そこで、以下</string,>…

カウンタ付きの Consumer

Stream ラムダ式の実行中のカウンタ - Oboe吹きプログラマの黙示録 の続き、、、 Throwable を捕捉できる Consumer 以下を継承するようにして、 yipuran-core/ThrowableConsumer.java at master · yipuran/yipuran-core · GitHub 3要素の Consumer 、トリプ…

Stream ラムダ式の実行中のカウンタ

Stream の forEach や、map 、filter 、様々なラムダ式実行の中で、カウンタが必要な時、 しかたなく、AtomicInteger や、グローバルスコープに置いたカウンタインクリメント参照を よく書いてました。 また、ネット検索してよく紹介されてる例は、実行処理…

List<Integer> → int[]

Object型からプリミティブ型でラッパーが必要になる宿命から、、 Integerリストから、int[] が欲しい時の為に、、、 public static int[] toIntArrays(Collection<Integer> values){ int[] iary = (int[])Array.newInstance(int.class, values.size()); int n = 0; fo</integer>…

配列のリストをソートする

先日の投稿、入れ子リスト、List<List<T>> をソートする - Oboe吹きプログラマの黙示録 と、 yipuran-core/NestedListComparator.java at master · yipuran/yipuran-core · GitHub に続いて配列のリストをソートする場合もついでなので書いてみる。。前回同様、配列</list<t>…

Repetition Permutation の生成数

要素の繰り返し有りの順列 Permutation が生成するリストは、Java では、長さ8以上ではメモリ不足になってしまう。 生成する順列を溜めなくても、7以上はかなり遅くなる。以下のとおり長さに対して結果の数はとても大きくなる。 data length List A,B,C 3 …

入れ子リスト、List<List<T>> をソートする

入れ子リストをソートしなければいけない要件は少ないとは思います。任意クラスが、Comparable を実装しているなら簡単ですがそうでなく、中の属性値でソートしなければならない時は 面倒です。例)Item は,属性 Integer price を Not NULL で持っており、こ…

Python で順列・組み合わせ

itertools を使います。順列(Permutation) # -*- coding: UTF-8 -*- import itertools for s in itertools.permutations(['A','B','C'], r=3): print(s) 重複ありの順列(Repetition Permutation) for s in itertools.product(['A','B','C'], repeat=3): pr…

総称型の配列を作るメソッド

配列数が動的な総称型の配列を作る必要がある時、、、n個の配列、全て null で初期化するなら、 @SuppressWarnings("unchecked") public static <T> T[] nullArrays(int n, Class<T> cls) { return (T[])Array.newInstance(cls, n); } ただし、int.class や、char</t></t>…

リストから、固定の長さで並びを保持したリストのリストを求める。

リストと連続させる数を指定して、List の List で結果を求める。 public static <T> List<List<T>> lengthSequencelist(List<T> list, int length){ int last = list.size() - length + 1; return Stream.concat( IntStream.range(0, last).boxed().map(i->list.subList(i</t></list<t></t>…

Java9 dropWhile と takeWhile を意識した Java8 で実行する方法

昨日、以下を書いたが、、 Java9 Stream の takeWhile を意識した Java8 での方法 - Oboe吹きプログラマの黙示録 dropWhile もと思い、、改めて、dropWhile の方法も。。。 public static <T> Stream<T> dropstream(Stream<T> stream, Predicate predicate) { Spliter</t></t></t>…