• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

472
Views
guardando emoji en mysql usando hibernate Valor de cadena incorrecto: '\xF0\x9F\x98\x88\xF0\x9F...' para la columna 'nombre' en la fila 1

mi cadena de conexión tiene las siguientes propiedades useUnicode=true&characterEncoding=utf8&character_set_server=utf8mb4&charset=utf8mb4

y usé

 jpaProperties.put("hibernate.connection.useUnicode", true); jpaProperties.put("hibernate.connection.characterEncoding", "utf8"); jpaProperties.put("hibernate.connection.CharSet", "utf8mb4");

la base de datos también es compatible con utf8mb4 ya que cuando agrego un registro manualmente, lo guarda correctamente

sigo recibiendo errores al intentar guardar un emoji

 Incorrect string value: '\xF0\x9F\x98\x88\xF0\x9F...' for column 'name' at row 1
about 3 years ago · Santiago Trujillo
2 answers
Answer question

0

Estoy bastante seguro de que expresó claramente su intención de usar UTF-8 contra toda su pila de tecnología... excepto sus datos.

Su problema real aquí es que sus datos (la cadena original) no son UTF-8 válidos para empezar. Puede verificar esto fácilmente con el siguiente fragmento:

 public static boolean isValidUTF8(byte[] input) { CharsetDecoder utf8Decoder = Charset.forName("UTF-8").newDecoder(); try { utf8Decoder.decode(ByteBuffer.wrap(input)); return true; } catch (CharacterCodingException e) { return false; } }

En su lugar, debe usar utf8mb4 hasta el final (incluida la definición de su columna, que debe ser ... CHARSET=utf8mb4 COLLATE utf8mb4_general_ci o ... CHARACTER SET utf8mb4 COLLATE utf8mb4_bin ).

Debe prestar especial atención a la versión (y configuración) de MySQL Connector de acuerdo con la documentación .

about 3 years ago · Santiago Trujillo Report

0

Lo resolví actualizando mysql-connector-java a 5.1.49 y agregando lo siguiente a la cadena de conexión

 {connection string}?characterEncoding=UTF-8&useUnicode=true

referencia: https://dev.mysql.com/doc/connector-j/5.1/en/connector-j-reference-charsets.html

about 3 years ago · Santiago Trujillo Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error