数据库表由编码latin1_swedish_ci插入到另一张UTF-8的编码的表中
来源:互联网 发布:台湾 led芯片 知乎 编辑:程序博客网 时间:2024/05/14 05:55
由于数据库编码的改变,所以数据的插入和查看都是乱码问题,所以需要转化一下编码。
一.转化编码
PHP给我们提供了一个转化函数iconv
iconv —字符串按要求的字符编码来转换
说明
$in_charset
, string$out_charset
, string$str
)将字符串str
从 in_charset
转换编码到out_charset
。
二.如果你的数据表数据比较多,需要设置PHP的运行时间,PHP默认的运行时间是30秒
改变PHP脚本运行时间的方法
1.在php.ini里面设置
max_execution_time=120;
2.通过PHP的ini_set函数设置
ini_set("max_execution_time","120");
3.通过set_time_limit函数设置
set_time_limit(120);
以上几个数字设置为0则无限制,默认一般是30秒.可以在脚本使用函数修改
.三.数据库插入的时候,如果是文章的话,文章里面有引号的话,需要用htmlspecialchars 函数,把里面的符号转化成HTML实体
htmlspecialchars —Convert special characters to HTML entities
取出数据库的时候需要把实体转化为正常字符,使用htmlspecialchars_decode 函数
htmlspecialchars_decode —将特殊的 HTML 实体转换回普通字符
我的代码如下
<?php
ini_set("max_execution_time",10000);
mysql_connect('localhost','root','123456') or die('数据库连接错误');
mysql_select_db('dream') or die('数据库选择错误');
mysql_query('set names latin1');
$sql="select * from zhuanti_dream";
$rs = mysql_query($sql);
while($row = mysql_fetch_assoc($rs)){
$id=$row['id'];
//数据库中表名为titile,比title多了一个i
$title=iconv('gbk','UTF-8',$row['titile']);
$info=iconv('gbk','UTF-8',$row['info']);
$info=htmlspecialchars($info, ENT_QUOTES);
$zuozhe=iconv('gbk','UTF-8',$row['zuozhe']);
$jianjie=$row['jianjie'];
if(is_string($jianjie)){
$jianjie=iconv('gbk','UTF-8',$row['jianjie']);
}
$time=$row['time'];
$dianji=$row['dianji'];
$tuijian=$row['tuijian'];
$fenlei=$row['fenlei'];
mysql_select_db('lxxn');
mysql_query('set names utf8');
$sql="insert into shuju (id,titile,info,zuozhe,time,dianji,tuijian,fenlei)
values
(null,'$title','$info','$zuozhe','$time','$dianji','$tuijian','$fenlei')";
$a=mysql_query($sql);
//下面为测试数据是否插入成功
if($a){
echo '1','<br />';
}else{
echo $row['id'],'<br />';
echo $sql;
echo '0','<br />';
}
}
?>
- 数据库表由编码latin1_swedish_ci插入到另一张UTF-8的编码的表中
- MySQL数据库中,将一张表的数据插入到另一张表的各种情况
- 如何用一条语句把一张表的数据插入到另一张数据库表中
- 如何用一条语句把一张表的数据插入到另一张数据库表中
- 由一张表的内容UPDATE到另一张表
- mysql插入一张表里的数据到另一张表
- 将UTF-8编码的数据表导入到GBK编码的表中
- 将查询数据插入到另一张已存在的表中
- mysql数据库把一张表插入到另一张表
- 复制mysql数据库的一张表到另一张表
- UTF编码与张的一个问题
- sql insert into 一次性插入多条数据 从一张表中查询到的数据插入到另一张表
- sql insert into 一次性插入多条数据 从一张表中查询到的数据插入到另一张表
- oracle中从4个表查询数据并插入到另一张表里 扩展到查询到的数据和其他数据共同插入
- 一个表的查询结果直接插入到另一张表
- oracle 将一张表的数据插入到另一张表
- 将一张表的查询结果插入到另一张表
- 将一张表的查询结果插入到另一张表
- LeetCode题解——Sudoku Solver
- libGDX执行DesktopLauncher提示Couldn't load file: badlogic.jpg
- 南大软院大神养成计划-css布局
- C-020.变量的修饰符 short、long、longlong、unsigned
- FreeRTOS系列第6篇---FreeRTOS内核配置说明
- 数据库表由编码latin1_swedish_ci插入到另一张UTF-8的编码的表中
- NEUQOJ 题目1496 田鼠看热闹(Ⅱ)(线段树,约瑟夫)
- HelloBlog
- android studio导入eclipse项目方式及相关问题解决办法
- 自定义ArcGIS矢量底图
- 代码原则
- (第十一周项目1)二叉树算法验证
- 《leetCode》:Subsets
- LeetCode 141 Linked List Cycle