php编写的mysql 操作类 php5的
<?php /*mysql 简单类 by joffe q89949401 围脖@狂code诗人; 本类全静态 使用的时候直接include后 用mysql::方法()名即可 由于类在php5里面全局可视,所以不必担心变量范围的问题.如果有什么意见 请围脖私信||qq邮件; 目前没有与存储过程有关的方法,当然存储过程一般是创建数据库的时候做的. config文件需要配置以下常量信息: LIB:类存放位置 DEBUG:是否开启debug(如果开启会输出错误信息跟踪) TB_EX:数据库表前缀; */ defined('LIB') or die('Missing config!!'); final class mysql { /** * 查询总次数 * * @var int */ public static $querynum = 0; /** * 连接句柄 * * @var object */ public static $link; /* 表前缀 @var string 下面方法需要在配置文件中配置TB_EX 作为表的前缀 */ static function add_ex($tb){ return TB_EX.$tb_ex.$tb; } /*mysql数据库是否使用严格的类型(mysql类型没开启自动转换)默认为false,表示mysql有开启类型转换,这个变量目前只要是用于insert函数的单引号在没有自动转换的mysql里面的问题,可能将来会增加相关函数 */ public static $is_type_tight=false; /** * 构造函数 * * @param string $dbhost 主机名 * @param string $dbuser 用户 * @param string $dbpw 密码 * @param string $dbname 数据库名 * @param int $pconnect 是否持续连接 */ static function connect($dbhost, $dbuser, $dbpw, $dbname = "",$dbcharset, $pconnect = 0) { if($pconnect) { if(!self::$link = @mysql_pconnect($dbhost, $dbuser, $dbpw)) { self::halt("Can not connect to MySQL server"); } } else { if(!self::$link = @mysql_connect($dbhost, $dbuser, $dbpw)) { self::halt("Can not connect to MySQL server"); } } if(self::version() > "4.1") { if($dbcharset) { mysql_query("SET character_set_connection={$dbcharset}, character_set_results=$dbcharset, character_set_client=binary", self::$link); } if(self::version() > "5.0.1") { mysql_query("SET sql_mode=''", self::$link); } } if($dbname) { mysql_select_db($dbname, self::$link); } } /** * 选择数据库 * * @param string $dbname * @return */ static function select_db($dbname) { return mysql_select_db($dbname, self::$link); } /** * 取出结果集中一条记录 * * @param object $query * @param int $result_type * @return array */ static function fetch_array($query, $result_type = MYSQL_ASSOC) { //默认只取关联数组 不取数字数组. return mysql_fetch_array($query, $result_type); } /** * 查询SQL * * @param string $sql * @param string $type * @return object */ static function query($sql, $type = "") { $func = $type == "UNBUFFERED" && @function_exists("mysql_unbuffered_query") ? "mysql_unbuffered_query" : "mysql_query"; if(!($query = $func($sql, self::$link)) && $type != "SILENT") { self::halt("MySQL Query Error", $sql); } self::$querynum++; return $query; } /** * 取影响条数 * * @return int */ static function affected_rows() { return mysql_affected_rows(self::$link); } /** * 返回错误信息 * * @return array */ static function error() { return ((self::$link) ? mysql_error(self::$link) : mysql_error()); } /** * 返回错误代码 * * @return int */ static function errno() { return intval((self::$link) ? mysql_errno(self::$link) : mysql_errno()); } /** * 返回查询结果 * * @param object $query * @param string $row * @return mixed */ static function result($query, $row,$flname=0) { $query = @mysql_result($query, $row,$flname); return $query; } /** * 结果条数 * * @param object $query * @return int */ static function num_rows($query) { $query = mysql_num_rows($query); return $query; } /** * 取字段总数 * * @param object $query * @return int */ static function num_fields($query) { return mysql_num_fields($query); } /** * 释放结果集 * * @param object $query * @return bool */ static function free_result($query) { return @mysql_free_result($query); } /** * 返回自增ID * * @return int */ static function insert_id() { return ($id = mysql_insert_id(self::$link)) >= 0 ? $id : self::$result(self::$query("SELECT last_insert_id()"), 0); } /** * 从结果集中取得一行作为枚举数组 * * @param object $query * @return array */ static function fetch_row($query) { $query = mysql_fetch_row($query); return $query; } /** * 从结果集中取得列信息并作为对象返回 * * @param object $query * @return object */ static function fetch_fields($query) { return mysql_fetch_field($query); } static function select_affectedt_rows($rs){ return mysql_affected_rows($rs,self::$link); } /** * 返回mysql版本 * * @return string */ static function version() { return mysql_get_server_info(self::$link); } /** * 关闭连接 * * @return bool */ static function close() { return mysql_close(self::$link); } /** * 输出错误信息 * * @param string $message * @param string $sql */ static function halt($message = "", $sql = "") { @header("Content-type: text/html; charset=utf-8"); if (DEBUG==1){ $debug = debug_backtrace(); echo $message . "\r\n<br/>SQL--> " . $sql."\r\n<br/>ERROR_MESSAGE-->".self::error(). "\r\n<br/>--------------debug--------------\r\n<br/>"; self::echoarray($debug); echo "\r\n<br/>-------------debug end----------------"; }else{ echo 'SQL Error'; } @self::rollback(); exit; } /////////////////////////////以下是扩展的sql方法.////// /* 把数组按照 key value value 的对应关系插入数据表table中 table 要插入的数据表 要注意 这些扩展方法是没自己给表有加前缀的. */ static function insert($table,$array){ $temp="";$temp2=''; foreach($array as $key=>$value){ if(self::$is_type_tight){ if(is_string($value)){ $temp .="$key,";$temp2 .="'$value',"; }elseif(is_int($value||is_null($value)||is_float($value))){ $value+=0; $temp .="$key,";$temp2 .="'$value',"; } }else{ $temp .="$key,";$temp2 .="'$value',"; } } $temp = substr($temp,0,strlen($temp)-1); $temp2 = substr($temp2,0,strlen($temp2)-1); $sql = "INSERT INTO $table ($temp) VALUE($temp2)"; return self::query($sql); } static function del($table,$where){ $sql = "DELETE FROM {$table} where {$where}"; return self::query($sql); } static function update($table,$array,$where){ foreach ($array as $key=>$value){ $temp .= "$key='$value',"; } $temp = substr($temp,0,strlen($temp)-1); $sql = "update {$table} set ($temp) where {$where} "; return self::query($sql); } /*进行数据库查询select 参数不定 参数说明:所有参数必须是string 第一个参数必须是表名; 从第二个参数起, 如果是写上 "where:XXX" 则认为是where条件; 如果写上 "xxx" 则认为是键值 如果写上 "by:XXX" 则认为是排序 如果写上 "limit:xxx,xxx" 则认为是分页 #参数不正确则返回false; 成功查询返回查询后的数组; */ static function select(){ $numargs = func_num_args();//获取参数个数; $where = "";$key="";$limit="";$by=""; if($numargs==0){return false;} //echo $numargs; if($numargs>=2){ $arg_list = func_get_args(); $table = $arg_list[0]; unset($arg_list[0]); // print_r($arg_list); foreach($arg_list as $k=>$value){ if(preg_match("#^(where:)\w#",$value)){ $temp = explode(":",$value); $where = "WHERE {$temp[1]} " ; }elseif(preg_match("#^by:\w#",$value)){ $temp = explode(":",$value); $by = "order by {$temp[1]}" ; }elseif(preg_match("#^limit:\w#",$value)){ $temp = explode(":",$value); $limit = "limit {$temp[1]}"; }else{ $key .= "$value,"; } } if($key==""){ $key = "*"; }else{ $key =substr($key,0,strlen($key)-1); } $sql_base="SELECT $key FROM $table"; } if(!empty($where)){ $sql_base .= " $where"; } if(!empty($by)){ $sql_base .= " $by"; } if(!empty($limit)){ $sql_base .= " $limit"; } //echo $sql_base; //echo $by ; $rs = self::query($sql_base); $re=array(); if(self::num_rows($rs)>=1){ while($info = self::fetch_array($rs)){ $re[]=$info; } } self::free_result($rs); return $re; } /*回滚事务*/ static function rollback(){ self::query('rollback'); } /*开始事务*/ static function begin(){ self::query('SET AUTOCOMMIT =0'); //停用自动提交; self::query('BEGIN') ;//开始一个事务; } /*提交事务*/ static function commit(){ self::query('commit'); } static function echoarray($array){ foreach($array as $k=>$v ){ if(is_array($v)){ if(is_array($v)){ echo "<br/>--------------------------------<br/>"; self::echoarray($v); } }else{ if($k==='line') echo "<b style='color:red'>$k -> " .$v."</b> "; else echo "$k -> " .$v." "; } } } static function get_server_info(){ return mysql_get_server_info(); } } ?>
以上就是php编写的mysql 操作类 php5的 的内容,更多相关内容请关注PHP中文网(www.php.cn)!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











MySQL은 오픈 소스 관계형 데이터베이스 관리 시스템으로, 주로 데이터를 신속하고 안정적으로 저장하고 검색하는 데 사용됩니다. 작업 원칙에는 클라이언트 요청, 쿼리 해상도, 쿼리 실행 및 반환 결과가 포함됩니다. 사용의 예로는 테이블 작성, 데이터 삽입 및 쿼리 및 조인 작업과 같은 고급 기능이 포함됩니다. 일반적인 오류에는 SQL 구문, 데이터 유형 및 권한이 포함되며 최적화 제안에는 인덱스 사용, 최적화 된 쿼리 및 테이블 분할이 포함됩니다.

PHP는 현대 웹 개발, 특히 컨텐츠 관리 및 전자 상거래 플랫폼에서 중요합니다. 1) PHP는 Laravel 및 Symfony와 같은 풍부한 생태계와 강력한 프레임 워크 지원을 가지고 있습니다. 2) Opcache 및 Nginx를 통해 성능 최적화를 달성 할 수 있습니다. 3) PHP8.0은 성능을 향상시키기 위해 JIT 컴파일러를 소개합니다. 4) 클라우드 네이티브 애플리케이션은 Docker 및 Kubernetes를 통해 배포되어 유연성과 확장 성을 향상시킵니다.

PHP와 Python은 각각 고유 한 장점이 있으며 프로젝트 요구 사항에 따라 선택합니다. 1.PHP는 웹 개발, 특히 웹 사이트의 빠른 개발 및 유지 보수에 적합합니다. 2. Python은 간결한 구문을 가진 데이터 과학, 기계 학습 및 인공 지능에 적합하며 초보자에게 적합합니다.

MySQL은 성능, 신뢰성, 사용 편의성 및 커뮤니티 지원을 위해 선택됩니다. 1.MYSQL은 효율적인 데이터 저장 및 검색 기능을 제공하여 여러 데이터 유형 및 고급 쿼리 작업을 지원합니다. 2. 고객-서버 아키텍처 및 다중 스토리지 엔진을 채택하여 트랜잭션 및 쿼리 최적화를 지원합니다. 3. 사용하기 쉽고 다양한 운영 체제 및 프로그래밍 언어를 지원합니다. 4. 강력한 지역 사회 지원을 받고 풍부한 자원과 솔루션을 제공합니다.

PHP가 많은 웹 사이트에서 선호되는 기술 스택 인 이유에는 사용 편의성, 강력한 커뮤니티 지원 및 광범위한 사용이 포함됩니다. 1) 배우고 사용하기 쉽고 초보자에게 적합합니다. 2) 거대한 개발자 커뮤니티와 풍부한 자원이 있습니다. 3) WordPress, Drupal 및 기타 플랫폼에서 널리 사용됩니다. 4) 웹 서버와 밀접하게 통합하여 개발 배포를 단순화합니다.

데이터베이스 및 프로그래밍에서 MySQL의 위치는 매우 중요합니다. 다양한 응용 프로그램 시나리오에서 널리 사용되는 오픈 소스 관계형 데이터베이스 관리 시스템입니다. 1) MySQL은 웹, 모바일 및 엔터프라이즈 레벨 시스템을 지원하는 효율적인 데이터 저장, 조직 및 검색 기능을 제공합니다. 2) 클라이언트 서버 아키텍처를 사용하고 여러 스토리지 엔진 및 인덱스 최적화를 지원합니다. 3) 기본 사용에는 테이블 작성 및 데이터 삽입이 포함되며 고급 사용에는 다중 테이블 조인 및 복잡한 쿼리가 포함됩니다. 4) SQL 구문 오류 및 성능 문제와 같은 자주 묻는 질문은 설명 명령 및 느린 쿼리 로그를 통해 디버깅 할 수 있습니다. 5) 성능 최적화 방법에는 인덱스의 합리적인 사용, 최적화 된 쿼리 및 캐시 사용이 포함됩니다. 모범 사례에는 거래 사용 및 준비된 체계가 포함됩니다

PHP는 서버 측에서 널리 사용되는 스크립팅 언어이며 특히 웹 개발에 적합합니다. 1.PHP는 HTML을 포함하고 HTTP 요청 및 응답을 처리 할 수 있으며 다양한 데이터베이스를 지원할 수 있습니다. 2.PHP는 강력한 커뮤니티 지원 및 오픈 소스 리소스를 통해 동적 웹 컨텐츠, 프로세스 양식 데이터, 액세스 데이터베이스 등을 생성하는 데 사용됩니다. 3. PHP는 해석 된 언어이며, 실행 프로세스에는 어휘 분석, 문법 분석, 편집 및 실행이 포함됩니다. 4. PHP는 사용자 등록 시스템과 같은 고급 응용 프로그램을 위해 MySQL과 결합 할 수 있습니다. 5. PHP를 디버깅 할 때 error_reporting () 및 var_dump ()와 같은 함수를 사용할 수 있습니다. 6. 캐싱 메커니즘을 사용하여 PHP 코드를 최적화하고 데이터베이스 쿼리를 최적화하며 내장 기능을 사용하십시오. 7

PHP와 Python은 각각 고유 한 장점이 있으며 다양한 시나리오에 적합합니다. 1.PHP는 웹 개발에 적합하며 내장 웹 서버 및 풍부한 기능 라이브러리를 제공합니다. 2. Python은 간결한 구문과 강력한 표준 라이브러리가있는 데이터 과학 및 기계 학습에 적합합니다. 선택할 때 프로젝트 요구 사항에 따라 결정해야합니다.
