mysql 協定的ResultsetRow套件及解析

黄舟
發布: 2017-03-07 13:19:59
原創
1860 人瀏覽過

git

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

概況

#ResultsetRow包屬於服務端傳回ResultSet時的其中一部分包,用於描述結果集的行記錄。

mysql通訊封包結構

##string payload封包文體,長度即為前面指定的payload長度
類型 名字 描述
#int<3> payload長度 #按照the least significant byte first存儲,3個字節的payload和1個字節的序號組合成報文頭
int<1> #序號
ResultsetRow套件



############### ###Payload#########
if(NULL){  0xfb}else{
  Protocol::LengthEncodedString}
登入後複製
###更多詳情: http://dev.mysql.com/doc/internals/en/com-query-response.html#text-resultset## ####ResultsetRow套件類別###
/**
 * 
 * <pre class="brush:php;toolbar:false"><b>resultset row 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 ResultsetRowPacket extends MySQLPacket {
    private static final byte NULL_MARK = (byte) 251;    
    public int columnCount;    
    public List<byte[]> columnValues;    
    public ResultsetRowPacket() {

    }    
    public ResultsetRowPacket(int columnCount) {        
    this.columnCount = columnCount;
    }    
    @Override
    public void read(byte[] data) {
        MySQLMessage mm = new MySQLMessage(data);
        packetLength = mm.readUB3();
        packetId = mm.read();        
        for (int i = 0; i < columnCount; i++) {
            columnValues.add(mm.readBytesWithLength());
        }
    }    @Override
    public void write(ByteBuffer buffer) {
        BufferUtil.writeUB3(buffer, calcPacketSize());
        buffer.put(packetId);        
        for (int i = 0; i < columnCount; i++) {            
        byte[] fv = columnValues.get(i);            
        if (fv == null) {
                buffer.put(NULL_MARK);
            } else {
                BufferUtil.writeLength(buffer, fv.length);
                buffer.put(fv);
            }
        }
    }    @Override
    public int calcPacketSize() {        
    int size = 0;        
    for (int i = 0; i < columnCount; i++) {            
    byte[] v = columnValues.get(i);
            size += (v == null || v.length == 0) ? 1 : BufferUtil.getLength(v);
        }        return size;
    }    @Override
    protected String getPacketInfo() {        
    return "MySQL Resultset Row Packet";
    }

}
登入後複製
### 以上就是mysql 協定的ResultsetRow套件及解析的內容,更多相關內容請關注PHP中文網(www.php.cn)! ################
相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板