新聞中心
php 怎么連接中文名稱數(shù)據(jù)庫(SqlServer)?
php頁面是utf八的編碼,然后命令發(fā)給數(shù)據(jù)庫的時(shí)候轉(zhuǎn)換下編碼,例子見圖
成都創(chuàng)新互聯(lián)主營(yíng)五原網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,成都app軟件開發(fā)公司,五原h(huán)5小程序設(shè)計(jì)搭建,五原網(wǎng)站營(yíng)銷推廣歡迎五原等地區(qū)企業(yè)咨詢
用PHP向mysql數(shù)據(jù)庫中寫入中文漢字為什么顯示不出來?我已經(jīng)設(shè)置成gb2312了
PHP與數(shù)據(jù)庫的編碼應(yīng)一致
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. 在需要做數(shù)據(jù)庫操作的php程序前加mysql_query("set names
'編碼'");,編碼和php編碼一致,如果php編碼是gb2312那mysql編碼就是gb2312,如果是utf-8那mysql編碼就是 utf8,這樣插入或檢索數(shù)據(jù)時(shí)就不會(huì)出現(xiàn)亂碼了
php不能往mysql數(shù)據(jù)庫添加漢字,只能添加字母和數(shù)字
php+mysql數(shù)據(jù)時(shí)我們必須保證提交到數(shù)據(jù)庫的編碼與mysql編碼是一致的這樣才可以保存中文不出現(xiàn)問號(hào)亂碼問題,下面我先整理兩個(gè)讓mysql與頁面保證編碼一致的方法。
解決中文插入數(shù)據(jù)庫亂碼的方法:
直接把中文轉(zhuǎn)變成utf-8格式,大多是這個(gè)問題導(dǎo)致的。
代碼如下復(fù)制代碼
$str
=
iconv('gbk','utf-8',$str);
如果還不行檢查網(wǎng)頁編碼是否正確:
代碼如下復(fù)制代碼
?php
header("Content-Type:text/html;charset=utf-8");
?
建表:
代碼如下復(fù)制代碼
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("
數(shù)據(jù)名",$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的,也是可以的~
在查詢數(shù)據(jù)時(shí)我們直接使用mysql_query()來設(shè)置
mysql_query("SET
NAMES
GBK");
//GBK處為編碼設(shè)置
例子
下面是
"insert.php"
頁面的代碼:
代碼如下復(fù)制代碼
?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處為編碼設(shè)置
$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將漢字寫入數(shù)據(jù)庫問題
你建立的表字段的編碼是什么編碼呢?mysql的編碼分為兩種,一種是客戶端編碼,這個(gè)可以通過set names GBK(utf8);來改變;這句話的意思是告訴mysql服務(wù)器,你的客戶端使用的是什么編碼。另一種是數(shù)據(jù)在庫中存儲(chǔ)時(shí)使用的編碼,這個(gè)編碼可以在安裝mysql建立數(shù)據(jù)庫,建立表的時(shí)候選擇,以建表時(shí)的選擇為最后標(biāo)準(zhǔn),若果沒選擇,默認(rèn)繼承安裝時(shí)的選擇。你說的插入成功卻是空行的原因,可能是因?yàn)榘惭b時(shí)選擇的編碼里面,對(duì)漢字的編碼支持的太少,因此出現(xiàn)這樣的情況,建議:show create table table_name;查看下建表語句中的字符集。最好修改成utf8。這樣適應(yīng)能力強(qiáng)一些!
php不能想數(shù)據(jù)庫插入中文。。
你要保證你程序中指定的數(shù)據(jù)庫編碼和數(shù)據(jù)庫本身的編碼是一致的,
要存中文的話最好用utf-8編碼,同時(shí)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=InnoDB DEFAULT CHARSET=utf8 COLLATE utf8_general_ci;
建表的時(shí)候指定編碼和字符集,一般就不會(huì)有問題了。
當(dāng)前題目:php怎么添加數(shù)據(jù)庫中文,php寫入數(shù)據(jù)庫代碼
鏈接URL:http://www.dlmjj.cn/article/hedgci.html