学习啦——学设计>网页设计>网站建设>网站服务器管理>

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次的情况,也要比排序速度快,而且也不是把所有的内容全部读入内存,可以理解成就是一次线性遍历.