PHP Mysqli common code collection

迷茫
Release: 2023-03-05 10:40:02
Original
2394 people have browsed it

Starting with PHP 5.0, you can not only use the early mysql database extension functions, but also use the newly expanded mysqli technology to communicate with the mysql database. PHP's mysqli extension is encapsulated in a class, which is an object-oriented technology. , can only be used in PHP5 and MYSQL4,1 or higher versions, (i) indicates that it should be entered, using mysqli, the execution speed is faster, more convenient, more efficient, and can also make database access safer (because the class mode is used )

Simple process using mysqli

Set PHP.ini configuration file
extension=php_mysqli.dll

//Create connection

$conn = new mysqli($servername, $username, $password, $dbname);
Copy after login

//Detect connection

if ($conn->connect_error)  
{ 
  die("Connection failed: " . $conn->connect_error); 
}
Copy after login

//Get the database return value

if($stmt=$con->prepare("SELECT username,password FROM member WHERE username=? AND password=?")) 
{ 
  $stmt->bind_param("ss",$username,$password); 
  $stmt->execute(); 
  $stmt->bind_result($U,$P); 
  $HasData=false; 
  while($stmt->fetch()) 
  { 
    $HasData=true; 
    echo "username->".$U." password->".$P."<br>"; 
  } 
}
Copy after login

//Close the connection

$conn->close();
Copy after login

//Common syntax
INSERT INTO [table name] ([field 1],[field 2]) VALUES ([value 1],[value 2]);
SELECT * FROM [table name] WHERE [expression] ORDER BY [field 1],[ASC/DESC rise/fall] [field 2],[ASC/DESC rise/fall];
DELETE FROM [table name] WHERE [expression];
UPDATE [table name] SET [field 1]=[value 1],[field 2]=[value 2] WHERE [expression];
Get the total number of rows: SELECT COUNT(*) FROM [table]

//Chinese garbled

//针对页面 
header("Content-Type:text/html;charset=utf-8"); 
//针对数据库 
mysqli->query("SET CHARACTER SET 'utf8'");//读库  
mysqli->query("SET NAMES 'utf8'");//写库
Copy after login

Here are some examples

Connect to mysqli

Create MYSQL configuration file config.ini.php

The content of config.ini.php is as follows:

<?php 
 $dbhost ="locallhost";
 $dbuser = "hehehe";
 $dbpwd = "123456";
 $dbname = "Student";
 $charName = "gbk2312"; 设置查询字符集gbk,gbk2312,utf-8
?>
Copy after login

(Use mysqli to connect to the MYSQL database)

requery_once("config.ini.php");
$mysqliObj = new mysqli($dbhost,$dbuser,$dbpwd,$dbname);
if(mysqli_connect_errno()){
 echo "连接失败".mysqli_connect_error();
 exit();
}
$mysqliObj->query("set name $charName");
Copy after login

(Other operations)

Inquire

(单条查询)
$sql = "drop table if exists user;";
$mysqliObj->query($sql);
  
(多条查询)
$musqliObj->multip_query($sql)
  
 
返回执行$sql受影响的行数()
  
if($mysqliObj->query($sql))
echo $mysqliObj->affected_rows;
  
insert 插入时,返回插入的id (很有用) 
 
 $num = $mysqliObj->insert_id;
Copy after login

Three types of processing query results

$sql = "select * from user";
 $result = $mysqli->query($sql);
  
(1)fetch_row()  返回索引数组
fetch_row()
while(list($id,$name,$pwd)=$result->fetch_row()){
echo "id: ".$id." name:".$name." pwd:".$pwd."<br>";
  
}
(2)fetch_assoc() 返回关联数组
fetch_assoc()
while ($row = $result->fetch_assoc()){
 echo "id:".$row["userId"]." name:".$row["userName"]." pwd:".$row["password"]."<br>";
}
  
(3)fetch_object()返回对象
while($row = $result->fetch_object()){
echo "id:".$row->userId." name:".$row->uerName." pwd:".$row->password."<br>";
  
}
Copy after login

Associative arrays are nested arrays, such as:

<?php
$data = array(
     array('name' => 'John Smith', 'home' => '555-555-5555',
        'cell' => '666-555-5555', 'email' => 'john@myexample.com'),
     array('name' => 'Jack Jones', 'home' => '777-555-5555',
        'cell' => '888-555-5555', 'email' => 'jack@myexample.com'),
     array('name' => 'Jane Munson', 'home' => '000-555-5555',
        'cell' => '123456', 'email' => 'jane@myexample.com')
    );
 
?>
Copy after login

Use mysqli_stmt class

Mysql4.1 version began to provide a preprocessing (prepared statement) mechanism, which can see the entire command sent to the MYSQL server once. Only the parameters will change in the future. MYSQL only needs to analyze the command once, which greatly reduces the need for transmission. The amount of data also improves the processing efficiency of commands (note, close() should be closed immediately when the connection is not needed)

step:

1. Prepare SQL commands
$sql = "insert into user(name,pwd) values(?,?)";
$stms = $mysqli->prepare($sql);
2. Bind data
$stms->bind_param('ss',$name,$pwd); (Note 'ss': it must correspond to the following variables ($name,$pwd)
                                                                                                                                                                 because Dough or float type
                                                                                                                                                                            s b Binary (blob, binary byte string)
                                                                                                    )
$name = "huang";
$pwd = "123456";
3.Execute
$stms->execute();
[4. Execute another set of data in the binding
$name = "he";
$pwd = "666666";
$stms->execute();
]
5.Close
$stmt->close();
$mysqli->close();

(Other useful parameters)
$num = $stmt->affected_rows; Number of rows affected
$id = $stmt->insert_id; When it is an insert command, return the inserted row id (automatic)

事务处理

在默认情况下,MYSQL是以自动提交(autocommit)模式运行,这就意味着所执行的每一个语句都将立即写入数据库中,但如果使用事务安全的表格类型,是不希望自动提交的行为的
事务处理
当执行多条MYSQL命令时,当然希望当其中一条命令出错时,所有的命令都不执行,返回执行命令之前的状态
这就用到事务了

简单运用事务流程
1.写好SQL命令
$sql1 = "insert user(name) values('huang','123456')";
$sql2 = "update account set number = number+1";
2.关闭MYSQL事务处理的自动提交模式
$mysqli->cutocommit(0);
3.试执行命令
$success = true;
$res1 = $mysqli->query($sql1);
if(!$res1 or $mysqli->affected_rows !=1){
$success = false;
}
$res2 = $mysqli->query($sql2);
if(!$res2 or $mysqli->affected_rows !=1){
$success = false;
}
4.查看执行情况,都成功执行,有失败回滚初态
if($success ){
$mysqli->commit();
echo "执行成功";
}else{
$mysqli->rollback();
echo "执行失败";
}
5.恢复MYSQL事务处理的自动提交模式
$mysqli->cutocommit(1);
$mysqli->close();

mysql 目前只有InnDB和BDB两种数据包类型才支持事务
InnoDB最快
(创建InnDB类型表)

create table user(
id int(10) not null auto_increment,
name varchar(50) not null,
pwd varchar(50) not null,
primary key(id)
)type=InnoDB
Copy after login
Related labels:
source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template
About us Disclaimer Sitemap
php.cn:Public welfare online PHP training,Help PHP learners grow quickly!