MySQL和PHP页面同时正确中文&PHP date函数的用法

记录下项目遇到的问题和解决方法。

1. 显示中文

在PHP页面显示的时候,我们通常需要在开头加入下面的代码来让我们的页面能正确显示中文:

<pre name="code" class="html"><meta content = text/html; charset=UTF-8 http-equiv = Content-Type>

是的,让页面显示UTF-8, 这样我们在写诸如此类的php代码时

echo '哈哈哈';

就能正确的在页面上显示中文了。

但是这样会有一个问题,我们存储到数据库时,如果直接写入中文,会导致在数据库里面看起来是这样的:

这样虽然你从PHP页面上打印出来的内容是争取的,可是如果你直接查看数据库的话,就不懂是什么内容了。

同样的,如果你在数据库里面输入的是能看懂的GBK编码的中文,如果用页面打印就变成了这样

那到底改怎么办?我们想要找到一种方法,要同时满足:

1. 通过php代码 echo直接可以打印出来中文

2. 在数据库里面显示的是能看懂的中文

3. 读取数据库到页面显示时也是能看懂的中文

毫无疑问,要想满足第1条,那么我们在开头毫无疑问要加入:

<meta content = text/html; charset=UTF-8 http-equiv = Content-Type>

那如何将UTF-8编码的中文存储到数据库后我们可以看懂呢?这里就需要进行两次转换了,UTF-8和GBK之间的转换了。

在我们从页面的内容(UTF-8编码)存到数据库(GBK)时和从数据库(GBK)读出到页面(UTF-8)

我们只需要用到这个函数:

iconv()

想要了解关于这个函数更多的内容请点击:

PHP:iconv- Manual

所以,我们在输入到数据库时,进行下列的转换:

同理,如果是从数据库读出来到页面,我们就进行gbk到utf-8的转换。

2. PHP:date()函数

date函数是用来从时间戳换算成我们想要的日期格式然后打印出来,这里主要记录一下各个单词代表的含义:

参数如下:
a - "am" 或是 "pm"
A - "AM" 或是 "PM"
d - 几日,二位数字,若不足二位则前面补零; 如: "01" 至 "31"
D - 星期几,三个英文字母; 如: "Fri"
F - 月份,英文全名; 如: "January"
h - 12 小时制的小时; 如: "01" 至 "12"
H - 24 小时制的小时; 如: "00" 至 "23"
g - 12 小时制的小时,不足二位不补零; 如: "1" 至 12"
G - 24 小时制的小时,不足二位不补零; 如: "0" 至 "23"
i - 分钟; 如: "00" 至 "59"
j - 几日,二位数字,若不足二位不补零; 如: "1" 至 "31"
l - 星期几,英文全名; 如: "Friday"
m - 月份,二位数字,若不足二位则在前面补零; 如: "01" 至 "12"
n - 月份,二位数字,若不足二位则不补零; 如: "1" 至 "12"
M - 月份,三个英文字母; 如: "Jan"
s - 秒; 如: "00" 至 "59"
S - 字尾加英文序数,二个英文字母; 如: "th","nd"
t - 指定月份的天数; 如: "28" 至 "31"
U - 总秒数
w - 数字型的星期几,如: "0" (星期日) 至 "6" (星期六)
Y - 年,四位数字; 如: "1999"
y - 年,二位数字; 如: "99"
z - 一年中的第几天; 如: "0" 至 "365"
如果显示的时间与系统不一致,就要改PHP.ini配置文件。
系统默认是UTC时间
可以打开php.inc
设置   date.timezone = PRC

所以,如果我们想要输出例如  2015年05月27日 15:45格式的时间,我们就需要这样写:

echo date('Y年m月j日, H:i', $suggestions['suggestion_time']);

想要输出其他格式的,参照上面的各个参数就好了!

时间: 2024-08-14 10:15:01

MySQL和PHP页面同时正确中文&PHP date函数的用法的相关文章

(转)MySQL获取某个时间范围内的数据 TO_DAYS(date)函数与now()函数

有这样一个需求,我们需要获得某个时间段内所有数据记录,比如最近一个月内的新闻,然后再在这个数据集合中进行排序,看哪个新闻的点击率最高.现在问题是,如何获得那个时间段.MySQL已经有些函数可以帮助我们,先看看这些函数吧. TO_DAYS(date) 函数 给定一个日期date,返回一个天数(从年份0开始的天数). 比如下面的例子: 1 mysql> SELECT TO_DAYS('2009-08-07'); 2 +-----------------------+ 3 | TO_DAYS('200

mysql like 匹配查询出不正确中文的解决办法

本文讲述mysql使用like语句时,匹配查询出不正确中文的解决办法 mysql like 搜索的时候发现,用 select title from tb_name where title like '%a%' 的时候出来的结果除了包含a的名字外连包含中文“新”的名字也出现在搜索结果里面,这令我想弄清楚mysql的匹配模式和规则到底是怎么样的,另外在匹配的时候正则表达式也很常用! 出现这个问题的原因是:MySQL在查询字符串时是大小写不敏感的,在编绎MySQL时一般以ISO-8859字符集作为默认

jsp页面间传中文参数示例(页面传参数编码)

在url地址栏使用中文传参数可能会是乱码了,下面我们来看看正确的jsp中页面间传中文参数转码的方法. 转码代码: String tcontent = "测试":a.href="./showCont.jsp?tcontent="+encodeURI(encodeURI(tcontent)); 解码代码: java.net.URLDecoder.decode((String)request.getParameter("tcontent"), &quo

火狐 此页面不能正确地重定向

事情发生在访问谷歌的时候. 当在搜索框输入数据之后,提示是这样的: 此页面不能正确地重定向 Firefox 检测到该服务器正在将此地址的请求循环重定向. 此问题可能是因为禁用或拒绝 Cookie 导致. 在网上搜了很长一段时间都没有找到解决办法, 还因此放弃使用火狐好几个月.该用chrome.但是就是喜欢火狐没办法,用chrome的话,瓜机要一直叫个不停. 图片如下: 并且这个问题只出现在火狐当中, chrome访问很正常,好像chrome默认使用的是https. 网上到处都说允许第三方cook

grails2.3.x创建插件,gsp页面不能正确显示内容

grails2.3.x创建plugin时,默认的Config.groovy只有简单的log设置,这时候,页面添加数据之后,正确的逻辑是show新增的数据,但却变成404,需要在Config.groovy中增加以下代码: grails.mime.types = [ // the first one is the default format all:           '*/*', // 'all' maps to '*' or the first available format in wit

JS获取中文拼音首字母,并通过拼音首字母高速查找页面内的中文内容

实现效果: 图一: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdGVzdGNzX2Ru/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" /> 图二: 此例中输入的中文字符串"万万保重",有三个字是多音字.所以alert对话框中显示的是多种读音的组合. 怎样实现? 怎样实现通过拼音首字母高速查找页面内的中文内容呢? 过程原

JS获取中文拼音首字母,并通过拼音首字母快速查找页面内的中文内容

实现效果: 图一: 图二: 此例中输入的中文字符串"万万保重",有三个字是多音字,所以alert对话框中显示的是多种读音的组合: 如何实现? 如何实现通过拼音首字母快速查找页面内的中文内容呢? 过程原理是这样的:例如要对一些人名进行快速查找,当页面加载完成后,对所有人名建立一个索引,生成拼音首字母与姓名的对应关系:然后监听键盘事件,当用户按下键盘时,根据键值得到按下的是哪个字母,然后遍历索引中是否存在相同的拼音首字母: 这里还实现了根据字母组合来查找的功能,原理是这样的:当用户按键时,

5月9日 页面不显示中文

若页面不显示中文,可能原因: 1.由于适用的 Cufon字体包不支持中文造成的. 解决方法:下载cufon中文包,下载地址:http://i.cnblogs.com/Files.aspx 将相应的js解压到原先的js存放目录下,覆盖cufon-yui然后将代码引用的<script src="js/(文件名).font.js" type="text/javascript"></script>改为<script src="js/V

页面传参中文乱码解决方案

jsp页面传递参数到servlet,只要参数有中文就是乱码,大多数是??????乱码,尝试了网上比较普遍的好多种办法都不行,最后加了一句话解决掉,分享给大家. 1.打开tomcat安装目录 2.找到conf文件夹 3.打开里面的server.xml 4.找到 <Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443