php不能想数据库插入中文 。。你要保证你程序中指定的数据库编码和数据库本身的编码是一致的 ,
要存中文的话最好用utf-8编码 , 同时php的文件编码也用utf-8;
CREATE TABLE test (
`pid` int(11) NOT NULL AUTO_INCREMENT,
`version` varchar(50) NOT NULL,
`recorddate` datetime NOT NULL,
PRIMARY KEY (`pid`)
) ENGINE=InnoDBDEFAULT CHARSET=utf8 COLLATE utf8_general_ci;
建表的时候指定编码和字符集 , 一般就不会有问题了 。
用PHP向mysql数据库中写入中文汉字为什么显示不出来?我已经设置成gb2312了PHP与数据库的编码应一致
1. 修改mysql配置文件my.ini或my.cnf,mysql最好用utf8编码
[mysql]
default-character-set=utf8
[mysqld]
default-character-set=utf8
default-storage-engine=MyISAM
在[mysqld]下加入:
default-collation=utf8_bin
init_connect='SET NAMES utf8'
2. 在需要做数据库操作的php程序前加mysql_query("set names
'编码'");,编码和php编码一致,如果php编码是gb2312那mysql编码就是gb2312,如果是utf-8那mysql编码就是 utf8,这样插入或检索数据时就不会出现乱码了
php不能往mysql数据库添加汉字,只能添加字母和数字php mysql数据时我们必须保证提交到数据库的编码与mysql编码是一致的这样才可以保存中文不出现问号乱码问题,下面我先整理两个让mysql与页面保证编码一致的方法 。
解决中文插入数据库乱码的方法:
直接把中文转变成utf-8格式,大多是这个问题导致的 。
代码如下复制代码
$str
=
iconv('gbk','utf-8',$str);
如果还不行检查网页编码是否正确:
代码如下复制代码
?php
header("Content-Type:text/html;charset=utf-8");
?
建表:
代码如下复制代码
Create
TABLE
`net_city`
(
`cityid`
smallint(4)
NOT
NULL
auto_increment,
`cityname`
varchar(80)
NOT
NULL
default
'',
`provinceid`
smallint(2)
NOT
NULL
default
'0',
`inarea`
varchar(5000)
NOT
NULL
default
'',
`outarea`
varchar(5000)
NOT
NULL
default
'',
`tel`
varchar(400)
NOT
NULL
default
'',
PRIMARY
KEY
(`cityid`)
)
ENGINE=MyISAM
DEFAULT
CHARSET=utf8;
PHP里的代码:
$conn=mysql_connect("localhost",
"用户名",
"密码");
mysql_query("set
names
'utf8'",$conn);
mysql_select_db("
数据名",$conn);
$exec="insert
into
net_city
(cityname,inarea,outarea,tel)
values
('".$link_cityname."','".$link_inarea."','".$link_outarea."','".$link_tel."')";
$result=mysql_query($exec,$conn);
if($result){
echo
"1";
}else{
echo
"0";
}
mysql_close($conn);
后来我试了试全部都用成gbk的 , 也是可以的~
在查询数据时我们直接使用mysql_query()来设置
mysql_query("SET
NAMES
GBK");
//GBK处为编码设置
例子
下面是
"insert.php"
页面的代码:
代码如下复制代码
?php$con
=
mysql_connect("localhost","peter","abc123");
if
(!$con)
{
die('Could
not
connect:
'
.
mysql_error());
}
mysql_select_db("my_db",
$con);
mysql_query("SET
NAMES
GBK");
//GBK处为编码设置
$sql="INSERT
INTO
person
(FirstName,
LastName,
Age)VALUES('$_POST[firstname]','$_POST[lastname]','$_POST[age]')";
if
(!mysql_query($sql,$con))
{
die('Error:
'
.
mysql_error());
}
echo
"1
record
added";
mysql_close($con)
?
php将汉字写入数据库问题php数据库怎么存汉字你建立的表字段的编码是什么编码呢?mysql的编码分为两种php数据库怎么存汉字,一种是客户端编码 , 这个可以通过set names GBK(utf8);来改变php数据库怎么存汉字;这句话的意思是告诉mysql服务器,php数据库怎么存汉字你的客户端使用的是什么编码 。另一种是数据在库中存储时使用的编码,这个编码可以在安装mysql建立数据库 , 建立表的时候选择,以建表时的选择为最后标准,若果没选择,默认继承安装时的选择 。你说的插入成功却是空行的原因,可能是因为安装时选择的编码里面,对汉字的编码支持的太少 , 因此出现这样的情况,建议:show create table table_name;查看下建表语句中的字符集 。最好修改成utf8 。这样适应能力强一些php数据库怎么存汉字!
【php数据库怎么存汉字 php怎么把数据库的内容输出到html前端】关于php数据库怎么存汉字和php怎么把数据库的内容输出到html前端的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站 。
推荐阅读
- cpu硬拿下来会损坏什么,cpu拆下来还能用吗
- linux发送信息命令,linux 发送信息
- 普陀区直播卖货教程电话,普陀区小商品市场在哪
- php本地数据接口 php接口调用数据库
- html标签调用js方法吗,html标签调用js函数
- 体育游戏立德树人,体育游戏立德树人教学反思
- 怎么快速推广小程序给别人,怎么快速推广小程序给别人推广
- php.数据库优化 php数据库优化
- 什么应用直播软件,哪些软件直播