免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1947 | 回复: 7
打印 上一主题 下一主题

請問下面 MySQL Query 為何不能在JAVA程序里執行 [复制链接]

论坛徽章:
1
综合交流区版块每日发帖之星
日期:2016-02-13 06:20:00
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-07-19 18:04 |只看该作者 |倒序浏览
Connection C = DriverManager.getConnection(url, user, pwd);
Statement stmt  = C.createStatement();

stmt.execute(insert into tblMails (FirstName,LastName,Email,Country) values ('三 ','張','三.張@tom.com','China')  on duplicate key update  FirstName='三', LastName='張', Country='China';);


錯誤信息:
java.sql.SQLException: Syntax error or access violation,  message from server: "You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near ''China' at line 1"


而從MYSQL 命令行下運行
insert into tblMails (FirstName,LastName,Email,Country) values ('三 ','張','三.張@tom.com','China')  on duplicate key update  FirstName='三', LastName='張', Country='China';
沒有問題

請教大俠了

先謝

[ 本帖最后由 perryhg 于 2006-7-20 02:12 编辑 ]

论坛徽章:
0
2 [报告]
发表于 2006-07-20 02:13 |只看该作者
要用引号!
stmt.execute("insert into ..");

论坛徽章:
1
综合交流区版块每日发帖之星
日期:2016-02-13 06:20:00
3 [报告]
发表于 2006-07-20 03:57 |只看该作者
原帖由 perryhg 于 2006-7-20 02:13 发表
要用引号!
stmt.execute("insert into ..");


谢谢

有引号. 忘写了.
否则不能编译

论坛徽章:
0
4 [报告]
发表于 2006-07-21 04:12 |只看该作者
Connection C = DriverManager.getConnection(url, user, pwd);
问题可能在这个url上,connection里面应该指定连接数据库用的编码,
例如
url="jdbc:mysql://localhost:3306/roller?autoReconnect=true&useUnicode=true&characterEncoding=utf-8&mysqlEncoding=utf8"

论坛徽章:
1
综合交流区版块每日发帖之星
日期:2016-02-13 06:20:00
5 [报告]
发表于 2006-07-21 16:21 |只看该作者
謝謝樓上版主

將試試在URL中加useUnicode=true&characterEncoding=utf-8

论坛徽章:
1
综合交流区版块每日发帖之星
日期:2016-02-13 06:20:00
6 [报告]
发表于 2006-07-28 19:26 |只看该作者
錯誤:
"Illegal mix of collations"

(MySQL 4.1)

大俠幫忙

论坛徽章:
0
7 [报告]
发表于 2006-07-29 18:10 |只看该作者
你mysql指定的collation是什么?对应在连接中也要相同

论坛徽章:
0
8 [报告]
发表于 2006-07-30 00:04 |只看该作者
mysql的collation要和charset相匹配才能插入string,collation决定string索引和排序的顺序。
参考
http://www.v66.org/page/perry?en ... t%E8%AE%BE%E7%BD%AE

[ 本帖最后由 perryhg 于 2006-7-30 00:05 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP