php连接数据utf PHP连接数据库数据填写不完整( 二 )


mysql_query("SET
NAMES
`UTF-8`");
即可
当然,你得保证你的数据库的字符集是UTF-8
如果仍然出错,那就说明数据库的字符集配置有问题
php 连接ORALCE数据库 utf8 转 iso-8859-1的问题ISO-8859-1是单字节字符集,又称Latin-1,向下兼容ASCII,所以你可以尝试直接使用GBK编码写入数据库 。
其实数据库本身只是存储而已,你所说的乱码只是你的数据库查看工具所反映出来的现象 。如果你页面本身用的是UTF-8编码,存入数据库和读出应该都是正常的,而不必纠结数据库查询工具所看到的现象 。或者只能通过设置数据库编码、数据库查看工具编码、页面源代码编码三者一致才能最好地解决这个问题 。
PHP使用utf8插入中文数据到MySQL中文显示会乱码怎么办?数据库使用utf8编码php连接数据utf,需要在操作php连接数据utf的过程中统一全部编码 。
1.数据库默认编码
CREATE DATABASE `test` DEFAULT CHARACTER SET 'utf8';
2.表默认编码
CREATE TABLE `tablea`(
`id` INT NOT NULL AUTO_INCREMENT,
`title` VARCHAR(100) NULL,
)ENGINE=InnoDB DEFAULT CHARSET=utf8;
3.字段默认编码
默认情况下php连接数据utf,字段的编码同表的编码php连接数据utf,但是如果修改了表的编码php连接数据utf,字段编码不会同步修改,需要手动修改
这里修改编码测试我将utf8 改为 gb2312,仅用于观察修改后的情况(实际使用中可能是将gbk修改为utf8)
ALTER TABLE `test`.`tablea` CHARACTER SET = gb2312 ;
-- 修改表编码后 , 查看建表语句
show create table `tablea`;
-- 可以看到输出的建表语句中字段单独设置了编码
CREATE TABLE `tablea`(
`id` INT NOT NULL AUTO_INCREMENT,
`title` VARCHAR(100) CHARACTER SET utf8 NULL,
)ENGINE=InnoDB DEFAULT CHARSET=gb2312;
-- 需要手动修改字段编码
ALTER TABLE `tablea`
CHANGE COLUMN `title` `title` VARCHAR(100) CHARACTER SET 'gb2312' NULL DEFAULT NULL ;
4.当前数据库连接的编码
连接数时设置编码
// PDO 连接
$db = new PDO('mysql:host=myhost;dbname=test', 'login', 'password',
array(PDO::MYSQL_ATTR_INIT_COMMAND = 'SET NAMES \'UTF8\'')
);
// mysqli连接
$link = mysqli_connect("127.0.0.1", "my_user", "my_password", "test");
mysqli_query($link,"SET NAMES 'utf8';");
通过以上几步操作,基本可以保证数据库使用过程中不会出现乱码
【php连接数据utf PHP连接数据库数据填写不完整】php连接数据utf的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于PHP连接数据库数据填写不完整、php连接数据utf的信息别忘了在本站进行查找喔 。

推荐阅读