java连接mysql数据库乱码的解决方案

java连接mysql数据库乱码的解决方案,第1张

解决方法一:

mysql安装时候的编码

看下my ini 有无

[mysql]

default character set=utf

[client] default character set=utf

[mysqld] default character set=utf 创建表的时候设置

DROP   TABLE   IF   EXISTS   `Company`CREATE   TABLE   IF   NOT   EXISTS   `Company` (     `Cname`   VARCHAR( )   NOT   NULL     `Caddr`   VARCHAR( )     `Ctel`     VARCHAR( ) )ENGINE=InnoDB   DEFAULT   CHARSET=UTF jsp标头

<%@ page language="java" import="java util *" pageEncoding="UTF "%>不行的话就尝试

contentType="text/charset=gb " 解决方法二

连接mysql时(无论在从mysql读还是取数据的情况) 指定使用的编码方式为utf 具体代码如下

//装载mysql jdbc驱动

Class forName(" mysql jdbc Driver") newInstance()

//连接数据库

Connection sqlCon = DriverManager getConnection( "jdbc:mysql://localhost: /test?user=root&password= &useUnicode=true&characterEncoding=utf " )解决方法三

如果方法一不行那么在方法一的基础上对读入的字符串进行强制编码方式转换

String name = request getParameter("name")name= new String(name getBytes("ISO ") "utf ")或者

String name =new String( rst getString("name") getBytes("ISO ") "utf "))解决方法四

这个方法在有些文章里是首推的 我首先也是试了这个方法 但是好像不行 这里还是说一下 不知是不是 *** 作错误 还是先贴原文吧

"如果数据库中有中文的话而mysql默认的语言不是中文时要在配置文件C:winntmy ini 中的 [mysqld] 里添加一行

default character set=utf

然后重起mysql

方法五 在tomca或者web项目下的web xml里面更改

<filter>   <filter name>UTFEncoding</filter name>     <filter class>founder chenph Util EncodingFilter_UTF

lishixinzhi/Article/program/Java/JSP/201311/20273

在 DBeaver 中连接 Oracle 数据库显示乱码的解决方法可能有多种,下面列举几种常见的方法:

修改字符集: 修改 DBeaver 的字符集设置为与 Oracle 数据库的字符集相同,可以在 DBeaver 中的首选项 - 数据库 - Oracle 中设置。

修改环境变量: 编辑环境变量 NLS_LANG 设置为与 Oracle 数据库的字符集相同。

修改数据库连接字符集:在连接 Oracle 数据库时将字符集设置为与 Oracle 数据库的字符集相同。

修改客户端配置文件:修改客户端的配置文件,如 client/network/admin/sqlnet.ora 将字符集设置为与 Oracle 数据库的字符集相同。

修改SQL语句:在执行的SQL语句中加入 nls_lang 语句来解决乱码问题。

以前用php连mssqy时也经常出现中文乱码(中文变问号)的问题,那时就明白是编码没设置好导航,现在的Python连mssql数据库也同样出现这问题,问题一样,解决的办法当然也会相似,现在我们来看看解决方法。

python一直对中文支持的不好,最近老遇到编码问题,而且几乎没有通用的方案来解决这个问题,但是对常见的方法都试过之后,发现还是可以解决的,下面总结了常用的支持中文的编码问题(这些方法中可能其中一个就能解决问题,也可能是多个组合)。

(1)、首先,要保证文件的开头要加上编码设置来说明文件的编码

代码如下

复制代码

#encoding=utf-8

(2)、然后,在连接数据的连接参数里加上字符集说明查询出的结果的编码,这个不加的后果可能是查询出的汉字字符都是问号

代码如下

复制代码

conn=pymssql.connect(server='.',user='',

password='',database='MyTest',charset='utf8')

(3)、设置python系统的默认编码(对于文件来说,这招几乎屡试不爽,呵呵~~)

代码如下

复制代码

import

sys

reload(sys)

sys.setdefaultencoding('utf8')

注意:上述编码是“utf8”,而不是“utf-8”,我也没弄明白,大部分情况下,这个无所谓的,但是这里我试了必须要是“utf8”

一个简单的完整的python连接mssqlserver的例子如下(得安装pymssql包):

代码如下

复制代码

#encoding:utf8

import

sys

reload(sys)

sys.setdefaultencoding('utf8')

import

pymssql

try:

conn=pymssql.connect(server='.',user='',

password='',database='MyTest',charset='utf8')

sql="select

*

from

UserInfo"

cur=conn.cursor()

cur.execute(sql)

data=cur.fetchall()

conn.close()

print

data

except

Exception,e:

print

e

运行结果如下:

代码如下

复制代码

[(u'20093501',

u'xb9xf9xbexb8',

u'u7537

',

35,

u'xb4xf3xcfxc0'),

(u'20093502',

u'xbbxc6xc8xd8',

u'u5973

',

34,

u'xc3xc0xc5xae'),

(u'20093503',

u'xc1xeexbaxfcxb3xe5',

u'u7537

',

25,

u'2Bxc7xe0xc4xea'),

(u'20093504',

u'xc8xcexd3xafxd3xaf',

u'u5973

',

24,

u'xc6xafxc1xc1')]

[Finished

in

0.2s]

虽然摆脱了问号和乱码的困扰,但这仍不是我们想要的结果,但这个确实是正确的,因为结果是utf8编码。这个现象确实诡异,请教了许多高手,得知,最好的结果就是逐个字段查询,才能显示中文,整个查询的话,会以utf8的格式显示出来。

上述代码中第14行data是整个查询的结果,如果指定某个具体的字段,如print

data[0][2](表示取查询结果的第一行第三列的字段的值),则会输出中文。

其实不仅仅是mssqlserver数据库,mysql(需下载MySQLdb包)、sqllite(python自带的文件数据库)、mongodb(需下载PyMongo包)等或者是普通文本文件也是类似的解决方案。


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/sjk/9874178.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-02
下一篇2023-05-02

发表评论

登录后才能评论

评论列表(0条)

    保存