www.syrq.net > jAvA jDBC 插入数据时 数据中存在问号

jAvA jDBC 插入数据时 数据中存在问号

在对SQL进行预处理的时候,使用通配符“?”来代替字段的值,例如: sql = con.prepareStatement("delete * from chengjibiao where number=?") 在执行之前,需要调用sql方法设置通配符所代表的具体值: void setString(int index,String x) index...

那是因为在Connection conn = DriverManager.getConnection("jdbc:mysql://localhost:3306/immoc","root", "root");中没有设置编码格式,导致插入数据的时候才产生乱码。 可以将这句话修改为:Connection conn = DriverManager.getConnection("j...

你应该是安装mysql的时候编码你是选择默认的吧。 你可以找到mysql的安装目录MySQL Server 5.0\bin\MySQLInstanceConfig.exe 重新配置下就可以了。一般选择utf-8编码。 再一个如果数据库开始就建立好了。alter database 表名 character set utf8;...

你从数据库获得的信息是以UTF-8进行编码的,当传递到Myeclipse下,获得的数据是以GB2312 编码的,即Myeclipse会用GB2312对数据库中以UTF-8 编码的字符再次编码,得到的肯定是乱码。 解决方法,推荐的是使用String a = new String("数据库数据".g...

你这个问题具体的不好说是哪的编码不一致,但是数据库跟程序的编码不一致时肯定的知道问题的所在了,你就要去找,首先你要知道都哪里可以进行编码首先,在Myeclipse中至少有三个地方可以进行编码: 1:window->Preferences->General->WorkSpace将...

简单的一个例子:登陆. 从登陆框中传过来两个参数. 正常情况下、假设是 aa bb select * from tbl_user where uname='aa' and upass='bb' 然后有些会sql的人就想到了在参数后面加些其他的东西 比如在bb' or 'a'='a 或者 ;DELETE FROM tbl_user WHE...

这个要配合PreparedStatement来使用的 比如 PreparedStatement ps = conn.prepareStatement(sql); sql是你刚才那条语句 然后 ps.setString(1, xxx); 这个记数从一开始,对应每个问号, 而且还要保证数据类型正确。

?是占位符,代表数据参数。你看后面的 " ps.setInt(1,deptId); ps.setString(2,depname); ps.setString(3,address); "代码就给这三个 ? 赋值了!

每一次的转发,写一条打印语句,然后看看哪里出了问题,然后再对应解决。

这么放的话,sql相当于是: select "userid" from usertable.

网站地图

All rights reserved Powered by www.syrq.net

copyright ©right 2010-2021。
www.syrq.net内容来自网络,如有侵犯请联系客服。zhit325@qq.com