Maison > base de données > tutoriel mysql > Introduction détaillée au package ColumnCount et analyse du protocole mysql

Introduction détaillée au package ColumnCount et analyse du protocole mysql

黄舟
Libérer: 2017-03-07 13:30:08
original
1456 Les gens l'ont consulté


git

https://github.com/sea-boat/mysql-protocol

Présentation

Le package ColumnCount est l'un des packages lorsque le serveur renvoie ResultSet.

Structure du message de communication MySQL

Type Nom Description th >
int<3> la longueur de la charge utile est stockée en fonction de l'octet de poids faible en premier, 3 mots La charge utile de la strophe et le numéro de séquence de 1 octet sont combinés dans un en-tête de message
int<1> Numéro de série
类型 名字 描述
int<3> payload长度 按照the least significant byte first存储,3个字节的payload和1个字节的序列号组合成报文头
int<1> 序列号
string payload 报文体,长度即为前面指定的payload长度
chaîne charge utile Corps du message, la longueur est la longueur de la charge utile précédemment spécifiée tr>

Package ColumnCount

Charge utile

Protocol::LengthEncodedInteger
Copier après la connexion

Plus de détails : http : / /dev.mysql.com/doc/internals/en/com-query-response.html#packet-ProtocolText::ResultsetRow

Classe de package ColumnCount

/**
 * 
 * <pre class="brush:php;toolbar:false"><b>column count packet.</b>
* @author *
seaboat
*
<b>email: </b>849586227@qq.com
*
<b>blog: </b>http://www.php.cn/;/pre>
 * @version 1.0
 * @see http://www.php.cn/
 */public class ColumnCountPacket extends MySQLPacket {

    public int columnCount;    
    public void read(byte[] data) {
        MySQLMessage mm = new MySQLMessage(data);        
        this.packetLength = mm.readUB3();        
        this.packetId = mm.read();        
        this.columnCount = (int) mm.readLength();
    }    
    @Override
    public void write(ByteBuffer buffer) {        
    int size = calcPacketSize();
        BufferUtil.writeUB3(buffer, size);
        buffer.put(packetId);
        BufferUtil.writeLength(buffer, columnCount);
    }    
    @Override
    public int calcPacketSize() {        
    int size = BufferUtil.getLength(columnCount);        
    return size;
    }    @Override
    protected String getPacketInfo() {        
    return "MySQL Column Count Packet";
    }

}
Copier après la connexion

Ce qui précède est un introduction détaillée à mysql Le package ColumnCount et le contenu analysé du protocole, veuillez faire attention au site Web PHP chinois (www.php.cn) pour plus de contenu connexe !

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal