FLEAPHP框架下Mysqli连接扩展
公司老的CRM系统是基于FLEAPHP,这玩意老早就不更新了,当php升级到5.5后,系统会提示mysql_connect函数即将被废弃,建议跟换mysqli或pdo,nnd逼我换框架么,好吧我只是随便说说,还是自己动手,丰衣足食。 新增一个Mysqli.php,修改Abstract.php文件。 使用方
公司老的CRM系统是基于FLEAPHP,这玩意老早就不更新了,当php升级到5.5后,系统会提示mysql_connect函数即将被废弃,建议跟换mysqli或pdo,nnd逼我换框架么,好吧我只是随便说说,还是自己动手,丰衣足食。
新增一个 Mysqli.php,修改Abstract.php 文件。
使用方法:
将两个文件放到"FLEA\Db\Driver\"目录下,覆盖即可。
Ps:Abstract.php只是做了一个很小的兼容性修改,不影响其他功能。 FleaPHP
<?php /** * 定义 FLEA_Db_Driver_Mysqli 驱动 基于FLEA_Db_Driver_Mysql 修改 * by 豚鼠窝窝 2014.05.07 * maophp@qq.com */ // {{{ includes FLEA::loadClass('FLEA_Db_Driver_Abstract'); // }}} class FLEA_Db_Driver_Mysqli extends FLEA_Db_Driver_Abstract { var $NEXT_ID_SQL = 'UPDATE %s SET id = LAST_INSERT_ID(id + 1)'; var $CREATE_SEQ_SQL = 'CREATE TABLE %s (id INT NOT NULL)'; var $INIT_SEQ_SQL = 'INSERT INTO %s VALUES (%s)'; var $DROP_SEQ_SQL = 'DROP TABLE %s'; var $META_COLUMNS_SQL = 'SHOW FULL COLUMNS FROM %s'; var $PARAM_STYLE = DBO_PARAM_QM; var $HAS_INSERT_ID = true; var $HAS_AFFECTED_ROWS = true; var $_mysqlVersion = null; function connect($dsn = false) { $this->lasterr = null; $this->lasterrcode = null; if ($this->conn && $dsn == false) { return true; } if (!$dsn) { $dsn = $this->dsn; } else { $this->dsn = $dsn; } if (isset($dsn['port']) && $dsn['port'] != '') { $host = $dsn['host'] . ':' . $dsn['port']; } else { $host = $dsn['host']; } if (!isset($dsn['login'])) { $dsn['login'] = ''; } if (!isset($dsn['password'])) { $dsn['password'] = ''; } if (!empty($dsn['options'])) { $this->conn = mysqli_connect($host, $dsn['login'], $dsn['password'], false, $dsn['options']); } else { $this->conn = mysqli_connect($host, $dsn['login'], $dsn['password']); } if (!$this->conn) { FLEA::loadClass('FLEA_Db_Exception_SqlQuery'); return __THROW(new FLEA_Db_Exception_SqlQuery("mysqli_connect('{$host}', '{$dsn['login']}') failed!", mysqli_error(), mysqli_errno())); } if (!empty($dsn['database'])) { if (!$this->selectDb($dsn['database'])) { return false; } } $this->_mysqlVersion = $this->getOne('SELECT VERSION()'); if (isset($dsn['charset']) && $dsn['charset'] != '') { $charset = $dsn['charset']; } else { $charset = FLEA::getAppInf('databaseCharset'); } if ($this->_mysqlVersion >= '4.1' && $charset != '') { if (!$this->execute("SET NAMES '" . $charset . "'")) { return false; } } if ($this->_mysqlVersion >= '5.0') { $this->HAS_SAVEPOINT = true; } return true; } function close() { if ($this->conn) { mysqli_close($this->conn); } parent::close(); } function selectDb($database) { if (!mysqli_select_db( $this->conn, $database)) { FLEA::loadClass('FLEA_Db_Exception_SqlQuery'); return __THROW(new FLEA_Db_Exception_SqlQuery("SELECT DATABASE: '{$database}' FAILED!", mysqli_error($this->conn), mysqli_errno($this->conn))); } return true; } function execute($sql, $inputarr = null, $throw = true) { if (is_array($inputarr)) { $sql = $this->bind($sql, $inputarr); } if ($this->enableLog) { $this->log[] = $sql; log_message("sql: {$sql}", 'debug'); } $this->querycount++; $result = mysqli_query($this->conn, $sql,MYSQLI_USE_RESULT); if ($result !== false) { $this->lasterr = null; $this->lasterrcode = null; return $result; } $this->lasterr = mysqli_error($this->conn); $this->lasterrcode = mysqli_errno($this->conn); if ($throw) { FLEA::loadClass('FLEA_Db_Exception_SqlQuery'); __THROW(new FLEA_Db_Exception_SqlQuery($sql, $this->lasterr, $this->lasterrcode)); } return false; } function qstr($value) { if (is_int($value) || is_float($value)) { return $value; } if (is_bool($value)) { return $value ? $this->TRUE_VALUE : $this->FALSE_VALUE; } if (is_null($value)) { return $this->NULL_VALUE; } return "'" . mysqli_real_escape_string($this->conn, $value) . "'"; } function qtable($tableName, $schema = null) { return $schema != '' ? "`{$schema}`.`{$tableName}`" : "`{$tableName}`"; } function qfield($fieldName, $tableName = null, $schema = null) { $fieldName = ($fieldName == '*') ? '*' : "`{$fieldName}`"; return $tableName != '' ? $this->qtable($tableName, $schema) . '.' . $fieldName : $fieldName; } function _insertId() { return mysqli_insert_id($this->conn); } function _affectedRows() { return mysqli_affected_rows($this->conn); } function fetchRow($res) { return mysqli_fetch_row($res); } function fetchAssoc($res) { return mysqli_fetch_assoc($res); } function freeRes($res) { return mysqli_free_result($res); } function selectLimit($sql, $length = null, $offset = null) { if (!is_null($offset)) { $sql .= " LIMIT " . (int)$offset; if (!is_null($length)) { $sql .= ', ' . (int)$length; } else { $sql .= ', 4294967294'; } } elseif (!is_null($length)) { $sql .= " LIMIT " . (int)$length; } return $this->execute($sql); } function metaColumns($table) { /** * C CHAR 或 VARCHAR 类型字段 * X TEXT 或 CLOB 类型字段 * B 二进制数据(BLOB) * N 数值或者浮点数 * D 日期 * T TimeStamp * L 逻辑布尔值 * I 整数 * R 自动增量或计数器 */ static $typeMap = array( 'BIT' => 'I', 'TINYINT' => 'I', 'BOOL' => 'L', 'BOOLEAN' => 'L', 'SMALLINT' => 'I', 'MEDIUMINT' => 'I', 'INT' => 'I', 'INTEGER' => 'I', 'BIGINT' => 'I', 'FLOAT' => 'N', 'DOUBLE' => 'N', 'DOUBLEPRECISION' => 'N', 'FLOAT' => 'N', 'DECIMAL' => 'N', 'DEC' => 'N', 'DATE' => 'D', 'DATETIME' => 'T', 'TIMESTAMP' => 'T', 'TIME' => 'T', 'YEAR' => 'I', 'CHAR' => 'C', 'NCHAR' => 'C', 'VARCHAR' => 'C', 'NVARCHAR' => 'C', 'BINARY' => 'B', 'VARBINARY' => 'B', 'TINYBLOB' => 'X', 'TINYTEXT' => 'X', 'BLOB' => 'X', 'TEXT' => 'X', 'MEDIUMBLOB' => 'X', 'MEDIUMTEXT' => 'X', 'LONGBLOB' => 'X', 'LONGTEXT' => 'X', 'ENUM' => 'C', 'SET' => 'C', ); $rs = $this->execute(sprintf($this->META_COLUMNS_SQL, $table)); if (!$rs) { return false; } $retarr = array(); while (($row = mysqli_fetch_assoc($rs))) { $field = array(); $field['name'] = $row['Field']; $type = $row['Type']; $field['scale'] = null; $queryArray = false; if (preg_match('/^(.+)\((\d+),(\d+)/', $type, $queryArray)) { $field['type'] = $queryArray[1]; $field['maxLength'] = is_numeric($queryArray[2]) ? $queryArray[2] : -1; $field['scale'] = is_numeric($queryArray[3]) ? $queryArray[3] : -1; } elseif (preg_match('/^(.+)\((\d+)/', $type, $queryArray)) { $field['type'] = $queryArray[1]; $field['maxLength'] = is_numeric($queryArray[2]) ? $queryArray[2] : -1; } elseif (preg_match('/^(enum)\((.*)\)$/i', $type, $queryArray)) { $field['type'] = $queryArray[1]; $arr = explode(",",$queryArray[2]); $field['enums'] = $arr; $zlen = max(array_map("strlen",$arr)) - 2; // PHP >= 4.0.6 $field['maxLength'] = ($zlen > 0) ? $zlen : 1; } else { $field['type'] = $type; $field['maxLength'] = -1; } $field['simpleType'] = $typeMap[strtoupper($field['type'])]; // if ($field['simpleType'] == 'C' && $field['maxLength'] > 250) { // $field['simpleType'] = 'X'; // } $field['notNull'] = ($row['Null'] != 'YES'); $field['primaryKey'] = ($row['Key'] == 'PRI'); $field['autoIncrement'] = (strpos($row['Extra'], 'auto_increment') !== false); if ($field['autoIncrement']) { $field['simpleType'] = 'R'; } $field['binary'] = (strpos($type,'blob') !== false); $field['unsigned'] = (strpos($type,'unsigned') !== false); if ($field['type'] == 'tinyint' && $field['maxLength'] == 1) { $field['simpleType'] = 'L'; } if (!$field['binary']) { $d = $row['Default']; if ($d != '' && $d != 'NULL') { $field['hasDefault'] = true; $field['defaultValue'] = $this->setValueByType($d, $field['simpleType']); } else { $field['hasDefault'] = false; } } $field['description'] = isset($row['Comment']) ? $row['Comment'] : ''; $retarr[strtoupper($field['name'])] = $field; } mysqli_free_result($rs); return $retarr; } function metaTables($pattern = null, $schema = null) { $sql = 'SHOW TABLES'; if (!empty($schema)) { $sql .= " FROM {$schema}"; } if (!empty($pattern)) { $sql .= ' LIKE ' . $this->qstr($schema); } $res = $this->execute($sql, null, false); $tables = array(); while (($row = $this->fetchRow($res))) { $tables[] = reset($row); } $this->freeRes($res); return $tables; } function _startTrans() { $this->execute('START TRANSACTION'); } function _completeTrans($commitOnNoErrors = true) { if ($this->_hasFailedQuery == false && $commitOnNoErrors) { $this->execute('COMMIT'); } else { $this->execute('ROLLBACK'); } } }

핫 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)

뜨거운 주제











Java 프레임워크에 대한 상용 지원의 비용/성능 평가에는 다음 단계가 포함됩니다. 필요한 보증 수준과 SLA(서비스 수준 계약) 보장을 결정합니다. 연구지원팀의 경험과 전문성. 업그레이드, 문제 해결, 성능 최적화와 같은 추가 서비스를 고려하십시오. 위험 완화 및 효율성 향상을 기준으로 비즈니스 지원 비용을 평가합니다.

PHP 프레임워크의 학습 곡선은 언어 숙련도, 프레임워크 복잡성, 문서 품질 및 커뮤니티 지원에 따라 달라집니다. PHP 프레임워크의 학습 곡선은 Python 프레임워크에 비해 높고 Ruby 프레임워크에 비해 낮습니다. Java 프레임워크에 비해 PHP 프레임워크는 학습 곡선이 적당하지만 시작하는 데 걸리는 시간이 더 짧습니다.

경량 PHP 프레임워크는 작은 크기와 낮은 리소스 소비를 통해 애플리케이션 성능을 향상시킵니다. 그 특징은 다음과 같습니다: 작은 크기, 빠른 시작, 낮은 메모리 사용량, 향상된 응답 속도 및 처리량, 리소스 소비 감소 실제 사례: SlimFramework는 500KB에 불과한 REST API를 생성하며 높은 응답성과 높은 처리량을 제공합니다.

벤치마크에 따르면 소규모 고성능 애플리케이션의 경우 Quarkus(빠른 시작, 낮은 메모리) 또는 Micronaut(TechEmpower 우수)가 이상적인 선택입니다. SpringBoot는 대규모 풀 스택 애플리케이션에 적합하지만 시작 시간과 메모리 사용량이 약간 느립니다.

Golang 프레임워크에서는 명확하고 포괄적인 문서를 작성하는 것이 중요합니다. 모범 사례에는 Google의 Go 코딩 스타일 가이드와 같은 확립된 문서 스타일을 따르는 것이 포함됩니다. 제목, 부제, 목록 등 명확한 조직 구조를 사용하고 탐색 기능을 제공하세요. 시작 안내서, API 참조 및 개념을 포함하여 포괄적이고 정확한 정보를 제공합니다. 코드 예제를 사용하여 개념과 사용법을 설명합니다. 문서를 계속 업데이트하고, 변경 사항을 추적하고, 새로운 기능을 문서화하세요. GitHub 문제 및 포럼과 같은 지원 및 커뮤니티 리소스를 제공합니다. API 문서와 같은 실용적인 예제를 만듭니다.

애플리케이션 시나리오를 기반으로 최고의 Go 프레임워크를 선택하세요. 애플리케이션 유형, 언어 기능, 성능 요구 사항 및 생태계를 고려하세요. Common Go 프레임워크: Gin(웹 애플리케이션), Echo(웹 서비스), Fiber(높은 처리량), gorm(ORM), fasthttp(속도). 실제 사례: REST API(Fiber) 구축 및 데이터베이스(gorm)와 상호 작용. 프레임워크를 선택하세요. 주요 성능을 위해서는 fasthttp를 선택하고, 유연한 웹 애플리케이션을 위해서는 Gin/Echo를, 데이터베이스 상호작용을 위해서는 gorm을 선택하세요.

Go 프레임워크 개발에서 일반적인 과제와 해결 방법은 다음과 같습니다. 오류 처리: 관리에는 오류 패키지를 사용하고 중앙에서 오류를 처리하려면 미들웨어를 사용합니다. 인증 및 권한 부여: 타사 라이브러리를 통합하고 사용자 정의 미들웨어를 생성하여 자격 증명을 확인합니다. 동시 처리: 고루틴, 뮤텍스 및 채널을 사용하여 리소스 액세스를 제어합니다. 단위 테스트: 격리를 위해 getest 패키지, 모의 및 스텁을 사용하고, 충분성을 보장하기 위한 코드 적용 도구를 사용합니다. 배포 및 모니터링: Docker 컨테이너를 사용하여 배포를 패키징하고, 데이터 백업을 설정하고, 로깅 및 모니터링 도구를 사용하여 성능과 오류를 추적합니다.

Go 프레임워크 학습에는 다섯 가지 오해가 있습니다. 프레임워크에 대한 과도한 의존과 제한된 유연성입니다. 프레임워크 규칙을 따르지 않으면 코드를 유지 관리하기가 어려워집니다. 오래된 라이브러리를 사용하면 보안 및 호환성 문제가 발생할 수 있습니다. 패키지를 과도하게 사용하면 코드 구조가 난독화됩니다. 오류 처리를 무시하면 예기치 않은 동작과 충돌이 발생합니다.
