MySQL 数据库操作

数据库中有表 members(id、username、post_number、pass、email) 和表 posts(id、members_id、title、content、add_time)

1. 取出表 members 中发帖数量 (post_number) 前10位的名字

select username,post_number from members order by posts_number desc limit 10;

2. 名字为 join 的最新10个发帖的标题

select title from posts where id=(select id from members where username=”join”) order by add_time desc limit 10;

select username.title from members as m join posts as p on m.id=p.members_id where m.username=”join” order by p.add_time desc limit 10;

MySQL 数据库中的字段类型 varchar 和 char 的主要区别

MySQL 数据库中的字段类型 varchar 和 char 的主要区别是什么?哪种字段的查询效率高?

varchar 为存储变长字符串,存储单位为字节,不同的编码方式存储的字符长度不一样,并且会单独用一个字符来存储字符长度。

char 为存储定长字符串,存储单位为字符,最多不超过256个字符。

char 的查询效率高,因为 varchar 会单独存储长度,在查询时先查找长度,然后进行数据的提取,比 char 定长类型多了一个步骤,所以效率第一点。

什么是数据库索引,主键索引、唯一索引的区别,索引的缺点是什么

索引的意义

索引用来快速寻找那些具有特定值的记录。

主键索引和唯一索引的区别

1. 主键索引是一种唯一性索引,且必须指定为“PRIMARY KEY” ,每个表只能有一个主键。

2. 唯一索引索引列的值只能出现一次,即必须唯一。

索引的缺点

1. 创建索引和维护索引徐尧耗费时间,这种时间随着数据量的增加而增加。

2. 索引需要占用物理空间,除了数据表占用数据空间之外,每一个索引还要占用一定的物理空间,如果要建立聚簇索引,则需要的空间会更大。

3. 当对数据表中的数据进行增加、删除、修改的时候,索引也要进行动态的维护,这样就降低了数据的维护速度。

PHP 中函数 isset(), empty(), is_null() 的区别

NULL:

当你在你的脚本中写下这样一行代码

$myvariable; //此处你想定义一个变量,但未赋值。会有Notice: Undefined variable 
echo $myvariable + 3; //使用这个变量出现:Notice: Undefined variable: myvariable in

如果将其改写成:

$myvariable = NULL; 
echo $myvariable + 3; //这样就不会有问题了

所以得出在你的脚本在使用一个变量时最好赋一个默认值,如果你不想,就可以将NULL赋给变量,表示这个变量已经定义但没有值,属于NULL类型。

is_null():

bool is_null ( mixed $var ) (php.net官方文档的函数定义)
当参数满足下面三种情况时,is_null()将返回TRUE,其它的情况就是FALSE
1、它被赋值为NULL
2、它还没有赋值
3、它未定义,相当于unset(),将一个变量unset()后,不就是没有定义吗
让我们来看一些例子:

$myvar = NULL; 
var_dump(is_null($myvar)); // TRUE 
$myvar1; 
var_dump(is_null($myvar1)); // TRUE Notice: Undefined variable 
$num = 520; 
unset($num); 
var_dump(is_null($num)); //TRUE Notice: Undefined variable 
var_dump(is_null($some_undefined_var)); //TRUE Notice: Undefined variable 

$myvar = 0; is_null($myvar); // FALSE 
$myvar = FALSE; is_null($myvar); // FALSE 
$myvar = ''; is_null($myvar); // FALSE

isset():

bool isset ( mixed $var [, mixed $… ] ),参数是一个变量
检测参数已设定,并且不是NULL。如果没有设置变量,变量未赋值,或变量被设为NULL,isset()函数就返回NULL。
正好和is_null()函数相反,is_null()为TRUE的情况在isset()中就为FALSE。有意思!
如果传递多个参数,将取交集。即所有参数全部符合 isset() 时才返回 TRUE。
似乎让人感觉有点困惑,来看一些例子:

$myvar = NULL; isset($myvar); // FALSE 当一个变量被赋值为NULL时,就表示这个变量没有值 
$myvar = 0; isset($myvar); // TRUE 
$myvar = FALSE; isset($myvar); // TRUE 
$myvar = ''; isset($myvar); // TRUE 
isset($some_undefined_var); // FALSE Undefined variable

可以看出isset()着重检测一个 变量是否设置和这个变量是否有具体的值,当变量满足这两种情况时isset()返回TRUE

defined():

bool defined ( string $name )
检测是否设置常量

empty():

bool empty ( mixed $var )
判读变量是否为空。
请见上面的类型比较表empty()那一列你就明白哪些情况是空的情形了。还有其他一些函数的参照。
来看一些例子:

$myvar = NULL; empty($myvar); // TRUE 
$myvar = 0; empty($myvar); // TRUE 
$myvar = FALSE; empty($myvar); // TRUE 
$myvar = ''; empty($myvar); // TRUE 
empty($some_undefined_var); // TRUE

empty()为TRUE的情况,若变量不存在,或者变量存在且其值为””、0、”0″、NULL、FALSE、array()、var $var; 以及没有任何属性的对象,则返回 TURE。
一般如!empty()的判断,就是变量存在,且值不为””、0、”0″、NULL、FALSE、array()以及只是单纯定义一个变量$var。

PHP 数组查找函数 in_array()、array_search()、array_key_exists() 使用实例

in_array(value,array,type)

该函数的作用是在数组array中搜索指定的value值,type是可选参数,如果设置该参数为 true ,则检查搜索的数据与数组的值的类型是否相同,即恒等于。
<?php
$people = array("Peter", "Joe", "Glenn", "Cleveland");
if(in_array("Glenn", $people)) {
echo"Match found";
}else{
echo"Match not found";
}
?>

输出:

Match found

array_key_exists(key,array)

该函数是判断某个数组array中是否存在指定的 key,如果该 key 存在,则返回 true,否则返回 false。
<?php
$a = array("a"=>"Dog", "b"=>"Cat");
if(array_key_exists("a", $a)) {
echo"Key exists!";
}else{
echo"Key does not exist!";
}
?>

输出:

Key exists!

array_search(value,array,strict)

array_search() 函数与 in_array() 一样,在数组中查找一个键值。如果找到了该值,则返回匹配该元素所对应的键名。如果没找到,则返回 false。注意在 PHP 4.2.0 之前,函数在失败时返回 null 而不是 false。同样如果第三个参数 strict 被指定为 true,则只有在数据类型和值都一致时才返回相应元素的键名。
<?php
$a = array("a" => "Dog", "b" => "Cat", "c" => 5, "d" => "5");
echo array_search("Dog", $a);
echo array_search("5", $a);
?>

输出:

ac

经过实际性能对比,在数据量不大的时候,比如小于1000,查找用哪一种都行,都不会成为性能上的瓶颈。但当数据量比较大的时候,用 array_key_exists 比较合适。据测试 array_key_exist 要比 in_array 效率高十几甚至几十倍。

PHP 数组 array_push() 和 array_pop() 以及 array_shift() 函数

<?php  
/** 
 * array_push() 将一个或多个单元压入数组的末尾(入栈) 
 */  
$stack = array("Java", "Php", "C++");  
array_push($stack, "C#", "Ruby", array('jsp', 'Asp'));  
print_r($stack);  
echo "====================================="."<br>";  
    
/** 
 * array_pop() 将数组最后一个单元弹出(出栈) 
 */  
$stack = array("Java", "Php", "C++", "C#", "Ruby");  
array_pop($stack);  
print_r($stack);  
echo "====================================="."<br>";  
    
/** 
 * array_shift() 将数组开头的单元移出数组 array_unshift() 在数组开头插入一个或多个单元  
 */  
$stack = array("Java", "Php", "C++", "C#", "Ruby");  
array_shift($stack);  
print_r($stack);  
?>

运行结果如下: