一、问题:
数据库是ms sqlserver2000,要把sqlserver2000里的一张表的数据导入mysql5,其中sqlserver2000表的字段以简体中文命名(强烈建议不要以中文做为字段名)。其实操作就是对sqlserver查询记录,插入到mysql里。选择的脚本语言是php,php打开mssql和mysql扩展,对这两个数据库操作都是很容易的问题。
问题就出现在sqlserver中表的字段名是中文,写好的查询语句在sqlserve里测试是通过有记录返回,用php的mssql扩展查询就是报错。
上网查了资料,网上相关的信息不太多,很多网友都认为是php的mssql扩展不支持sql语句中有中文。查了一下资料,php的mssql是支持sql中有中文的语句。出现报错问题大多是因为编码的问题,编码数据库和编码与查询语句编码不统一,查询语句到sqlserver里中文部分就成了乱码,造成查询失败。
二、解决方法:
知道了原因,接下来分析解决,确认是编码不统一的问题。解决分以下几步:
1、确认sqlserver 数据库的编码,我的数据编码是gbk。
2、确认当前php脚本文件的编码,我的编码是utf-8。
3、转换sql查询语句的的编码。
补充:有的网友提到要把php的脚本文件编码转成和数据库编码一致,其实这一步大可不必,只要确认你的sql语句和数据库的编码一致就可以,这里建议不必转换的原因是如果你的php脚本文件里包含其它php脚本,那也得对所有include或require的脚本文件编码转换,不然php脚本编码不统一很容易出错,若互相关联的文件很多,这也是一件很麻烦的问题而且把事情复杂化了。
三、方案:
写一个转换函数,在把sql操作前把sql语句编码转换。下面贴出我的范例代码:
复制代码 代码如下:
//编码转换函数
function utf8togb($s) {
return iconv('utf-8', 'gbk//ignore', $s); // ignore 参数是遇到不成转换的字符时忽略
}
//建议把所有中文字段用英文别名替换,方便下面操作还有编码转换等问题
$sql="select [id], [栏目] as typeid, [正题] as title, [作者] as author, convert(text, [正文]) as body from [文章表];";
$sql = utf8togb($sql);
0
0
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
本专题围绕漫蛙漫画(Manwa / Manwa2)官网网页版入口进行整理,涵盖漫蛙漫画官方主页访问方式、网页版在线阅读入口、台版正版漫画浏览说明及基础使用指引,帮助用户快速进入漫蛙漫画官网,稳定在线阅读正版漫画内容,避免误入非官方页面。
13
2026.02.03
本专题汇总了俄罗斯知名搜索引擎 Yandex 的官网入口、免登录访问地址、中文登录方法与网页版使用指南,帮助用户稳定访问 Yandex 官网,并提供一站式入口汇总。无论是登录入口还是在线搜索,用户都能快速获取最新稳定的访问链接与使用指南。
114
2026.02.03
本专题专注讲解 Java 中常用的设计模式,包括单例模式、工厂模式、观察者模式、策略模式等,并结合代码重构实践,帮助学习者掌握 如何运用设计模式优化代码结构,提高代码的可读性、可维护性和扩展性。通过具体示例,展示设计模式如何解决实际开发中的复杂问题。
3
2026.02.03
本专题系统讲解 C# 异步编程与并发控制,重点介绍 async 和 await 关键字、Task 类、线程池管理、并发数据结构、死锁与线程安全问题。通过多个实战项目,帮助学习者掌握 如何在 C# 中编写高效的异步代码,提升应用的并发性能与响应速度。
2
2026.02.03
本专题深入讲解 Python 在强化学习(Reinforcement Learning)中的应用,重点介绍 深度Q网络(DQN) 及其实现方法,涵盖 Q-learning 算法、深度学习与神经网络的结合、环境模拟与奖励机制设计、探索与利用的平衡等。通过构建一个简单的游戏AI,帮助学习者掌握 如何使用 Python 训练智能体在动态环境中作出决策。
3
2026.02.03
热门下载
相关下载
精品课程






