У меня случай: перенести данные из базы данных доступа в SQL. Я столкнулся с проблемой создания множества новых первичных ключей в SQL.
Когда я переносил предыдущие таблицы, я использовал генератор случайных значений для генерации случайной строки. Новый ключ я сократил до 5 цифр.
введите здесь описание изображения
Но сейчас у меня много рядов 900 000 и насчитывается около 200 новых ключей.
Я не мог использовать Добавить последовательность, потому что первичный ключ имеет длину 5 цифр (char (5)).
Я думаю, что могу использовать java для создания ключа и найти этот скрипт, но я не понимаю, как это работает.
введите здесь описание изображения
введите здесь описание изображения
import java.security.SecureRandom;
import java.util.Locale;
import java.util.Objects;
import java.util.Random;
public class RandomString {
public String nextString() {
for (int idx = 0; idx < buf.length; ++idx)
buf[idx] = symbols[random.nextInt(symbols.length)];
return new String(buf);
}
public static final String upper = "ABCDEFGHIJKLMNOPQRSTUVWXYZ";
public static final String lower = upper.toLowerCase(Locale.ROOT);
public static final String digits = "0123456789";
public static final String alphanum = upper + lower + digits;
private final Random random;
private final char[] symbols;
private final char[] buf;
public RandomString(int length, Random random, String symbols) {
if (length < 1) throw new IllegalArgumentException();
if (symbols.length() < 2) throw new IllegalArgumentException();
this.random = Objects.requireNonNull(random);
this.symbols = symbols.toCharArray();
this.buf = new char[length];
}
введите здесь описание изображения
В моей базе данных нет последовательности для использования Добавить последовательность и Использовать БД для получения последовательности, но есть функция для генерации ключей. Как я могу использовать эту функцию? Или нет?
Это статистика потерянных данных. Могу ли я создать цикл для повторной генерации ключа в такой ситуации?