php连接数据库都需要哪些方法_php连接数据库有什么方法
如果你要学习php,那么你首先要学习的肯定是php连接mysql数据库。下面由学习啦小编为大家整理的php连接数据库,希望大家喜欢!
php连接数据库方法
连接数据库:
使用面向对象的方法;
1.造一个mysqli对象,造连接对象
2.准备一条SQL语句
3.执行SQL语句,如果是查询语句。成功返回结果及对象
4.从结果集对象里找到数据;
查询属性代码:
query($sql);//判断返回是否有内容,执行成功if($reslut){//如果成功了,从结果集对象里找到数据; $attr = $reslut->fetch_all();//返回索引数组:$attr = $reslut->fetch_row()//返回关联数组:tch_assoc();//返回对象:$attr = $reslut->fetch_object();//返回既有索引又有关联:$arrt = $reslut->fetch_array(); var_dump($attr);?>
最后的返回值是一个集对象,为了方便清晰的看到结果 我们用到了fetch_all(),fetch_row(); fetch_object();
增删改语句:
增加一条信息:
//造连接对象$db = new MySQLi("localhost","root","12345678","heiheihei");//准备SQL语句$sql = "insert into cou values('3-111','嘿嘿','803')"; //执行SQL语句$r = $db ->query($sql);if($r)//如果$r是ture{ echo "执行成功";}else { echo "执行失败";}
改变一条信息:
query($sql);if($r){ echo "执行成功";}else { echo "执行失败";}?>
删除:
query($sql);if($r){ echo "执行成功";}else { echo "执行失败";}?>
PHP常用魔术方法
1,__constuct()构造函数
通常实例化完一个对象之后,都要对该对象的属性进行初始化!在实例化一个对象的时候,PHP系统会自动的调用一个名字叫作__construct()的方法,我们把这个方法叫作“构造方法”!
其中,构造方法可以没有参数!
stu_name = $name; $this->stu_age = $age; } }//实例化stu对象$stu = new Stu('孙悟空','500');
2.__destruct()析构方法
与构造方法是一对,构造方法是在一个对象“出生”的时候由系统自动调用的,而析构方法是在一个对象“消失”的时候由系统自动调用的!
析构方法的名字叫__destruct();注意里面不能有任何的参数!
注意:析构方法是在对象销毁之前调用的!
作用:
析构方法的作用一般是用来释放该对象所占用的额外的资源,而不是销毁该对象本身!
3,__clone()克隆
触发时机:是在克隆一个对象的时候,对新对象进行初始化的工作
//克隆方法在克隆对象的时候对新对象的初始化工作 public function __clone(){ $this->is_clone=true;}
思考:
克隆出来的对象还是不是Student类中的一个实例呢?
我们可以利用instanceof运算符来进行判断!
instanceof就是用来判断某个对象是否是某个类的一个实例!
需要两个操作数,前面是一个对象变量,后面是一个类名!返回一个布尔值!
var_dump($stu instanceof Stu);
//返回bool(true)
4.__autoload()自动加载类
当调用不存在的类的时候自动调用!
5.__tostring()
当将对象当成字符串使用的时候自动调用
6.__invoke()
当将对象当成函数使用的时候自动调用
7,__set()
当对无法访问的属性赋值时自动调用(比如:类外调用私有属性)
8.__get()
当对获取无法访问的属性值的时候自动调用
9.__unset()
当销毁无法访问的属性的时候自动调用
10.__isset()
当判断无法访问的属性是否存在的时候自动调用
PHP二叉堆是什么
二叉堆
二叉堆是一种特殊的堆,二叉堆是完全二叉树或者是近似完全二叉树,二叉堆有两种,最大堆 和 最小堆,最大堆:父结点的键值总是大于或等于任何一个子节点的键值;最小堆:父结点的键值总是小于或等于任何一个子节点的键值。
二叉堆实现流程是:
1、先读取10个或100个数到数组里面,这就是我们的topN数.
2、调用生成小顶堆函数,把这个数组生成一个小顶堆结构,这个时候堆顶一定是最小的.
3、从文件或者数组依次遍历剩余的所有数.
4、每遍历出来一个则跟堆顶的元素进行大小比较,如果小于堆顶元素则抛弃,如果大于堆顶元素则替换之.
5、跟堆顶元素替换完毕之后,在调用生成小顶堆函数继续生成小顶堆,因为需要再找出来一个最小的.
6、重复以上4~5步骤,这样当全部遍历完毕之后,我们这个小顶堆里面的就是最大的topN,因为我们的小顶堆永远都是排除最小的留下最大的,而且这个调整小顶堆速度也很快,只是相对调整下,只要保证根节点小于左右节点就可以.
7、算法复杂度的话按top10最坏的情况下,就是每遍历一个数,如果跟堆顶进行替换,需要调整10次的情况,也要比排序速度快,而且也不是把所有的内容全部读入内存,可以理解成就是一次线性遍历.