<?php
header("content-type:text/html;charset=utf-8");
error_reporting(E_ALL); /*
连接数据库---类被实例化的自动连接
获取提示信息的方法
查询的方法
单条查询
多条查询
增删改的方法
统计记录数的方法
关闭数据库、销毁资源----程序结束的时候调用
*/
class dbManage{
private $conn; #保存数据库连接
public $mess; #保存提示信息
/*
方法名:__construct 构造方法
方法功能: 类实例化的同时连接数据库
方法参数:$hostname 主机地址
$username 数据库用户名
$password 数据库密码
$dbname 数据库名称 */
public function __construct($hostname,$username,$password,$dbname){
$this->conn=mysqli_connect($hostname,$username,$password,$dbname); #连接数据库
//判断数据库是否正确连接
if($this->conn){
$this->getMessage('连接成功',true);
$res=mysqli_query($this->conn,"set names utf8");
//判断编码是否正确设置
if($res){
$this->getMessage('数据库编码设置为utf8',true);
}else{
$this->getMessage(mysqli_errno($this->conn).":".mysqli_error($this->conn),false);
}
}else{
$this->getMessage('连接失败',false);
}
}
/*
方法名:getMessage
方法功能: 改造提示信息
方法参数:$info 提示信息
$flag true表示正确信息绿色文字 false 表示失败信息红色文字
*/
public function getMessage($info,$flag){
if($flag){ $this->mess.="<div style='color:green;'>".$info."</div>";
}else{
$this->mess.="<div style='color:red;'>".$info."</div>";
}
}
/*
方法名: getMoreData
方法功能: 获取多条记录
方法参数:$sql sql语句
*/
public function getMoreData($sql){
$rreg=preg_match('/^select/',trim($sql));#验证$sql是否为查询语句 if($rreg){
$data=mysqli_query($this->conn,$sql);
//判断mysqli_query是否执行成功
if($data){
//将资源类型的数据$data改变成数组
while($arr=mysqli_fetch_array($data,MYSQL_ASSOC)){
$res[]=$arr;
}
return $res; #将执行成功结果返回
}else{
$this->getMessage(mysqli_errno($this->conn).":".mysqli_error($this->conn),false);
}
}else{
$this->getMessage(__FUNCTION__.'()只能用于查询多条记录',false);
} }
/*
方法名: getOneData
方法功能: 获取单条记录
方法参数:$sql sql语句
*/
public function getOneData($sql){
$rreg=preg_match('/^select/',trim($sql));
if($rreg){
$data=mysqli_query($this->conn,$sql);
if($data){
$arr=mysqli_fetch_array($data,MYSQL_ASSOC);
return $arr;
}else{
$this->getMessage(mysqli_errno($this->conn).":".mysqli_error($this->conn),false);
}
}else{
$this->getMessage(__FUNCTION__.'()只能用于查询单条记录',false);
} }
/*
方法名: execSql
方法功能: 用于执行insert|update|delete|drop语句
方法参数:$sql sql语句
*/
public function execSql($sql){
$rreg=preg_match('/^insert|delete|update|drop/',trim($sql));
if($rreg){
$data=mysqli_query($this->conn,$sql);
if($data){
$this->getMessage($sql.'语句执行成功',true);
return true;
}else{
$this->getMessage(mysqli_errno($this->conn).":".mysqli_error($this->conn),false);
return false;
}
}else{
$this->getMessage(__FUNCTION__.'()只能用于执行insert|update|delete|drop语句',false);
return false;
}
}
/*
方法名: getRows
方法功能: 获取满足条件的记录数
方法参数:$tablename 表名称
$tj 条件,默认为1,1表示统计整张表的记录数
*/
public function getRows($tablename,$tj=1){
// select count(*) from student where cj>80;
$sql="select count(*) as c from ".$tablename." where ".$tj;
$data=mysqli_query($this->conn,$sql);
if($data){
$arr=mysqli_fetch_array($data,MYSQL_ASSOC);
// print_r($arr['c']);
return $arr['c'];
}else{
$this->getMessage(mysql_errno($this->conn).":".mysqli_error($this->conn),false);
}
}
/*
方法名: __destruct 析构方法
方法功能:销毁资源,关闭数据库 程序结束自动调用
方法参数:无
*/
public function __destruct(){
mysqli_close($this->conn); #关闭数据库
unset($this->mess);#销毁mess
}
} ?>

php连接mySql数据库 示例的更多相关文章

  1. JDBC连接MySQL数据库及示例

      JDBC是Sun公司制定的一个可以用Java语言连接数据库的技术. 一.JDBC基础知识         JDBC(Java Data Base Connectivity,java数据库连接)是一 ...

  2. .NET连接MySql数据库的方法及示例

    方法一: 使用MySQL推出的MySQL Connector/Net组件, 该组件是MySQL为ADO.NET访问MySQL数据库设计的.NET专用访问组件.完成该组件后,需要在项目中引用这个组件,也 ...

  3. 一个非常标准的连接Mysql数据库的示例代码

    一.About Mysql 1.Mysql 优点 体积小.速度快.开放源码.免费 一般中小型网站的开发都选择 MySQL ,最流行的关系型数据库 LAMP / LNMP Linux作为操作系统 Apa ...

  4. .NET 5/.NET Core使用EF Core 5连接MySQL数据库写入/读取数据示例教程

    本文首发于<.NET 5/.NET Core使用EF Core 5(Entity Framework Core)连接MySQL数据库写入/读取数据示例教程> 前言 在.NET Core/. ...

  5. JSP连接MySQL数据库问题

    之前写了一大段,还说了一下具体JDBC连接数据库API的具体包的基本知识,哪知道自己手残不小心按了删除按钮.结果去看自动保存记录时,就只剩下下面这段了.好吧,其实最主要最核心的也就是下面这点了.具体如 ...

  6. c/c++连接mysql数据库

    环境:win7 x64.vs2008.mysql 对于已经安装mysql的,查看mysql安装目录,如果安装目录下没有include和lib目录, 说明没有完全安装,需要下载mysql-connect ...

  7. python3.4怎么连接mysql pymysql连接mysql数据库

    本文介绍了python3 4连接mysql数据库的方法,在python3 4中使用原来python2 7的mysqldb已不能连接mysql数据库了,可以使用pymysql.   在python3.4 ...

  8. ASP 连接 MySQL 数据库两种方法

    一般都是用myodbc来连接.首先,在系统中安装 Mysql 的ODBC数据库驱动.如安装稳定版本是3.51.下载地址是:http://dev.mysql.com/downloads/connecto ...

  9. Java连接MySQL数据库及简单操作代码

    1.Java连接MySQL数据库 Java连接MySql需要下载JDBC驱动MySQL-connector-java-5.0.5.zip(举例,现有新版本).然后将其解压缩到任一目录.我是解压到D盘, ...

随机推荐

  1. GeneXus DevOps 自动化构建和部署流程

    以下视频详细介绍了GeneXus DevOps自动化构建和部署流程,包括通过MS Bulid来管理自动化流程,自动化的架构,以及在GeneXus Server上使用Jenkins做为自动化引擎. 视频 ...

  2. Spring--2.Spring之IOC--了解IOC容器

    IOC(容器),用来集成别的框架 1.IOC(Inversion(反转)Of Control):控制反转 控制:资源的获取方式: 主动式: BookServlet{ BookService bs=ne ...

  3. Spring学习记录1——IoC容器

    IoC容器 1.1  IoC概述 Ioc(Inverse of Control,控制反转)是Spring容器的内核.对于软件来说,即某一接口具体实现类的选择控制权从调用类中移除,转交给第三方决定,即由 ...

  4. HTTP图解笔记(六)—— 第6章 HTTP首部

    前言 为啥第一章直接跳到第六章呢,因为...博主当初看书的时候挑着看..只看了第一章和第六章┗( ▔, ▔ )┛ HTTP图解对于不熟悉HTTP的小伙伴来说是很好的书籍,建议入手! 一. HTTP报文 ...

  5. Mysql的binlog日志与mysqlbinlog命令

    binlog相关 MySQL 的二进制日志 binlog 可以说是 MySQL 最重要的日志,它记录了所有的 DDL 和 DML 语句(除了数据查询语句select.show等),以事件形式记录,还包 ...

  6. java.lang.IllegalArgumentException: clusterListener can not be null

    Caused by: org.springframework.beans.BeanInstantiationException: Failed to instantiate [com.mongodb. ...

  7. 关于SOA架构设计的案例分析

    关于SOA架构设计的案例分析 面向服务的体系结构(SOA)是一个组件模型,它将应用程序的不同功能单元(称为服务)通过这些服务之间定义良好的接口和契约联系起来.它可以根据需求通过网络对松散耦合的粗粒度应 ...

  8. Isx个人第4次作业—Alpha项目测试

    标题 内容 这个作业属于哪个课程 https://edu.cnblogs.com/campus/xnsy/GeographicInformationScience 这个作业要求在哪里 https:// ...

  9. 【原创】(一)Linux进程调度器-基础

    背景 Read the fucking source code! --By 鲁迅 A picture is worth a thousand words. --By 高尔基 说明: Kernel版本: ...

  10. Python中的 if __name__ == '__main__' 是什么意思?

    最近在看Python代码的时候,因为是Python初学者,看到这个if __name__ == '__main__' 的判断,并且下面还有代码语句,看了其他地方的说明,还是没搞明白是什么意思, 在看到 ...