Anonymous | Login | Signup for a new account | 01-05-2025 09:15 PST |
Main | My View | View Issues | Change Log | Docs |
Viewing Issue Simple Details [ Jump to Notes ] | [ View Advanced ] [ Issue History ] [ Print ] | ||||||||
ID | Category | Severity | Reproducibility | Date Submitted | Last Update | ||||
0002606 | [Quercus] | major | always | 04-15-08 07:32 | 05-29-08 15:55 | ||||
Reporter | sgraf | View Status | public | ||||||
Assigned To | nam | ||||||||
Priority | normal | Resolution | fixed | ||||||
Status | closed | Product Version | 3.1.6 | ||||||
Summary | 0002606: ResultSet columns of type LONGVARCHAR do not hande unicode characters correctly | ||||||||
Description |
Problem found with latest SVN source build using Tomcat 6.0.16 and MySQL 5. JDBC's LONGVARCHAR are mysql's smalltext, mediumtext, text types. com.caucho.quercus.lib.db.JdbcResultResource.getColumnValue() doesn't handle LONGVARCHAR columns correctly. At the moment it will use a binary input string and StringBuilder.append(byte[],int, int) which doesn't parse multibyte characters correctly. A possible solution is to use rs.getCharacterStream() to obtain a multibyte compatible reader and use StringBuilder.append(Reader). A patch implementing that solution is attached. |
||||||||
Additional Information | While testing the beforementioned fix I have discovered an additioal issue in com.caucho.quercus.env.StringBuilderValue which I will report in a separate bug-report. | ||||||||
Attached Files | JdbcResultResource.java.diff [^] (1,320 bytes) 04-15-08 07:32 | ||||||||
|
Notes | |
(0002974) sgraf 04-15-08 07:44 |
Related StringBuilder Bug Report is here: 0002607 |
(0003013) nam 04-24-08 21:14 |
I don't think MySQL has the LONGVARCHAR type :). But good catch anyways because this would certainly affect other databases. PHP5 has byte strings, so interpretation of strings is up to the user application. So the current code is fine. However, there is a new unicode string type where we would want to read LONGVARCHAR as Java characters instead of bytes. Our Env.createUnicodeBuilder() detects when we are in PHP5 or PHP6 mode and returns the appropriate builder. So your patch is the correct thing to do for when we are in PHP6 mode. To do: make a test case for Postgres/Oracle |
(0003015) sgraf 04-25-08 11:04 edited on: 04-25-08 11:05 |
Yes I discovered this while using the unicode mode (or php6 mode as you call it). From what I have experienced and seen by debugging quercus in eclipse, MysQL JDBC Driver considers the mysql TEXT and LONGTEXT types as LONGVARCHAR. If you want to reproduce the bug I encountered, create mysql table containing a utf-8 encoded VARCHAR column and a utf-8 encoded TEXT colum. You will see that the text retrieved from the VARCHAR column is encoded correctly but the text comming from the TEXT column isn't. |
(0003115) ferg 05-29-08 15:55 |
php/1463 |
Mantis 1.0.0rc3[^]
Copyright © 2000 - 2005 Mantis Group
39 total queries executed. 31 unique queries executed. |