Home Database Mysql Tutorial php-mysql扩展的mysql

php-mysql扩展的mysql

Jun 07, 2016 pm 03:20 PM
linux mysql Expand Enter

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入 今天我们来探讨一下php-mysql扩展的mysql_connect/mysql_pconnect比较 item mysql_connect mysql_pconnect 函数原型 resource mysql_connect($host_port, $user, $passwd, $newlink, $client_flags);

欢迎进入Linux社区论坛,与200万技术人员互动交流 >>进入

  今天我们来探讨一下php-mysql扩展的mysql_connect/mysql_pconnect比较

item

mysql_connect

mysql_pconnect

函数原型

resource mysql_connect($host_port, $user, $passwd, $newlink, $client_flags);

第四个参数$newlink标记是否创建新的资源对象

resource mysql_pconnect($host_port, $user, $passwd, $client_flags);

allow_persistent指令

设置此指令使得两个函数行为均和mysql_connect()一致

连接资源对象获取

  1. $host_port, $user, $passwd, $client_flags求哈希值
  2. 在普通资源列表(EG(regular_list))中查找连接对象(已找到并且没有设置$newlink强制创建新连接)
  3. 检查找到的对象是否资源类型
  4. 从查找到的对象中读取连接对象
  5. 将当前获取的连接对象设置为全局默认连接对象
  6. 增加连接对象的引用计数, 设置zval属性返回
  1. $host_port, $user, $passwd, $client_flags求哈希值
  2. 从持久化资源列表(EG(persist_list))中查找连接对象(没有找到)
  3. 检查max_links配置指令限制是否到达
  4. 检查max_persistent配置指令限制是否到达
  5. 分配连接对象(php_mysql_conn)空间
  6. 设置连接对象的基础属性
  7. 初始化驱动层连接对象(mysqlnd/libmysql两种方式)
  8. 设置连接超时时间
  9. 发起驱动层的真实连接请求
  10. 构造持久化列表元素对象, 将新连接对象设置到元素中
  11. 将连接对象更新到持久化列表中
  12. 更新(增加)num_persistent/num_links计数
  13. 注册资源类型返回值
  14. 将当前获取的连接设置为全局默认连接对象
  1. $host_port, $user, $passwd, $client_flags求哈希值
  2. 在普通资源列表(EG(regular_list))中查找连接对象(未找到或设置了$newlink强制创建新连接)
  3. 检查max_links配置指令限制
  4. 分配连接对象(php_mysql_conn)空间
  5. 设置连接对象基础属性
  6. 初始化驱动层连接对象(mysqlnd/libmysql)
  7. 设置连接超时时间
  8. 发起驱动层的真实连接
  9. 将连接对象注册为资源类型返回值
  10. 将连接对象更新到普通资源列表(EG(regualr_list))
  11. 更新num_links计数
  12. 将当前获取的连接对象设置为全局默认连接对象
  1. $host_port, $user, $passwd, $client_flags求哈希值
  2. 从持久化资源列表中查找连接对象(已找到)
  3. 检查查找到的持久化资源的类型是否匹配
  4. 从持久化资源中读取连接对象
  5. 设置连接对象基本属性
  6. 检查服务端是否主动关闭
  7. 如果服务端主动关闭则进行重连
  8. 注册资源类型返回值
  9. 将当前获取的连接设置为全局默认连接对象

regular_list Vs. persistent_list

  1. regular_listpersistent_list两者都是HashTable
  2. 两者都是执行全局环境executor_globals的成员
  3. 两者生命周期不同, regular_listphp_request_shutdown()时被释放, 也就是单个请求处理完成之后释放, persistent_listphp_module_shutdown()的时候调用zend_shutdown()释放, 也就是在整个进程完成执行时释放

php-mysql扩展的mysql

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

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Roblox: Bubble Gum Simulator Infinity - How To Get And Use Royal Keys
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌
Nordhold: Fusion System, Explained
3 weeks ago By 尊渡假赌尊渡假赌尊渡假赌

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

Hot Topics

Java Tutorial
1664
14
PHP Tutorial
1269
29
C# Tutorial
1249
24
MySQL and phpMyAdmin: Core Features and Functions MySQL and phpMyAdmin: Core Features and Functions Apr 22, 2025 am 12:12 AM

MySQL and phpMyAdmin are powerful database management tools. 1) MySQL is used to create databases and tables, and to execute DML and SQL queries. 2) phpMyAdmin provides an intuitive interface for database management, table structure management, data operations and user permission management.

Explain the purpose of foreign keys in MySQL. Explain the purpose of foreign keys in MySQL. Apr 25, 2025 am 12:17 AM

In MySQL, the function of foreign keys is to establish the relationship between tables and ensure the consistency and integrity of the data. Foreign keys maintain the effectiveness of data through reference integrity checks and cascading operations. Pay attention to performance optimization and avoid common errors when using them.

Docker on Linux: Containerization for Linux Systems Docker on Linux: Containerization for Linux Systems Apr 22, 2025 am 12:03 AM

Docker is important on Linux because Linux is its native platform that provides rich tools and community support. 1. Install Docker: Use sudoapt-getupdate and sudoapt-getinstalldocker-cedocker-ce-clicotainerd.io. 2. Create and manage containers: Use dockerrun commands, such as dockerrun-d--namemynginx-p80:80nginx. 3. Write Dockerfile: Optimize the image size and use multi-stage construction. 4. Optimization and debugging: Use dockerlogs and dockerex

Compare and contrast MySQL and MariaDB. Compare and contrast MySQL and MariaDB. Apr 26, 2025 am 12:08 AM

The main difference between MySQL and MariaDB is performance, functionality and license: 1. MySQL is developed by Oracle, and MariaDB is its fork. 2. MariaDB may perform better in high load environments. 3.MariaDB provides more storage engines and functions. 4.MySQL adopts a dual license, and MariaDB is completely open source. The existing infrastructure, performance requirements, functional requirements and license costs should be taken into account when choosing.

SQL vs. MySQL: Clarifying the Relationship Between the Two SQL vs. MySQL: Clarifying the Relationship Between the Two Apr 24, 2025 am 12:02 AM

SQL is a standard language for managing relational databases, while MySQL is a database management system that uses SQL. SQL defines ways to interact with a database, including CRUD operations, while MySQL implements the SQL standard and provides additional features such as stored procedures and triggers.

How to understand DMA operations in C? How to understand DMA operations in C? Apr 28, 2025 pm 10:09 PM

DMA in C refers to DirectMemoryAccess, a direct memory access technology, allowing hardware devices to directly transmit data to memory without CPU intervention. 1) DMA operation is highly dependent on hardware devices and drivers, and the implementation method varies from system to system. 2) Direct access to memory may bring security risks, and the correctness and security of the code must be ensured. 3) DMA can improve performance, but improper use may lead to degradation of system performance. Through practice and learning, we can master the skills of using DMA and maximize its effectiveness in scenarios such as high-speed data transmission and real-time signal processing.

MySQL: The Database, phpMyAdmin: The Management Interface MySQL: The Database, phpMyAdmin: The Management Interface Apr 29, 2025 am 12:44 AM

MySQL and phpMyAdmin can be effectively managed through the following steps: 1. Create and delete database: Just click in phpMyAdmin to complete. 2. Manage tables: You can create tables, modify structures, and add indexes. 3. Data operation: Supports inserting, updating, deleting data and executing SQL queries. 4. Import and export data: Supports SQL, CSV, XML and other formats. 5. Optimization and monitoring: Use the OPTIMIZETABLE command to optimize tables and use query analyzers and monitoring tools to solve performance problems.

macOS vs. Linux: Exploring the Differences and Similarities macOS vs. Linux: Exploring the Differences and Similarities Apr 25, 2025 am 12:03 AM

macOSandLinuxbothofferuniquestrengths:macOSprovidesauser-friendlyexperiencewithexcellenthardwareintegration,whileLinuxexcelsinflexibilityandcommunitysupport.macOS,developedbyApple,isknownforitssleekinterfaceandecosystemintegration,whereasLinux,beingo

See all articles