存档

作者存档

解决rtrim汉字产生乱码的问题

2018年6月25日 评论已被关闭

1、问题重现

echo rtrim('邯郸市','市');

输出: 邯�

2、原因

rtrim函数把参数都转成了UTF8后再进行比较。

对于中文,一般都是先转成Unicode,再根据下表转成UTF8。
UCS-4(UNICODE)编码    UTF-8字节流
U-00000000 – U-0000007F    0xxxxxxx
U-00000080 – U-000007FF    110xxxxx 10xxxxxx
U-00000800 – U-0000FFFF    1110xxxx 10xxxxxx 10xxxxxx
U-00010000 – U-001FFFFF    11110xxx 10xxxxxx 10xxxxxx 10xxxxxx
U-00200000 – U-03FFFFFF    111110xx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx
U-04000000 – U-7FFFFFFF    1111110x 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx 10xxxxxx

3、解决方法

var_dump(mb_substr('邯郸市',0,-1,'utf-8'));

分类: php 标签:

mysql下如何更改database下所有表的数据引擎--MyISAM 到InnoDB

2018年5月29日 评论已被关闭

1.查看当前数据引擎的命令:

  show engines;

2.

    USE `[DBNAME]`;

    SELECT GROUP_CONCAT(CONCAT( 'ALTER TABLE ' ,TABLE_NAME ,' ENGINE=InnoDB; ') SEPARATOR '' )

    FROM information_schema.TABLES AS t

    WHERE TABLE_SCHEMA = '[DBNAME]' AND TABLE_TYPE = 'BASE TABLE';

  将其中的红色部分替换为你所使用的数据库

   执行后其实生成的是查询命令,然后copy生产的命令,执行SQL 即可:

ALTER TABLE info_aaaa ENGINE=InnoDB; ALTER TABLE info_data_bbb ENGINE=InnoDB; ALTER TABLE info_data_ccc ENGINE=InnoDB; ALTER TABLE info_data_ddd ENGINE=InnoDB; ALTER TABLE info_data_eee ENGINE=InnoDB; ALTER TABLE info_data_fffENGINE=InnoDB;

 

再次查看数据表的数据引擎已经更改了:show table status from [DBNAME];

分类: mysql 标签:

Ubuntu 16.04系统下解决Vim乱码问题

2018年5月11日 评论已被关闭

方法:

打开终端输入:sudo vim /etc/vim/vimrc,进入编辑模式,加入如下配置:

set fileencodings=utf-8,gb2312,gbk,gb18030  
set termencoding=utf-8  
set encoding=prc  

保存–退出–重新进入,即可看到乱码已解决;

分类: linux 标签:


标签

ajax apache array array_slice CentOS checkbox composer cookie csv curl date DATE_FORMAT excel FCKEditor file_get_contents laravel Magento Certified Developer mb_substr memcache Memcached MySQL String Functions Netbeans openssl php面试题 preg_match_all preg_replace QQ登录 rewrite SaeStorage serialize session setTimeout Sphinx spl Storage strtotime ueditor vsftp vsftpd Zend zip 分割字符串 图片处理 新浪云 正则表达式

存档