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编译器和调试器。一、前置条件本文默认前置条件是,您的开发设备已...
- 一周热门
- 最近发表
- 标签列表
-
- mybatiscollection (79)
- mqtt服务器 (88)
- keyerror (78)
- c#map (65)
- resize函数 (64)
- xftp6 (83)
- bt搜索 (75)
- c#var (76)
- mybatis大于等于 (64)
- xcode-select (66)
- httperror403.14-forbidden (63)
- logstashinput (65)
- hadoop端口 (65)
- dockernetworkconnect (63)
- esxi7 (63)
- vue阻止冒泡 (67)
- c#for循环 (63)
- oracle时间戳转换日期 (64)
- jquery跨域 (68)
- php写入文件 (73)
- java大写转小写 (63)
- kafkatools (66)
- mysql导出数据库 (66)
- jquery鼠标移入移出 (71)
- 取小数点后两位的函数 (73)