você pode resolver isso com conversão de base. igual a gente faz de base binaria x decimal x hexadecimal, você pode trabalhar com um "número" de 36 algarismos (os numeros em sí e as letras do alfabeto).

no banco de dados, você continua utilizando os identificador decimal, até porque isso melhorar a indexação.

mas o que você apresenta para o usuario é a conversão desse número.

exemplo: de 0 a 9, você vai ter 0 a 9 mesmo. a partir daí que verá a diferença..

o 10 equivale a "a", o 11, "b" e assim por diante.

mas como no seu caso precisará de 6 digitos sempre, pode incluir na conversão uma adição para que id 1 seja equivalente a 100000. (e quando converter do uid para decimal, não esqueça de subtrair).

assim, não tem risco de duplicar e elimina a necessidade de verificar a disponibilidade no banco de dados.