一介简介的Mysql封装类
mysql|封装
class_mysql.php
//######################################################################
//##### TITLE :: CLASS MYSQL
//##### FILE :: class_mysql.php
//##### PROJECT :: WebVision
//##### RELATED DOCUMENT :: None
//##### DESCRIPTION ::
//##### To provide access utility for MySQL access
//##### RunDB is used to run SQL query with the result
//##### grouped into array.
//##### AUTHOR :: Mark Quah
//##### REVISION ::
//######################################################################
class MYSQL
{
var $no_rows=0, $row=array();
var $no_fields=0, $field=array();
//#-----------------------------------------------------------------
//#---- FUNCTION :: MYSQL($p_host, $p_user, $p_passwd, $p_db="mysql")
//#---- DESCRIPTION ::
//#---- Initialize class with information to access server
//#---- No connection will be made at this point.
//#---- INPUT ::
//#---- p_host : server hostname|IP address
//#---- p_user : user name to log into server
//#---- p_passwd : passwd for the user
//#---- p_db : database to be used
//#---- OUTPUT ::
//#---- none
//#-----------------------------------------------------------------
function MYSQL($p_host, $p_user, $p_passwd, $p_db="mysql")
{
$this->sql_host = $p_host;
$this->sql_user= $p_user;
$this->sql_passwd = $p_passwd;
$this->sql_db = $p_db;
} // end MYSQL
//#-----------------------------------------------------------------
//#---- FUNCTION :: RunDB($statement, $exp_result = "")
//#---- DESCRIPTION ::
//#---- Execute a MySQL statement in a non-persistant mode
//#---- INPUT ::
//#---- p_statement : statement to be executed
//#---- exp_result : is result expected?
//#---- value 1 (default): result stored in row array
//#---- value 0: result not stored in row array
//#---- OUTPUT ::
//#---- return "OK" : succesful
//#---- return err_message from mysql_connect
//#---- exp_result==1: additional result stored into array row
//#---- no_row contains no. of record retrieved
//#---- row[recno][ "field" ] contains value of recno record
//#---- field["fieldname"] contains the field list
//#-----------------------------------------------------------------
function RunDB($p_statement, $exp_result = 1)
{
//--- Connect to the Database
$link=mysql_connect($this->sql_host, $this->sql_user, $this->sql_passwd);
if (!$link)
return sprintf("error connecting to host %s, by user %s",
$this->sql_host, $this->sql_user) ;
//--- Select the Database
if (!mysql_select_db($this->sql_db, $link))
{ $err_msg=sprintf("Error in selecting %s database",
$this->sql_db);
$err_msg .= sprintf("error:%d %s", mysql_errno($link),
mysql_error($link));
return $err_msg;
}
//--- Execute the Statement
if (!($this->result=mysql_query($p_statement, $link)))
{ $err_msg=sprintf("Error in selecting %s database\n",
$this->sqldb);
$err_msg .= sprintf("\terror:%d\t\nerror message %s",
mysql_errno($link), mysql_error($link));
return $err_msg;
}
//--- Organize the result
if ($exp_result == 1)
{ $this->no_rows = mysql_num_rows($this->result);
$this->GroupResult();
}
//--- SUCCESS RETURN
return OK;
} // end function RunDB
//#-----------------------------------------------------------------
//#---- FUNCTION :: GroupResult( )
//#---- DESCRIPTION ::
//#---- To group the raw result retrieved in an associative array
//#---- A query has to be made using RunDB prior to this execution
//#---- The handle is storedin $result
//#---- INPUT :: None
//#---- OUTPUT :
//#---- return none
//#---- additional result stored into array
//#---- no_row, row[recno]["field"] = value
//#---- no_field, field["fieldname"]
//#-----------------------------------------------------------------
function GroupResult()
{
//--- Get RESULT
$is_header = FALSE;
for ( $recno = 0; $recno no_rows; $recno ++ )
{ $row = mysql_fetch_object($this->result);
//--- Get Field List
if ( ! $is_header )
{ $no_fields = 0;
$t_row = $row;
while ( $item = each($t_row) )
{ $this->field[$no_fields] = $item["key"];
$no_fields ++;
}
$this->no_fields = $no_fields;
$is_header = TRUE;
}
//---- GET DATA
while ( $item = each($row))
$this->row[$recno][$item["key"]] = $item["value"];
}
//--- END CONNECTION
mysql_free_result($this->result);
} // GroupResult
//#-----------------------------------------------------------------
//#---- FUNCTION :: ShowHTML($p_table="", $p_header = "", $p_cell = "")
//#---- DESCRIPTION ::
//#---- To return the result in HTML Table format
//#---- INPUT ::
//#---- p_table : HTML
recno"; for ($i = 0; $i no_fields; $i ++) printf(" |
%s", $this->field[$i]); //--- DISPLAY DATA for ( $i = 0; $i no_rows; $i ++) { echo " |
%-3s", $i); for ($f = 0; $f no_fields; $f ++) { $f_name = $this->field[$f]; $f_value = $this->row[$i][$f_name]; if ( $f_value=="" ) $f_value=" "; printf(" |
%s", $f_value); } } //--- THE END echo " |
} // ShowHTML
} // end class MYSQL
?>
例子:
include("class_mysql.php");
//===== set up sql connection
$mysql=new MYSQL("server", "mysql userid", "mysql passwd", "mysql DB");
//==== Extract Result
$status = $mysql->RunDB("select * from user;");
if ($status != "OK")
{ echo "
DB Error: $status.
";
die;
}
for ($i = 0; $i no_rows; $i ++)
{
echo "Record No: " . ($i + 1) ."
";
for ($j = 0; $j no_fields; $j ++)
{
$field_name = $mysql->field[$j];
echo "Field: ".$field_name." ----- Value: ".
$mysql->row[$i][$field_name]."
";
}
}
//==== Use the built-in ShowHTML format
$status = $mysql->RunDB("select * from user;");
if ($status != "OK")
{ echo "
DB Error: $status.
";
die;
}
$mysql->ShowHTML("","","CENTER");
//==== Run some query not expecting results
$stmt = ("FILL IN YOUR STAEMENT eg. INSERT INTO");
$status = $myql->RunDB($stmt, 0);
if ($status
if ($status != "OK")
{ echo "
DB Fail: $status.
";
die;
}
else
{ echo "
Success: $status.
";
die;
}
?>

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

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

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics



In MySQL database, the relationship between the user and the database is defined by permissions and tables. The user has a username and password to access the database. Permissions are granted through the GRANT command, while the table is created by the CREATE TABLE command. To establish a relationship between a user and a database, you need to create a database, create a user, and then grant permissions.

MySQL is suitable for beginners because it is simple to install, powerful and easy to manage data. 1. Simple installation and configuration, suitable for a variety of operating systems. 2. Support basic operations such as creating databases and tables, inserting, querying, updating and deleting data. 3. Provide advanced functions such as JOIN operations and subqueries. 4. Performance can be improved through indexing, query optimization and table partitioning. 5. Support backup, recovery and security measures to ensure data security and consistency.

Data Integration Simplification: AmazonRDSMySQL and Redshift's zero ETL integration Efficient data integration is at the heart of a data-driven organization. Traditional ETL (extract, convert, load) processes are complex and time-consuming, especially when integrating databases (such as AmazonRDSMySQL) with data warehouses (such as Redshift). However, AWS provides zero ETL integration solutions that have completely changed this situation, providing a simplified, near-real-time solution for data migration from RDSMySQL to Redshift. This article will dive into RDSMySQL zero ETL integration with Redshift, explaining how it works and the advantages it brings to data engineers and developers.

To fill in the MySQL username and password: 1. Determine the username and password; 2. Connect to the database; 3. Use the username and password to execute queries and commands.

1. Use the correct index to speed up data retrieval by reducing the amount of data scanned select*frommployeeswherelast_name='smith'; if you look up a column of a table multiple times, create an index for that column. If you or your app needs data from multiple columns according to the criteria, create a composite index 2. Avoid select * only those required columns, if you select all unwanted columns, this will only consume more server memory and cause the server to slow down at high load or frequency times For example, your table contains columns such as created_at and updated_at and timestamps, and then avoid selecting * because they do not require inefficient query se

Detailed explanation of database ACID attributes ACID attributes are a set of rules to ensure the reliability and consistency of database transactions. They define how database systems handle transactions, and ensure data integrity and accuracy even in case of system crashes, power interruptions, or multiple users concurrent access. ACID Attribute Overview Atomicity: A transaction is regarded as an indivisible unit. Any part fails, the entire transaction is rolled back, and the database does not retain any changes. For example, if a bank transfer is deducted from one account but not increased to another, the entire operation is revoked. begintransaction; updateaccountssetbalance=balance-100wh

Navicat itself does not store the database password, and can only retrieve the encrypted password. Solution: 1. Check the password manager; 2. Check Navicat's "Remember Password" function; 3. Reset the database password; 4. Contact the database administrator.

SQLLIMIT clause: Control the number of rows in query results. The LIMIT clause in SQL is used to limit the number of rows returned by the query. This is very useful when processing large data sets, paginated displays and test data, and can effectively improve query efficiency. Basic syntax of syntax: SELECTcolumn1,column2,...FROMtable_nameLIMITnumber_of_rows;number_of_rows: Specify the number of rows returned. Syntax with offset: SELECTcolumn1,column2,...FROMtable_nameLIMIToffset,number_of_rows;offset: Skip
