百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

PHP面试题—第五回 php面试常见问题

bigegpt 2024-10-03 14:51 6 浏览

1.用PHP打印出前一天的时间,格式是2012-5-10 22:21:21?

<?php

echo date("Y-m-d H:i:s",strtotime("-1 day"));

?>

2、MySQL取得当前时间的函数,格式化日期的函数?

取得当前时间用 now()

数据库中格式化时间 用DATE_FORMA T(date, format)

3、如何修改session的生存时间?

$lifetime = 3600; //一个小时

session_set_cookie_params($lifetime);

session_start();

4.用PHP写出显示客户端与服务器端IP的代码?

echo '服务器IP:',$_SERVER['SERVER_ADDR'];

echo '客户端IP:',$_SERVER['REMOTE_ADDR'];

5.创建新闻发布系统

Message表(文章表)

文章 id 文章标题 文章内容 文章分类 点击量

id title content category_id hits

comment表(记录用户对文章回复内容)

回复id 文章id,关联message表中的id 回复内容

comment_id id comment_content

1、现通过查询数据库需要得到一下格式的文章标题列表,并按照回复数量排序,回复最高的排在最前面 文章id 文章标题 点击量 回复数量

用一个SQL语句完成上述查询,如果文章没有回复则回复数量显示为0。

create database xinwen character set utf8;

use xinwen;

#文章表

create table message(

id int auto_increment primary key,

title varchar(20),

content varchar(100),

category_id int,

hits varchar(20)

);

insert into message values(' ',' 标题1','内容1',1,1);

insert into message values(' ',' 标题2','内容2',1,2);

insert into message values(' ',' 标题3','内容3',1,3);

insert into message values(' ',' 标题4','内容4',1,4);

insert into message values(' ',' 标题5','内容5',1,5);

insert into message values(' ',' 标题6','内容6',1,6);

insert into message values(' ',' 标题7','内容7',1,7);

insert into message values(' ',' 标题8','内容8',1,8);

insert into message values(' ',' 标题9','内容9',1,9);

insert into message values(' ',' 标题10','内容10',1,10);

insert into message values(' ',' 标题11','内容11',1,11);

insert into message values(' ',' 标题12','内容12',1 ,12);

insert into message values(' ',' 标题13','内容13',1,13);

#回复表

create table comment (

comment_id int auto_increment primary key,

id int references message(id),

comment_content varchar(100)

);

insert into comment values(' ',1,' 回复内容1');

insert into comment values(' ',2,' 回复内容2');

insert into comment values(' ',3,' 回复内容3');

insert into comment values(' ',4,' 回复内容4');

insert into comment values(' ',5,' 回复内容5');

insert into comment values(' ',6,' 回复内容6');

insert into comment values(' ',7,' 回复内容7');

insert into comment values(' ',8,' 回复内容8');

insert into comment values(' ',1,' 回复内容9');

insert into comment values(' ',1,' 回复内容10');

insert into comment values(' ',1,' 回复内容11');

insert into comment values(' ',1,' 回复内容12');

insert into comment values(' ',1,' 回复内容13');

insert into comment values(' ',1,' 回复内容14');

insert into comment values(' ',5,' 回复内容9');

insert into comment values(' ',5,' 回复内容10');

insert into comment values(' ',5,' 回复内容11');

insert into comment values(' ',13,' 回复内容12');

insert into comment values(' ',13,' 回复内容13');

insert into comment values(' ',13,' 回复内容14');

现通过查询数据库需要得到一下格式的文章标题列表,

并按照回复数量排序,回复最高的排在最前面

文章id 文章标题 点击量 回复数量

用一个SQL语句完成上述查询,如果文章没有回复则回复数量显示为0。

select a.id 文章id,

a.title 文章标题,

a.hits 点击量,

count(b.id) 回复数量

from

message a left join comment b on a.id = b.id

group by a.id

order by count(b.id) desc;

+----------+--------------+-----------+--------------+

| 文章id | 文章标题 | 点击量 | 回复数量 |

+----------+--------------+-----------+--------------+

| 1 | 标题1 | 1 | 7 |

| 5 | 标题5 | 5 | 4 |

| 13 | 标题13 | 13 | 3 |

| 6 | 标题6 | 6 | 1 |

| 8 | 标题8 | 8 | 1 |

| 3 | 标题3 | 3 | 1 |

| 7 | 标题7 | 7 | 1 |

| 2 | 标题2 | 2 | 1 |

| 4 | 标题4 | 4 | 1 |

| 9 | 标题9 | 9 | 0 |

| 11 | 标题11 | 11 | 0 |

| 10 | 标题10 | 10 | 0 |

| 12 | 标题12 | 12 | 0 |

+----------+--------------+-----------+--------------+

6、一个100W数据(MYSQL)的网站,目前访问速度慢,如果让你优化,你会从哪些方面进行考虑,谈谈你的思路?

1、select *把星号改成需要的字段,经测试,如果字段越多或字段的内容越多,那么查询速度是翻倍增长的。

或者可以把其他的字段单独放到1张表中,不要放在一起,导致单个表内容非常大,导致查询慢。

2、根据需求分析,正常用户只会看前几个页面内容,最多100页就很不错了,所以 100页*100条=1W条。也就是说用户只需要1W条信息。

可以优化limit值,limit 10000,10速度是很快的。

7、实现多重筛选条件(如图),谈谈你的设计思路,URL要求形如a1/b3/c4/d1

多条件使用hidden域来储存,ajax异步提交到后端地址,然后由后端返回筛选后的json数据给前端

8、php中过滤HTML的函数是什么?经常用在哪些地方?

Strip_tags()

strip_tags() 函数剥去字符串中的 HTML、XML 以及 PHP 的标签。

9、已知任意一个合法的日期,如何算出那一天所在的星期的周一是几月几号?

<meta charset="utf-8">

<?php

date_default_timezone_set('PRC');

function zhuanhuan($strtime){

$time=strtotime($strtime);

$xingqi=date('w',$time);

switch($xingqi){

case 0:

echo date("Y-m-d",$time-3600*24*6);

break;

case 1:

echo date("Y-m-d",$time);

break;

case 2:

echo date("Y-m-d",$time-3600*24);

break;

case 3:

echo date("Y-m-d",$time-3600*24*2);

break;

case 4:

echo date("Y-m-d",$time-3600*24*3);

break;

case 5:

echo date("Y-m-d",$time-3600*24*4);

break;

case 6:

echo date("Y-m-d",$time-3600*24*5);

break;

case 6:

echo date("Y-m-d",$time-3600*24*6);

break;

default:

echo "呵呵";

}

}

zhuanhuan("2017-01-06");

//代码输出结果:2017-01-02

相关推荐

得物可观测平台架构升级:基于GreptimeDB的全新监控体系实践

一、摘要在前端可观测分析场景中,需要实时观测并处理多地、多环境的运行情况,以保障Web应用和移动端的可用性与性能。传统方案往往依赖代理Agent→消息队列→流计算引擎→OLAP存储...

warm-flow新春版:网关直连和流程图重构

本期主要解决了网关直连和流程图重构,可以自此之后可支持各种复杂的网关混合、多网关直连使用。-新增Ruoyi-Vue-Plus优秀开源集成案例更新日志[feat]导入、导出和保存等新增json格式支持...

扣子空间体验报告

在数字化时代,智能工具的应用正不断拓展到我们工作和生活的各个角落。从任务规划到项目执行,再到任务管理,作者深入探讨了这款工具在不同场景下的表现和潜力。通过具体的应用实例,文章展示了扣子空间如何帮助用户...

spider-flow:开源的可视化方式定义爬虫方案

spider-flow简介spider-flow是一个爬虫平台,以可视化推拽方式定义爬取流程,无需代码即可实现一个爬虫服务。spider-flow特性支持css选择器、正则提取支持JSON/XML格式...

solon-flow 你好世界!

solon-flow是一个基础级的流处理引擎(可用于业务规则、决策处理、计算编排、流程审批等......)。提供有“开放式”驱动定制支持,像jdbc有mysql或pgsql等驱动,可...

新一代开源爬虫平台:SpiderFlow

SpiderFlow:新一代爬虫平台,以图形化方式定义爬虫流程,不写代码即可完成爬虫。-精选真开源,释放新价值。概览Spider-Flow是一个开源的、面向所有用户的Web端爬虫构建平台,它使用Ja...

通过 SQL 训练机器学习模型的引擎

关注薪资待遇的同学应该知道,机器学习相关的岗位工资普遍偏高啊。同时随着各种通用机器学习框架的出现,机器学习的门槛也在逐渐降低,训练一个简单的机器学习模型变得不那么难。但是不得不承认对于一些数据相关的工...

鼠须管输入法rime for Mac

鼠须管输入法forMac是一款十分新颖的跨平台输入法软件,全名是中州韵输入法引擎,鼠须管输入法mac版不仅仅是一个输入法,而是一个输入法算法框架。Rime的基础架构十分精良,一套算法支持了拼音、...

Go语言 1.20 版本正式发布:新版详细介绍

Go1.20简介最新的Go版本1.20在Go1.19发布六个月后发布。它的大部分更改都在工具链、运行时和库的实现中。一如既往,该版本保持了Go1的兼容性承诺。我们期望几乎所...

iOS 10平台SpriteKit新特性之Tile Maps(上)

简介苹果公司在WWDC2016大会上向人们展示了一大批新的好东西。其中之一就是SpriteKitTileEditor。这款工具易于上手,而且看起来速度特别快。在本教程中,你将了解关于TileE...

程序员简历例句—范例Java、Python、C++模板

个人简介通用简介:有良好的代码风格,通过添加注释提高代码可读性,注重代码质量,研读过XXX,XXX等多个开源项目源码从而学习增强代码的健壮性与扩展性。具备良好的代码编程习惯及文档编写能力,参与多个高...

Telerik UI for iOS Q3 2015正式发布

近日,TelerikUIforiOS正式发布了Q32015。新版本新增对XCode7、Swift2.0和iOS9的支持,同时还新增了对数轴、不连续的日期时间轴等;改进TKDataPoin...

ios使用ijkplayer+nginx进行视频直播

上两节,我们讲到使用nginx和ngixn的rtmp模块搭建直播的服务器,接着我们讲解了在Android使用ijkplayer来作为我们的视频直播播放器,整个过程中,需要注意的就是ijlplayer编...

IOS技术分享|iOS快速生成开发文档(一)

前言对于开发人员而言,文档的作用不言而喻。文档不仅可以提高软件开发效率,还能便于以后的软件开发、使用和维护。本文主要讲述Objective-C快速生成开发文档工具appledoc。简介apple...

macOS下配置VS Code C++开发环境

本文介绍在苹果macOS操作系统下,配置VisualStudioCode的C/C++开发环境的过程,本环境使用Clang/LLVM编译器和调试器。一、前置条件本文默认前置条件是,您的开发设备已...