如果用"from XXX" ,没有问题
如果用“form XXX where id='1234'" 也没有问题
如果用“form XXX where id=?"  query.setObject(0,"1234") 就会抛出exception??

解决方案 »

  1.   

    存取MySQL 4.1乱码问题
    查看系统的字符集和排序方式的设定可以通过下面的两条命令:
    mysql> SHOW VARIABLES LIKE 'character_set_%';
    +--------------------------+----------------------------+
    | Variable_name | Value |
    +--------------------------+----------------------------+
    | character_set_client | latin1 |
    | character_set_connection | latin1 |
    | character_set_database | latin1 |
    | character_set_results | latin1 |
    | character_set_server | latin1 |
    | character_set_system | utf8 |
    | character_sets_dir | /usr/share/mysql/charsets/ |
    +--------------------------+----------------------------+
    7 rows in set (0.00 sec)mysql> SHOW VARIABLES LIKE 'collation_%';
    +----------------------+-------------------+
    | Variable_name | Value |
    +----------------------+-------------------+
    | collation_connection | latin1_swedish_ci |
    | collation_database | latin1_swedish_ci |
    | collation_server | latin1_swedish_ci |
    +----------------------+-------------------+
    3 rows in set (0.00 sec)
    上面列出的值就是系统的默认值。默认是latin1的瑞典语排序方式当我们按照原来的方式通过jsp存取MySQL数据库时,就算设置了表的默认字符集为utf8并且通过UTF-8编码发送查询,
    你会发现存入数据库的仍然是乱码。问题就出在这个connection连接层上。解决方法是在发送查询前执行一下下面这句:SET NAMES 'gbk';它相当于下面的三句指令:
    SET character_set_client = gbk;
    SET character_set_results = gbk;
    SET character_set_connection = gbk;
    数库连接JDBC使用
    jdbc:mysql://localhost:3306/jbbs
    或者
    jdbc:mysql://localhost:3306/jbbs?useUnicode=true&characterEncoding=GBK
      

  2.   

    就是连接的url的问题,照楼上说的设置就成。