1、双引号和单引号区别
- 双引号解释变量,单引号不解释变量。
- 双引号里插入单引号,其中单引号里如果有变量的话,变量解释
- 双引号的变量名后面必须要有一个非数字、字母、下划线的特殊字符,或者用{}讲变量括起来,否则会将变量名后面的部分当做一个整体,引起语法错误
- 双引号解释转义字符,单引号不解释转义字符,但是解释'\和\
- 能使单引号字符尽量使用单引号,单引号的效率比双引号要高(因为双引号要先遍历一遍,判断里面有没有变量,然后再进行操作,而单引号则不需要判断)
2、常用的超全局变量
$_GET,$POST,$REQUEST,$GLOBALS,$FILE,$SERVER,$SESSION,$COOKIE
3、HTTP中POST、GET、PUT、DELETE区别
4、echo、print_r、print、var_dump区别
- echo、print是PHP语句,var_dump是函数
- echo输出一个或多个字符串,中间以逗号隔开,没有返回值是语言结构而不是真正的函数,因此不能作为表达式的一部分使用。
- print只能打印简单的变量(int,string),有返回值,显示成功则返回true
- print_r可以打印复杂类型变量的值以列表形式显示,但输出布尔值和null结果没有意义,都是打印“\n”
- var_dump 判断一个变量的类型和长度,并输出变量的数值
5、HTTP状态码
状态码分类:
- 1** 信息,服务器收到的请求,需要请求者继续执行操作
- 2** 成功,操作被成功接收并处理
- 3** 重定向,需要进一步的操作以完成请求
- 4** 客户端错误,请求包含语法错误或者无法完成请求
- 5** 服务器错误,服务器在处理请求的过程中发生了错误
常见状态码: - 200 请求成功
- 301 资源(网页等)被永久转义到其他URL
- 404 请求的资源不存在
- 505 内部服务器错误
6、include和require区别
- require是无条件包含,也就是如果一个流程里加入require,无论条件成立与否都会先执行require,当文件不存在或者无法打开时,会提示错误,并且终止程序
- include有返回值,如果被包含的文件不存在,那么会提示一个错误,但是程序会继续执行下去
7、如何获取客户端IP
客户端IP:$_SERVER["REMOTE_ADDR"];getenv('REMOTE_ADDR')
ip2long进行转换
服务端ip:gethostbyname('www.baidu.com')
8、isset、empty、is_null的区别
- isset判断变量是否定义或者是否为空(不存在,不赋值,赋值为null)
变量存在返回true,否则返回false
变量定义不赋值返回FALSE
unset一个变量,返回FALSE
变量赋值为null,返回FALSE
- empty判断变量是否为空能转换为false的否为空,为空返回true,反之返回false
"",0,"0",null,false都认为为空,返回true
没有任何属性的对象都认为是空
- is_null 检测传入的值是否为null(不存在(true并且警告),没赋值,赋值null)
定义了,但是赋值为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处理的方式都一样。
- AUTO_INCREMENT
MyISAM:可以和其他字段一起建立联合索引。
InnoDB:必须包含只有该字段的索引。
- 表锁差异
MyISAM:支持表级锁
InnoDB:支持行锁,但是只在where的是主键时有效