


Exemple d'explication PHP sur la classe d'opération de base de données MySQL
Le code présenté dans cet article appartient à une classe d'encapsulation de base de données relativement simple, qui convient mieux aux débutants. Les amis qui en ont besoin peuvent s'y référer
et ensuite parler de l'idée générale. L'encapsulation de la classe entière comprend une propriété privée $conn pour la connexion à la base de données et plusieurs fonctions d'exploitation. Lorsque $conn est instancié, le constructeur traite les paramètres entrants et renvoie un handle de connexion de type ressource. Vous pouvez ensuite ajouter, supprimer, vérifier et modifier la base de données en appelant la méthode correspondante de l'objet instancié.
parler moins et afficher le code :
<?php /** *以下代码用于数据库操作类的封装 * * @author rex<rex.sp.li@aliyun.com> * @version 1.0 * @since 2015 */ class Mysql{ //数据库连接返回值 private $conn; /** * [构造函数,返回值给$conn] * @param [string] $hostname [主机名] * @param [string] $username[用户名] * @param [string] $password[密码] * @param [string] $dbname[数据库名] * @param [string] $charset[字符集] * @return [null] */ function __construct($hostname,$username,$password,$dbname,$charset='utf8'){ $conn = @mysql_connect($hostname,$username,$password); if(!$conn){ echo '连接失败,请联系管理员'; exit; } $this->conn = $conn; $res = mysql_select_db($dbname); if(!$res){ echo '连接失败,请联系管理员'; exit; } mysql_set_charset($charset); } function __destruct(){ mysql_close(); } /** * [getAll 获取所有信息] * @param [string] $sql [sql语句] * @return [array] [返回二维数组] */ function getAll($sql){ $result = mysql_query($sql,$this->conn); $data = array(); if($result && mysql_num_rows($result)>0){ while($row = mysql_fetch_assoc($result)){ $data[] = $row; } } return $data; } /** * [getOne 获取单条数据] * @param [string] $sql [sql语句] * @return [array] [返回一维数组] */ function getOne($sql){ $result = mysql_query($sql,$this->conn); $data = array(); if($result && mysql_num_rows($result)>0){ $data = mysql_fetch_assoc($result); } return $data; } /** * [getOne 获取单条数据] * @param [string] $table [表名] * @param [string] $data [由字段名当键,属性当键值的一维数组] * @return [type] [返回false或者插入数据的id] */ function insert($table,$data){ $str = ''; $str .="INSERT INTO `$table` "; $str .="(`".implode("`,`",array_keys($data))."`) "; $str .=" VALUES "; $str .= "('".implode("','",$data)."')"; $res = mysql_query($str,$this->conn); if($res && mysql_affected_rows()>0){ return mysql_insert_id(); }else{ return false; } } /** * [update 更新数据库] * @param [string] $table [表名] * @param [array] $data [更新的数据,由字段名当键,属性当键值的一维数组] * @param [string] $where [条件,‘字段名'=‘字段属性'] * @return [type] [更新成功返回影响的行数,更新失败返回false] */ function update($table,$data,$where){ $sql = 'UPDATE '.$table.' SET '; foreach($data as $key => $value){ $sql .= "`{$key}`='{$value}',"; } $sql = rtrim($sql,','); $sql .= " WHERE $where"; $res = mysql_query($sql,$this->conn); if($res && mysql_affected_rows()){ return mysql_affected_rows(); }else{ return false; } } /** * [delete 删除数据] * @param [string] $table [表名] * @param [string] $where [条件,‘字段名'=‘字段属性'] * @return [type] [成功返回影响的行数,失败返回false] */ function del($table,$where){ $sql = "DELETE FROM `{$table}` WHERE {$where}"; $res = mysql_query($sql,$this->conn); if($res && mysql_affected_rows()){ return mysql_affected_rows(); }else{ return false; } } }
Cours instancié :
<?php //包含数据库操作类文件 include 'mysql.class.php'; //设置传入参数 $hostname='localhost'; $username='root'; $password='123456'; $dbname='aisi'; $charset = 'utf8'; //实例化对象 $db = new Mysql($hostname,$username,$password,$dbname); //获取一条数据 $sql = "SELECT count(as_article_id) as count FROM as_article where as_article_type_id=1"; $count = $db->getOne($sql); //获取多条数据 $sql = "SELECT * FROM as_article where as_article_type_id=1 order by as_article_addtime desc limit $start,$limit"; $service = $db->getAll($sql); //插入数据 $arr = array( 'as_article_title'=>'数据库操作类', 'as_article_author'=>'rex', ); $res = $db->insert('as_article',$arr); //更新数据 $arr = array( 'as_article_title'=>'实例化对象', 'as_article_author'=>'Lee', ); $where = "as_article_id=1"; $res = $db->update('as_article',$arr,$where); //删除数据 $where = "as_article_id=1"; $res = $db->del('as_article',$where); ?>
Après avoir démontré le code, dites quelques mots.
La méthode getOne transmet l'instruction sql de $sql pour interroger une seule donnée et renvoie un tableau unidimensionnel ; la méthode getAll transmet également l'instruction sql pour interroger plusieurs données et renvoie un tableau bidimensionnel ; la méthode d'insertion transmet le nom de la table et le tableau associatif, et renvoie un type booléen ou l'index correspondant aux données insérées ; la méthode de mise à jour transmet le nom de la table, un tableau associatif et les conditions, et renvoie un boolen ou le nombre de lignes affectées ; la méthode del transmet le nom et les conditions de la table et renvoie un type boolen.
C'est tout, mais pas tout. Les amis intéressés peuvent l'optimiser en passant getOne et getAll directement dans l'instruction SQL en tant que paramètres.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Outils d'IA chauds

Undress AI Tool
Images de déshabillage gratuites

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Clothoff.io
Dissolvant de vêtements AI

Video Face Swap
Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Phparrayshandledatacollectionsefficantyusing indexedorassociativstructures; theyareCreated withArray () ou [], accessedViakeys, modifiedByAssigment, itérated withoreach, andmanipulatedUsingFunction

$ _CookieisaphpsuperglobalForAccessingCooKiessentByThebrowser; cookiesAreSetingSetCooKie () BeforeOutput, ReadVia $ _cookie ['name'], Updated Resenderwithnewvalues, anddeletedBysetinganExpiredtimestamp, withsecurit
![Vous n'utilisez pas actuellement un écran attaché à un GPU NVIDIA [FIX]](https://img.php.cn/upload/article/001/431/639/175553352135306.jpg?x-oss-process=image/resize,m_fill,h_207,w_330)
Ifyousee "YouarenotusingAdisplayAttachedToannvidiagpu", assurez-vous

UsedateTimefordatesInPhp: CreateWithNewDateTime (), FormatWithFormat (), ModifyViaAdd () Ormodify (), SettimeZones withDatetimeZone, andCompareusingOratorsOrdiff () tagtIntervals.

Vous pouvez personnaliser le séparateur en utilisant le mot-clé séparateur dans la fonction group_concat (); 1. Utilisez le séparateur pour spécifier un séparateur personnalisé, comme le séparateur '; «Le séparateur peut être changé pour un semi-colon et plus d'espace; 2. Les exemples courants incluent l'utilisation du caractère de tuyau '|', de l'espace '', du caractère de rupture de ligne '\ n' ou de la chaîne personnalisée '->' comme séparateur; 3. Notez que le séparateur doit être une chaîne littérale ou expression, et la longueur du résultat est limitée par la variable Group_Concat_Max_Len, qui peut être ajustée par setSessionGroup_Concat_Max_Len = 10000; 4. Le séparateur est facultatif

Pour sélectionner les données de la table MySQL, vous devez utiliser l'instruction SELECT, 1. Utilisez SELECTColumn1, Column2FromTable_Name pour obtenir la colonne spécifiée, ou utilisez SELECT * pour obtenir toutes les colonnes; 2. Utilisez la clause pour filtrer les lignes, telles que SELECTNAME, AgefromUsers WHERAGEAGE> 25; 3. Utilisez l'ordre pour trier les résultats, tels que OrderByageSc, représentant l'ordre descendant de l'âge; 4. Utilisez Limit pour limiter le nombre de lignes, telles que Limit5 pour renvoyer les 5 premières lignes, ou utilisez Limit10OffSet20 pour implémenter la pagination; 5. Utiliser et, ou et parenthèses pour combiner

ThelikeOperatorInmysqlisUsedTosearchForPatternSintextDatausingwildcards; 1.Usure% tomatchanysenceofcharactersandtomatchasing caractère; 2.Forexample, 'John%' se trouve

Thephprequestlifecyclebeginswhenaclientsndanhttprequesttoawebserver, qui thenreceives andparsesitodetterminethere a été soutenu
