<?php /** * MySQL 数据库操作工具类, 方便数据库操作. * 示例见底部注释. * @author: <span style="color: rgb(0, 0, 0); ">http://www.ideawu.net/blog/ */ class Mysql{ var $conn; var $query_list = array(); public $query_count = 0; public function __construct($c){ if(!isset($c['port'])){ $c['port'] = '3306'; } $server = $c['host'] . ':' . $c['port']; $this->conn = mysql_connect($server, $c['username'], $c['password'], true) or die('connect db error'); mysql_select_db($c['dbname'], $this->conn) or die('select db error'); if($c['charset']){ mysql_query("set names " . $c['charset'], $this->conn); } } /** * 执行 mysql_query 并返回其结果. */ public function query($sql){ $stime = microtime(true); $result = mysql_query($sql, $this->conn); $this->query_count ++; if($result === false){ throw new Exception(mysql_error($this->conn)." in SQL: $sql"); } $etime = microtime(true); $time = number_format(($etime - $stime) * 1000, 2); $this->query_list[] = $time . ' ' . $sql; return $result; } /** * 执行 SQL 语句, 返回结果的第一条记录(是一个对象). */ public function get($sql){ $result = $this->query($sql); if($row = mysql_fetch_object($result)){ return $row; }else{ return null; } } /** * 返回查询结果集, 以 key 为键组织成关联数组, 每一个元素是一个对象. * 如果 key 为空, 则将结果组织成普通的数组. */ public function find($sql, $key=null){ $data = array(); $result = $this->query($sql); while($row = mysql_fetch_object($result)){ if(!empty($key)){ $data[$row->{$key}] = $row; }else{ $data[] = $row; } } return $data; } public function last_insert_id(){ return mysql_insert_id($this->conn); } /** * 执行一条带有结果集计数的 count SQL 语句, 并返该计数. */ public function count($sql){ $result = $this->query($sql); if($row = mysql_fetch_array($result)){ return (int)$row[0]; }else{ return 0; } } /** * 开始一个事务. */ public function begin(){ mysql_query('begin'); } /** * 提交一个事务. */ public function commit(){ mysql_query('commit'); } /** * 回滚一个事务. */ public function rollback(){ mysql_query('rollback'); } /** * 获取指定编号的记录. * @param int $id 要获取的记录的编号. * @param string $field 字段名, 默认为'id'. */ function load($table, $id, $field='id'){ $sql = "select * from `{$table}` where `{$field}`='{$id}'"; $row = $this->get($sql); return $row; } /** * 保存一条记录, 调用后, id被设置. * @param object $row */ function save($table, &$row){ $sqlA = ''; foreach($row as $k=>$v){ $sqlA .= "`$k` = '$v',"; } $sqlA = substr($sqlA, 0, strlen($sqlA)-1); $sql = "insert into `{$table}` set $sqlA"; $this->query($sql); if(is_object($row)){ $row->id = $this->last_insert_id(); }else if(is_array($row)){ $row['id'] = $this->last_insert_id(); } } /** * 更新$arr[id]所指定的记录. * @param array $row 要更新的记录, 键名为id的数组项的值指示了所要更新的记录. * @return int 影响的行数. * @param string $field 字段名, 默认为'id'. */ function update($table, &$row, $field='id'){ $sqlA = ''; foreach($row as $k=>$v){ $sqlA .= "`$k` = '$v',"; } $sqlA = substr($sqlA, 0, strlen($sqlA)-1); if(is_object($row)){ $id = $row->{$field}; }else if(is_array($row)){ $id = $row[$field]; } $sql = "update `{$table}` set $sqlA where `{$field}`='$id'"; return $this->query($sql); } /** * 删除一条记录. * @param int $id 要删除的记录编号. * @return int 影响的行数. * @param string $field 字段名, 默认为'id'. */ function remove($table, $id, $field='id'){ $sql = "delete from `{$table}` where `{$field}`='{$id}'"; return $this->query($sql); } function escape(&$val){ if(is_object($val) is_array($val)){ $this->escape_row($val); } } function escape_row(&$row){ if(is_object($row)){ foreach($row as $k=>$v){ $row->$k = mysql_real_escape_string($v); } }else if(is_array($row)){ foreach($row as $k=>$v){ $row[$k] = mysql_real_escape_string($v); } } } function escape_like_string($str){ $find = array('%', '_'); $replace = array('\%', '\_'); $str = str_replace($find, $replace, $str); return $str; } } ?>
使用例子:
<?php // 保存 $db->save('table_1', $row); // 更新 $db->update('table_1', $row); // 删除 $db->remove('table_1', 1); // 查询 $rows = $db->find($sql, 'id') ?>

function是函数的意思,是一段具有特定功能的可重复使用的代码块,是程序的基本组成单元之一,可以接受输入参数,执行特定的操作,并返回结果,其目的是封装一段可重复使用的代码,提高代码的可重用性和可维护性。

在mysql中,可以利用char()和REPLACE()函数来替换换行符;REPLACE()函数可以用新字符串替换列中的换行符,而换行符可使用“char(13)”来表示,语法为“replace(字段名,char(13),'新字符串') ”。

在这篇文章中,我们将向你展示如何通过拖放在PowerQuery中对多列进行重新排序。通常,从各种来源导入数据时,列可能不是所需的顺序。重新排序列不仅允许您按照符合您的分析或报告需求的逻辑顺序排列它们,还可以提高数据的可读性,并加快过滤、排序和执行计算等任务。如何在Excel中重新排列多个列?在Excel中,重新排列列的方法有多种。您可以简单地选择列标题,然后将其拖动到所需位置。但是,当处理包含许多列的大表时,这种方法可能会变得繁琐。为了更高效地重新排列列,您可以使用增强查询编辑器。通过增强查询编

转换方法:1、利用cast函数,语法“select * from 表名 order by cast(字段名 as SIGNED)”;2、利用“select * from 表名 order by CONVERT(字段名,SIGNED)”语句。

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了关于MySQL复制技术的相关问题,包括了异步复制、半同步复制等等内容,下面一起来看一下,希望对大家有帮助。

ReactQuery数据库插件:实现数据导入和导出的方法,需要具体代码示例随着ReactQuery在前端开发中的广泛应用,越来越多的开发者开始使用它来管理数据。而在实际开发中,我们经常需要将数据导出到本地文件或从本地文件导入数据到数据库中。为了更方便地实现这些功能,可以使用ReactQuery数据库插件。ReactQuery数据库插件提供了一系列方

本篇文章给大家带来了关于mysql的相关知识,其中主要介绍了mysql高级篇的一些问题,包括了索引是什么、索引底层实现等等问题,下面一起来看一下,希望对大家有帮助。

在mysql中,可以利用REGEXP运算符判断数据是否是数字类型,语法为“String REGEXP '[^0-9.]'”;该运算符是正则表达式的缩写,若数据字符中含有数字时,返回的结果是true,反之返回的结果是false。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

MinGW - Minimalist GNU for Windows
This project is in the process of being migrated to osdn.net/projects/mingw, you can continue to follow us there. MinGW: A native Windows port of the GNU Compiler Collection (GCC), freely distributable import libraries and header files for building native Windows applications; includes extensions to the MSVC runtime to support C99 functionality. All MinGW software can run on 64-bit Windows platforms.

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

VSCode Windows 64-bit Download
A free and powerful IDE editor launched by Microsoft

Notepad++7.3.1
Easy-to-use and free code editor
