cmd命令连接oracle数据库连接到三个字为什么是乱码

cmd命令连接oracle数据库连接到三个字为什么是乱码,第1张

cmd命令窗口字符编码不一致或不兼容。

1、查一下服务器端的字符集。

2、把客户端的字符集设置为一致的。

3、你要用sqlplus的话,先通过设置环境变量来定义客户端的字符集。

SET character_set_client = utf8;

SET character_set_results = gb2312;

SET character_set_connection = utf8;

如果上边的不行,还可以改成Gbk。总以根据你的数据的文字编码改成相应的编码类型就ok了。给出Gbk的代码:

SET character_set_client = gbK;

SET character_set_results = gbK;

SET character_set_connection = utf8;

但是重启SQL之后又不行了。

远程连接oracle11g查询结果中文乱码是客户端和服务端编码设置不同引起的。

1、检查windows7下面cmd里面sqlplus中oracle

server端的字符集。

打开cmd,用sqlplus登录,输入下面SQL查询服务端的字符集。

2、去后台linux查看字符集编码,

(1),查看profile文件

[oracle@powerlong4

~]$

vim/home/oracle/bash_profile

export

LANG=en_USgbk

export

NLS_LANG=AMERICAN_AMERICAZHS16GBK

(2),查看数据库的userenv

SQL>

select

userenv('language')

fromdual;

USERENV('LANGUAGE')

----------------------------------------------------

AMERICAN_AMERICAZHS16GBK

改成ZHS16GBK就不会有中文乱码了。

MySQL会出现中文乱码的原因不外乎下列几点:

1server本身设定问题。

2table的语系设定问题(包含character与collation)

3客户端程式(例如php)的连线语系设定问题强烈建议使用utf8。utf8可以兼容世界上所有字符!

一、避免创建数据库及表出现中文乱码和查看编码方法

1、创建数据库的时候:CREATE DATABASE `test`

CHARACTER SET 'utf8'

COLLATE 'utf8_general_ci';

2、建表的时候 CREATE TABLE `database_user` (

`ID` varchar(40) NOT NULL default '',

`UserID` varchar(40) NOT NULL default '',

) ENGINE=InnoDB DEFAULT CHARSET=utf8;

这2个设置好了,基本就不会出问题了,即建库和建表时都使用相同的编码格式。

但是如果已经建了库和表可以通过以下方式进行查询。

1查看默认的编码格式:

mysql> show variables like "%char%";

+--------------------------+---------------+

| Variable_name | Value |

+--------------------------+---------------+

| character_set_client | gbk |

| character_set_connection | gbk |

| character_set_database | utf8 |

| character_set_filesystem | binary |

| character_set_results | gbk |

| character_set_server | utf8 |

| character_set_system | utf8 |

+--------------------------+-------------+

注:以前2个来确定,可以使用set names utf8,set names gbk设置默认的编码格式;

执行SET NAMES utf8的效果等同于同时设定如下:

SET character_set_client='utf8';

SET character_set_connection='utf8';

SET character_set_results='utf8';

2查看test数据库的编码格式:

mysql> show create database test;

+------------+------------------------------------------------------------------------------------------------+

| Database | Create Database |

+------------+------------------------------------------------------------------------------------------------+

| test | CREATE DATABASE `test` /!40100 DEFAULT CHARACTER SET gbk / |

+------------+------------------------------------------------------------------------------------------------+

3查看yjdb数据库的编码格式:

mysql> show create table yjdb;

| yjdb | CREATE TABLE `yjdb` (

`sn` int(5) NOT NULL AUTO_INCREMENT,

`type` varchar(10) NOT NULL,

`brc` varchar(6) NOT NULL,

`teller` int(6) NOT NULL,

`telname` varchar(10) NOT NULL,

`date` int(10) NOT NULL,

`count` int(6) NOT NULL,

`back` int(10) NOT NULL,

PRIMARY KEY (`sn`),

UNIQUE KEY `sn` (`sn`),

UNIQUE KEY `sn_2` (`sn`)

) ENGINE=MyISAM AUTO_INCREMENT=1826 DEFAULT CHARSET=gbk ROW_FORMAT=DYNAMIC |

二、避免导入数据有中文乱码的问题

1:将数据编码格式保存为utf-8

设置默认编码为utf8:

set names utf8;

设置数据库db_name默认为utf8:

ALTER DATABASE `db_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

设置表tb_name默认编码为utf8:

ALTER TABLE `tb_name` DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci;

导入:

LOAD DATA LOCAL INFILE 'C:\\utf8txt' INTO TABLE yjdb;

2:将数据编码格式保存为ansi(即GBK或GB2312)

设置默认编码为gbk:

set names gbk;

设置数据库db_name默认编码为gbk:

ALTER DATABASE `db_name` DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;

设置表tb_name默认编码为gbk:

ALTER TABLE `tb_name` DEFAULT CHARACTER SET gbk COLLATE gbk_chinese_ci;

导入:

LOAD DATA LOCAL INFILE 'C:\\gbktxt' INTO TABLE yjdb;

注:1UTF8不要导入gbk,gbk不要导入UTF8;

2dos下不支持UTF8的显示;

三、解决网页中乱码的问题

将网站编码设为 utf-8,这样可以兼容世界上所有字符。

如果网站已经运作了好久,已有很多旧数据,不能再更改简体中文的设定,那么建议将页面的编码设为 GBK, GBK与GB2312的区别就在于:GBK能比GB2312显示更多的字符,要显示简体码的繁体字,就只能用GBK。

1编辑/etc/mycnf ,在[mysql]段加入default_character_set=utf8;

2在编写Connection URL时,加上useUnicode=true&characterEncoding=utf-8参;

3在网页代码中加上一个"set names utf8"或者"set names gbk"的指令,告诉MySQL连线内容都要使用utf8或者gbk。

安装MySQL时字符集选的是GB2312,看你用的是asp

那你再连接数据库的时候加上这段代码就不会出现乱码!!读取MYSQL内容的时候也加这段代码!

代码:Option=3;Stmt=Set Names 'GBK'

例如:

<%

set adoDataConn = servercreateobject("adodbconnection")

adoDataConnOpen "DRIVER={MySQL ODBC 351 Driver};server=localhost;DATABASE=test;USER=root;PASSWORD=123;Option=3;Stmt=Set Names 'GBK'"

strQuery = "select from vvv order by id asc"

Set rs = adoDataConnExecute(strQuery)

If Not rsBOF Then

%>

^^^^^^^^^^^^^^^^

网络连接名出现乱码怎么办

智能手机已经普及到千家万户,伴随着智能手机的普及,Wi-Fi无线路由器成了每个家庭必不可少的标配。但很多时候,大家都在用的是英文的Wi-Fi信号无线网络名称,对某些对英文不是很懂的用户,显得不够亲近。市面上很多的路由器都支持中文个性的Wi-Fi无线网络名称,但有些朋友发现,设置了中文SSID之后,会出现无法扫描到Wi-Fi信号,或者出现乱码的情况。接下来就来看看Wi-Fi无线网络名称出现乱码是怎么回事吧。

工具/原料

TP-LINK无线路由器

JCG无线路由器

小米无线路由器

Windows 7计算机(安装了无线网卡)

中兴Nubia智能手机(安卓)

苹果iPhone 6智能手机

方法/步骤

1

我们这里以TP-LINK、JCG、小米的无线路由器为例,来实验验证对中文SSID的支持情况。对于如何设置无线路由器,本经验不会涉及,有兴趣的朋友可以参考笔者的其他经验。

首先进入TP-LINK无线路由器的设置页面,切换到“无线设置”-“基本设置”,设置Wi-Fi无线网络名称(SSID号)为“TP无线路由器”。

单击“保存”之后,需要重启无线路由器才会生效,根据提示重启路由器,时间大概需要30-60秒钟。

接下来再设置JCG无线路由器。进入JCG无线路由器设置页面,转到“无线设置”-“基本设置”,设置Wi-Fi“无线网络名称”为“JCG无线luyou”,之后单击“保存/应用”,设置就直接生效了,无需重启路由器,可以节省不少时间。

在来看看小米路由器,进入小米路由器设置页面,切换到“常用设置”-“Wi-Fi设置”,设置Wi-Fi无线网络“名称”为“小米699”,单击“保存设置”。小米路由器会检测“名称”是否有中文,如果有中文存在,会提示“少数设备可能不支持中文或特殊字符”,这个还是比较人性化的。

单击“保存设置”之后,小米路由器需要重启,重启的时间是30秒,比较不好的是,这个双频路由器支持两个SSID和访客无线,设置三个名称需要重启3次,很浪费时间的说。

全部设置完毕,接下来就看效果吧。首先使用Windows查看无线网络,可悲的是,Windows只能看到TP-LINK的“TP无线路由器”信号,其他两个显示的都是乱码。

这是为什么呢?这里需要普及一下关于字符编码的知识。

Windows很早就对中文有很好的支持,中文字符不像英文字符那么简单,因此中文字符一般都会使用指定的字符编码表示,比较常见的就是Unicode编码和UTF编码,典型的代表就是Windows使用的GB2312(针对简体中文)和Linux/安卓/iOS/Mac OS使用的UTF-8编码了。

有兴趣的朋友可以查阅更多的有关字符编码的资料,这里只做了简单的说明,以方便大家理解。

了解了字符编码,就不难理解为什么会出现中文SSID乱码了。如果路由器没有使用与 *** 作系统相匹配的字符编码,就会出现乱码的情况。

首先来看看TP-LINK采用的字符编码。进入路由器设置页面,然后在浏览器菜单选择“查看”-“编码”,就可以看到,TP-LINK使用的是GB2312编码,因此可以被Windows *** 作系统识别,但可以预见的是,不能被很多的移动设备(如手机、平板电脑)识别。

再来看看JCG无线路由器的情况,进入路由器设置页面,然后在浏览器菜单选择“查看”-“编码”,可以发现,JCG无线路由器采用的是UTF-8字符编码。

那么小米路由器呢?进入路由器设置页面,然后在浏览器菜单选择“查看”-“编码”,发现也是采用的是UTF-8字符编码。

通过以上查看可以发现,TP-LINK作为老牌路由器厂商,依然遵循的是PC为先的理念,对移动设备的个性中文SSID没有办法支持。而转变和反应较快的JCG和小米,更倾向于对移动终端(手机和平板电脑)的个性中文SSID的支持。

实际结果正如我们料想的那样,首先看看安卓手机的情况。

JCG和小米的无线网络名称都可以正常显示,而TP-LINK的显示为乱码。

接下来再来看看iPhone的情况,与安卓手机一样,iPhone同样可以正常显示JCG和小米路由器的无线网络名称,而无法正常显示甚至不能扫描到TP-LINK的无线网络名称。

从上述结果可以看出:如果希望使用中文的无线网络名称调戏隔壁家妹纸,可以考虑JCG或小米的路由器;如果使用计算机上网的时候较多,TP-LINK可能是更好的选择。

但是不必担心,他们都可以正常连接到Wi-Fi上网的,只是显示会有乱码的,如果不使用中文Wi-Fi名称,他们都没有任何问题。

END

优化与分享

1

本经验是根据实际 *** 作完成,因路由器设置不同,可能会有出入,设置时请以实际路由器的 *** 作手册为准。如果您有任何意见或建议,可以留言提出,我会尽力改正和完善经验,以帮助更多有需要的人。

2

如果本经验对您有些许帮助,移动手指,点赞支持一下啦,您的支持是书写经验的最大动力哦^^。

段都有编码设置 出现乱码肯定是你现在用的编码混乱造成的 解决办法: 第一步 先改数据库编码 先修改你的数据库,如果你页面用的是UTF-8编码那么你数据库内的编码也需要设置为UTF-8,每个字段都需要设置要保持内外一致,你可以用Navicat for MySQL

以上就是关于cmd命令连接oracle数据库连接到三个字为什么是乱码全部的内容,包括:cmd命令连接oracle数据库连接到三个字为什么是乱码、如何解决sqlyog连接的数据库乱码的问题、sql server2005远程连接oracle11g查询结果中文乱码,怎么解决等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

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

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

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

发表评论

登录后才能评论

评论列表(0条)

    保存