PHP面试题

2017-04-21  本文已影响0人  煜明will

1、双引号和单引号区别

2、常用的超全局变量

$_GET,$POST,$REQUEST,$GLOBALS,$FILE,$SERVER,$SESSION,$COOKIE

3、HTTP中POST、GET、PUT、DELETE区别

4、echo、print_r、print、var_dump区别

5、HTTP状态码

状态码分类:

6、include和require区别

7、如何获取客户端IP

客户端IP:$_SERVER["REMOTE_ADDR"];getenv('REMOTE_ADDR')
ip2long进行转换
服务端ip:gethostbyname('www.baidu.com')

8、isset、empty、is_null的区别

变量存在返回true,否则返回false
变量定义不赋值返回FALSE
unset一个变量,返回FALSE
变量赋值为null,返回FALSE

"",0,"0",null,false都认为为空,返回true

没有任何属性的对象都认为是空

定义了,但是赋值为null或者没有赋值
unset一个变量

9、简述MySQL数据库中MySIAM和InnoDB的区别

MyISAM:每个MyISAM在磁盘上存储成单个文件,.frm文件存储表定义, .MYD文件存储表数据, .MYI文件存储索引文件
InnoDB:所有的表都存在同一个数据文件中,InnoDB表大小受限于操作系统文件的大小,一般为2GB。

MyISAM:可被压缩,存储空间较小。支持三种不同的存储格式:静态表、动态表、压缩表。
InnoDB:需要更多地内存和存储,他会在内存中建立起专用的缓冲池用于高速缓冲数据和索引

MyISAM:数据是以文件的形式存储,所以在跨平台的数据转移中会很方便。在备份和恢复时可单独针对某个表进行操作。
InnoDB:拷贝数据文件、备份binlog、MySQLdump

MyISAM:不支持

InnoDB:支持

MyISAM:支持
InnoDB:不支持

MyISAM:不支持
InnoDB:支持

MyISAM:保存表的总行数,如果select count() from table;会直接取出该值。
InnoDB:没有保存表的总行数,如果select count(
) from table;会遍历整个表,消耗大。如果添加where条件,myisam和innodb处理的方式都一样。

MyISAM:可以和其他字段一起建立联合索引。
InnoDB:必须包含只有该字段的索引。

MyISAM:支持表级锁
InnoDB:支持行锁,但是只在where的是主键时有效

上一篇 下一篇

猜你喜欢

热点阅读