Java unable to read chinese characters from Db2 Database









up vote
0
down vote

favorite












I am trying to read from Java application Chinese characters from Db2 database



Db2 database configuration



DB2 database XDSN3T configuration:



DB2 database XDSN3T configuration



with DB2 CLP data are displayed correctly



enter image description here



also from another delphi application chinese data are correct



enter image description here
To obtain this I set:



  • Regional and language options, Advanced, non unicode programs --> Chinese RPC

non unicode programs:



non unicode programs
- enviroment variables, DB2CODEPAGE = 1252



db2codepage:
enter image description here



Only Java is not able to display data correctly --> ÃæÁÏ¡¢¸¨ÁÏ¡¢¸½¼þ



enter image description here



Maybe something related to JDBC..










share|improve this question























  • Please add the code to fetch the data from the DB
    – JFPicard
    Nov 8 at 16:17










  • Nota nota = new Nota();
    – Bruno It
    Nov 9 at 10:45










  • nota.Nota = rs.getString("QUANNOTA");
    – Bruno It
    Nov 9 at 10:45










  • It's not a Java problem. Seems that the font your tool uses can't render these characters.
    – Mark Barinstein
    Nov 9 at 15:26














up vote
0
down vote

favorite












I am trying to read from Java application Chinese characters from Db2 database



Db2 database configuration



DB2 database XDSN3T configuration:



DB2 database XDSN3T configuration



with DB2 CLP data are displayed correctly



enter image description here



also from another delphi application chinese data are correct



enter image description here
To obtain this I set:



  • Regional and language options, Advanced, non unicode programs --> Chinese RPC

non unicode programs:



non unicode programs
- enviroment variables, DB2CODEPAGE = 1252



db2codepage:
enter image description here



Only Java is not able to display data correctly --> ÃæÁÏ¡¢¸¨ÁÏ¡¢¸½¼þ



enter image description here



Maybe something related to JDBC..










share|improve this question























  • Please add the code to fetch the data from the DB
    – JFPicard
    Nov 8 at 16:17










  • Nota nota = new Nota();
    – Bruno It
    Nov 9 at 10:45










  • nota.Nota = rs.getString("QUANNOTA");
    – Bruno It
    Nov 9 at 10:45










  • It's not a Java problem. Seems that the font your tool uses can't render these characters.
    – Mark Barinstein
    Nov 9 at 15:26












up vote
0
down vote

favorite









up vote
0
down vote

favorite











I am trying to read from Java application Chinese characters from Db2 database



Db2 database configuration



DB2 database XDSN3T configuration:



DB2 database XDSN3T configuration



with DB2 CLP data are displayed correctly



enter image description here



also from another delphi application chinese data are correct



enter image description here
To obtain this I set:



  • Regional and language options, Advanced, non unicode programs --> Chinese RPC

non unicode programs:



non unicode programs
- enviroment variables, DB2CODEPAGE = 1252



db2codepage:
enter image description here



Only Java is not able to display data correctly --> ÃæÁÏ¡¢¸¨ÁÏ¡¢¸½¼þ



enter image description here



Maybe something related to JDBC..










share|improve this question















I am trying to read from Java application Chinese characters from Db2 database



Db2 database configuration



DB2 database XDSN3T configuration:



DB2 database XDSN3T configuration



with DB2 CLP data are displayed correctly



enter image description here



also from another delphi application chinese data are correct



enter image description here
To obtain this I set:



  • Regional and language options, Advanced, non unicode programs --> Chinese RPC

non unicode programs:



non unicode programs
- enviroment variables, DB2CODEPAGE = 1252



db2codepage:
enter image description here



Only Java is not able to display data correctly --> ÃæÁÏ¡¢¸¨ÁÏ¡¢¸½¼þ



enter image description here



Maybe something related to JDBC..







java db2 character






share|improve this question















share|improve this question













share|improve this question




share|improve this question








edited Nov 8 at 23:18









Al Fahad

735620




735620










asked Nov 8 at 16:11









Bruno It

1




1











  • Please add the code to fetch the data from the DB
    – JFPicard
    Nov 8 at 16:17










  • Nota nota = new Nota();
    – Bruno It
    Nov 9 at 10:45










  • nota.Nota = rs.getString("QUANNOTA");
    – Bruno It
    Nov 9 at 10:45










  • It's not a Java problem. Seems that the font your tool uses can't render these characters.
    – Mark Barinstein
    Nov 9 at 15:26
















  • Please add the code to fetch the data from the DB
    – JFPicard
    Nov 8 at 16:17










  • Nota nota = new Nota();
    – Bruno It
    Nov 9 at 10:45










  • nota.Nota = rs.getString("QUANNOTA");
    – Bruno It
    Nov 9 at 10:45










  • It's not a Java problem. Seems that the font your tool uses can't render these characters.
    – Mark Barinstein
    Nov 9 at 15:26















Please add the code to fetch the data from the DB
– JFPicard
Nov 8 at 16:17




Please add the code to fetch the data from the DB
– JFPicard
Nov 8 at 16:17












Nota nota = new Nota();
– Bruno It
Nov 9 at 10:45




Nota nota = new Nota();
– Bruno It
Nov 9 at 10:45












nota.Nota = rs.getString("QUANNOTA");
– Bruno It
Nov 9 at 10:45




nota.Nota = rs.getString("QUANNOTA");
– Bruno It
Nov 9 at 10:45












It's not a Java problem. Seems that the font your tool uses can't render these characters.
– Mark Barinstein
Nov 9 at 15:26




It's not a Java problem. Seems that the font your tool uses can't render these characters.
– Mark Barinstein
Nov 9 at 15:26












2 Answers
2






active

oldest

votes

















up vote
0
down vote













When you open the connection you can define the encoding, not sure if it's available for chinese. but here is an example:



Connection con = DriverManager.getConnection("jdbc:mysql://examplehost:8888/dbname?useUnicode=yes&characterEncoding=UTF-8","user", "pass");






share|improve this answer




















  • unfortunately it doesn't worj with db2..
    – Bruno It
    Nov 8 at 17:26


















up vote
0
down vote













As it's been said the encoding might be an issue; characters in java are stored using UTF-16 encoding which has itself some issues regarding the encoding of Chinese (also some emoji) characters.



You can find the character list for UTF-16 here: https://www.fileformat.info/info/charset/UTF-16/list.htm



The issue with UTF-16 comes when characters cannot be encoded using a single 16-bit unit; these characters are encoded using two 16-bit units which is called a surrogate pair. see: https://docs.oracle.com/javase/6/docs/api/java/lang/Character.html#unicode



Sorry I cannot provide a complete answer, but I hope this will help






share|improve this answer




















    Your Answer






    StackExchange.ifUsing("editor", function ()
    StackExchange.using("externalEditor", function ()
    StackExchange.using("snippets", function ()
    StackExchange.snippets.init();
    );
    );
    , "code-snippets");

    StackExchange.ready(function()
    var channelOptions =
    tags: "".split(" "),
    id: "1"
    ;
    initTagRenderer("".split(" "), "".split(" "), channelOptions);

    StackExchange.using("externalEditor", function()
    // Have to fire editor after snippets, if snippets enabled
    if (StackExchange.settings.snippets.snippetsEnabled)
    StackExchange.using("snippets", function()
    createEditor();
    );

    else
    createEditor();

    );

    function createEditor()
    StackExchange.prepareEditor(
    heartbeatType: 'answer',
    convertImagesToLinks: true,
    noModals: true,
    showLowRepImageUploadWarning: true,
    reputationToPostImages: 10,
    bindNavPrevention: true,
    postfix: "",
    imageUploader:
    brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
    contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
    allowUrls: true
    ,
    onDemand: true,
    discardSelector: ".discard-answer"
    ,immediatelyShowMarkdownHelp:true
    );



    );













     

    draft saved


    draft discarded


















    StackExchange.ready(
    function ()
    StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53211736%2fjava-unable-to-read-chinese-characters-from-db2-database%23new-answer', 'question_page');

    );

    Post as a guest















    Required, but never shown

























    2 Answers
    2






    active

    oldest

    votes








    2 Answers
    2






    active

    oldest

    votes









    active

    oldest

    votes






    active

    oldest

    votes








    up vote
    0
    down vote













    When you open the connection you can define the encoding, not sure if it's available for chinese. but here is an example:



    Connection con = DriverManager.getConnection("jdbc:mysql://examplehost:8888/dbname?useUnicode=yes&characterEncoding=UTF-8","user", "pass");






    share|improve this answer




















    • unfortunately it doesn't worj with db2..
      – Bruno It
      Nov 8 at 17:26















    up vote
    0
    down vote













    When you open the connection you can define the encoding, not sure if it's available for chinese. but here is an example:



    Connection con = DriverManager.getConnection("jdbc:mysql://examplehost:8888/dbname?useUnicode=yes&characterEncoding=UTF-8","user", "pass");






    share|improve this answer




















    • unfortunately it doesn't worj with db2..
      – Bruno It
      Nov 8 at 17:26













    up vote
    0
    down vote










    up vote
    0
    down vote









    When you open the connection you can define the encoding, not sure if it's available for chinese. but here is an example:



    Connection con = DriverManager.getConnection("jdbc:mysql://examplehost:8888/dbname?useUnicode=yes&characterEncoding=UTF-8","user", "pass");






    share|improve this answer












    When you open the connection you can define the encoding, not sure if it's available for chinese. but here is an example:



    Connection con = DriverManager.getConnection("jdbc:mysql://examplehost:8888/dbname?useUnicode=yes&characterEncoding=UTF-8","user", "pass");







    share|improve this answer












    share|improve this answer



    share|improve this answer










    answered Nov 8 at 16:23









    Ângelo D

    196




    196











    • unfortunately it doesn't worj with db2..
      – Bruno It
      Nov 8 at 17:26

















    • unfortunately it doesn't worj with db2..
      – Bruno It
      Nov 8 at 17:26
















    unfortunately it doesn't worj with db2..
    – Bruno It
    Nov 8 at 17:26





    unfortunately it doesn't worj with db2..
    – Bruno It
    Nov 8 at 17:26













    up vote
    0
    down vote













    As it's been said the encoding might be an issue; characters in java are stored using UTF-16 encoding which has itself some issues regarding the encoding of Chinese (also some emoji) characters.



    You can find the character list for UTF-16 here: https://www.fileformat.info/info/charset/UTF-16/list.htm



    The issue with UTF-16 comes when characters cannot be encoded using a single 16-bit unit; these characters are encoded using two 16-bit units which is called a surrogate pair. see: https://docs.oracle.com/javase/6/docs/api/java/lang/Character.html#unicode



    Sorry I cannot provide a complete answer, but I hope this will help






    share|improve this answer
























      up vote
      0
      down vote













      As it's been said the encoding might be an issue; characters in java are stored using UTF-16 encoding which has itself some issues regarding the encoding of Chinese (also some emoji) characters.



      You can find the character list for UTF-16 here: https://www.fileformat.info/info/charset/UTF-16/list.htm



      The issue with UTF-16 comes when characters cannot be encoded using a single 16-bit unit; these characters are encoded using two 16-bit units which is called a surrogate pair. see: https://docs.oracle.com/javase/6/docs/api/java/lang/Character.html#unicode



      Sorry I cannot provide a complete answer, but I hope this will help






      share|improve this answer






















        up vote
        0
        down vote










        up vote
        0
        down vote









        As it's been said the encoding might be an issue; characters in java are stored using UTF-16 encoding which has itself some issues regarding the encoding of Chinese (also some emoji) characters.



        You can find the character list for UTF-16 here: https://www.fileformat.info/info/charset/UTF-16/list.htm



        The issue with UTF-16 comes when characters cannot be encoded using a single 16-bit unit; these characters are encoded using two 16-bit units which is called a surrogate pair. see: https://docs.oracle.com/javase/6/docs/api/java/lang/Character.html#unicode



        Sorry I cannot provide a complete answer, but I hope this will help






        share|improve this answer












        As it's been said the encoding might be an issue; characters in java are stored using UTF-16 encoding which has itself some issues regarding the encoding of Chinese (also some emoji) characters.



        You can find the character list for UTF-16 here: https://www.fileformat.info/info/charset/UTF-16/list.htm



        The issue with UTF-16 comes when characters cannot be encoded using a single 16-bit unit; these characters are encoded using two 16-bit units which is called a surrogate pair. see: https://docs.oracle.com/javase/6/docs/api/java/lang/Character.html#unicode



        Sorry I cannot provide a complete answer, but I hope this will help







        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 8 at 17:02









        UmshiniWami

        618




        618



























             

            draft saved


            draft discarded















































             


            draft saved


            draft discarded














            StackExchange.ready(
            function ()
            StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53211736%2fjava-unable-to-read-chinese-characters-from-db2-database%23new-answer', 'question_page');

            );

            Post as a guest















            Required, but never shown





















































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown

































            Required, but never shown














            Required, but never shown












            Required, but never shown







            Required, but never shown







            Popular posts from this blog

            𛂒𛀶,𛀽𛀑𛂀𛃧𛂓𛀙𛃆𛃑𛃷𛂟𛁡𛀢𛀟𛁤𛂽𛁕𛁪𛂟𛂯,𛁞𛂧𛀴𛁄𛁠𛁼𛂿𛀤 𛂘,𛁺𛂾𛃭𛃭𛃵𛀺,𛂣𛃍𛂖𛃶 𛀸𛃀𛂖𛁶𛁏𛁚 𛂢𛂞 𛁰𛂆𛀔,𛁸𛀽𛁓𛃋𛂇𛃧𛀧𛃣𛂐𛃇,𛂂𛃻𛃲𛁬𛃞𛀧𛃃𛀅 𛂭𛁠𛁡𛃇𛀷𛃓𛁥,𛁙𛁘𛁞𛃸𛁸𛃣𛁜,𛂛,𛃿,𛁯𛂘𛂌𛃛𛁱𛃌𛂈𛂇 𛁊𛃲,𛀕𛃴𛀜 𛀶𛂆𛀶𛃟𛂉𛀣,𛂐𛁞𛁾 𛁷𛂑𛁳𛂯𛀬𛃅,𛃶𛁼

            Edmonton

            Crossroads (UK TV series)