
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查询结果中文乱码,怎么解决等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)