當前位置: 首頁>>代碼示例>>C#>>正文


C# MySqlClient.MySqlPacket類代碼示例

本文整理匯總了C#中MySql.Data.MySqlClient.MySqlPacket的典型用法代碼示例。如果您正苦於以下問題:C# MySqlPacket類的具體用法?C# MySqlPacket怎麽用?C# MySqlPacket使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


MySqlPacket類屬於MySql.Data.MySqlClient命名空間,在下文中一共展示了MySqlPacket類的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: MySqlException

		void IMySqlValue.WriteValue(MySqlPacket packet, bool binary, object val, int length)
		{
			if (!(val is TimeSpan))
				throw new MySqlException("Only TimeSpan objects can be serialized by MySqlTimeSpan");

			TimeSpan ts = (TimeSpan)val;
			bool negative = ts.TotalMilliseconds < 0;
			ts = ts.Duration();

			if (binary)
			{
				packet.WriteByte(8);
				packet.WriteByte((byte)(negative ? 1 : 0));
				packet.WriteInteger(ts.Days, 4);
				packet.WriteByte((byte)ts.Hours);
				packet.WriteByte((byte)ts.Minutes);
				packet.WriteByte((byte)ts.Seconds);
			}
			else
			{
				String s = String.Format("'{0}{1} {2:00}:{3:00}:{4:00}.{5}'",
					negative ? "-" : "", ts.Days, ts.Hours, ts.Minutes, ts.Seconds, ts.Milliseconds);

				packet.WriteStringNoNull(s);
			}
		}
開發者ID:seeseekey,項目名稱:CSCL,代碼行數:26,代碼來源:MySqlTime.cs

示例2:

 void IMySqlValue.WriteValue(MySqlPacket packet, bool binary, object val, int length)
 {
   var v = (val is double) ? (double)val : Convert.ToDouble(val);
   if (binary)
     packet.Write(BitConverter.GetBytes(v));
   else
     packet.WriteStringNoNull(v.ToString("R", CultureInfo.InvariantCulture));
 }
開發者ID:RoxyLalonde,項目名稱:Phoenix-Realms,代碼行數:8,代碼來源:MySqlDouble.cs

示例3:

 void IMySqlValue.WriteValue(MySqlPacket packet, bool binary, object val, int length)
 {
   ulong v = (val is ulong) ? (ulong)val : Convert.ToUInt64(val);
   if (binary)
     packet.WriteInteger((long)v, 8);
   else
     packet.WriteStringNoNull(v.ToString());
 }
開發者ID:Jankos132,項目名稱:Server-Source,代碼行數:8,代碼來源:MySqlUInt64.cs

示例4:

 void IMySqlValue.WriteValue(MySqlPacket packet, bool binary, object val, int length)
 {
   int v = (val is Int32) ? (int)val : Convert.ToInt32(val);
   if (binary)
     packet.WriteInteger((long)v, 2);
   else
     packet.WriteStringNoNull(v.ToString());
 }
開發者ID:Jankos132,項目名稱:Server-Source,代碼行數:8,代碼來源:MySqlInt16.cs

示例5:

 void IMySqlValue.WriteValue(MySqlPacket packet, bool binary, object val, int length)
 {
   var v = (val is Int64) ? (Int64)val : Convert.ToInt64(val);
   if (binary)
     packet.WriteInteger(v, 8);
   else
     packet.WriteStringNoNull(v.ToString());
 }
開發者ID:RoxyLalonde,項目名稱:Phoenix-Realms,代碼行數:8,代碼來源:MySqlInt64.cs

示例6: WriteValue

 public void WriteValue(MySqlPacket packet, bool binary, object value, int length)
 {
   ulong v = (value is UInt64) ? (UInt64)value : Convert.ToUInt64(value);
   if (binary)
     packet.WriteInteger((long)v, 8);
   else
     packet.WriteStringNoNull(v.ToString());
 }
開發者ID:exaphaser,項目名稱:JSC-Cross-Compiler,代碼行數:8,代碼來源:MySqlBit.cs

示例7:

		void IMySqlValue.WriteValue(MySqlPacket packet, bool binary, object val, int length)
		{
			byte v = (val is byte) ? (byte)val : Convert.ToByte(val);
			if (binary)
				packet.WriteByte(v);
			else
				packet.WriteStringNoNull(v.ToString());
		}
開發者ID:seeseekey,項目名稱:CSCL,代碼行數:8,代碼來源:MySqlUByte.cs

示例8: ExecuteStatement

        public override void ExecuteStatement(MySqlPacket packetToExecute)
        {
            base.ExecuteStatement(packetToExecute);
            int pos = packetToExecute.Position;
            packetToExecute.Position = 1;
            int statementId = packetToExecute.ReadInteger(4);
            packetToExecute.Position = pos;

            MySqlTrace.TraceEvent(TraceEventType.Information, MySqlTraceEventType.StatementExecuted,
                Resources.TraceStatementExecuted, driverId, statementId, ThreadID);
        }
開發者ID:NoxHarmonium,項目名稱:rmitjourneyplanner,代碼行數:11,代碼來源:TracingDriver.cs

示例9: MySqlStream

        public MySqlStream(Encoding encoding)
        {
            // we have no idea what the real value is so we start off with the max value
              // The real value will be set in NativeDriver.Configure()
              maxPacketSize = ulong.MaxValue;

              // we default maxBlockSize to MaxValue since we will get the 'real' value in
              // the authentication handshake and we know that value will not exceed
              // true maxBlockSize prior to that.
              maxBlockSize = Int32.MaxValue;

              packet = new MySqlPacket(encoding);
        }
開發者ID:Arksutw,項目名稱:mysql-dnxcore50,代碼行數:13,代碼來源:MySqlStream.cs

示例10:

    void IMySqlValue.WriteValue(MySqlPacket packet, bool binary, object val, int length)
    {
      string v = val.ToString();
      if (length > 0)
      {
        length = Math.Min(length, v.Length);
        v = v.Substring(0, length);
      }

      if (binary)
        packet.WriteLenString(v);
      else
        packet.WriteStringNoNull("'" + MySqlHelper.EscapeString(v) + "'");
    }
開發者ID:exaphaser,項目名稱:JSC-Cross-Compiler,代碼行數:14,代碼來源:MySqlString.cs

示例11: SendQuery

    public override void SendQuery(MySqlPacket p)
    {
      rowSizeInBytes = 0;
      string cmdText = Encoding.GetString(p.Buffer, 5, p.Length - 5);
      string normalized_query = null;

      if (cmdText.Length > 300)
      {
        QueryNormalizer normalizer = new QueryNormalizer();
        normalized_query = normalizer.Normalize(cmdText);
        cmdText = cmdText.Substring(0, 300);
      }

      base.SendQuery(p);

      MySqlTrace.TraceEvent(TraceEventType.Information, MySqlTraceEventType.QueryOpened,
          Resources.TraceQueryOpened, driverId, ThreadID, cmdText);
      if (normalized_query != null)
        MySqlTrace.TraceEvent(TraceEventType.Information, MySqlTraceEventType.QueryNormalized,
            Resources.TraceQueryNormalized, driverId, ThreadID, normalized_query);
    }
開發者ID:jimmy00784,項目名稱:mysql-connector-net,代碼行數:21,代碼來源:TracingDriver.cs

示例12: MySqlBinary

        IMySqlValue IMySqlValue.ReadValue(MySqlPacket packet, long length, bool nullVal)
        {
            MySqlBinary b;
            if (nullVal)
                b = new MySqlBinary(type, true);
            else
            {
                if (length == -1)
                    length = (long)packet.ReadFieldLength();

                byte[] newBuff = new byte[length];
                packet.Read(newBuff, 0, (int)length);
                b = new MySqlBinary(type, newBuff);
            }
            return b;
        }
開發者ID:NoxHarmonium,項目名稱:rmitjourneyplanner,代碼行數:16,代碼來源:MySqlBinary.cs

示例13: MySqlByte

        IMySqlValue IMySqlValue.ReadValue(MySqlPacket packet, long length, bool nullVal)
        {
            if (nullVal)
                return new MySqlByte(true);

            if (length == -1)
                return new MySqlByte((sbyte)packet.ReadByte());
            else
            {
                string s = packet.ReadString(length);
                MySqlByte b = new MySqlByte(SByte.Parse(s, NumberStyles.Any, CultureInfo.InvariantCulture));
                b.TreatAsBoolean = TreatAsBoolean;
                return b;
            }
        }
開發者ID:BGCX261,項目名稱:zp-mysql-data-svn-to-git,代碼行數:15,代碼來源:MySqlByte.cs

示例14: SendPacket

        public void SendPacket(MySqlPacket packet)
        {
            byte[] buffer = packet.Buffer;
            int length = packet.Position-4;

            if ((ulong)length > maxPacketSize)
                throw new MySqlException(Resources.QueryTooLarge, (int)MySqlErrorCode.PacketTooLarge);

            int offset = 0;
            while (length > 0)
            {
                int lenToSend = length > maxBlockSize ? maxBlockSize : length;
                buffer[offset] = (byte)(lenToSend & 0xff);
                buffer[offset+1] = (byte)((lenToSend >> 8) & 0xff);
                buffer[offset+2] = (byte)((lenToSend >> 16) & 0xff);
                buffer[offset+3] = sequenceByte++;

                outStream.Write(buffer, offset, lenToSend + 4);
                outStream.Flush();
                length -= lenToSend;
                offset += lenToSend;
            }
        }
開發者ID:elevate,項目名稱:mysqlconnector-.net,代碼行數:23,代碼來源:MySqlStream.cs

示例15: Prepare

    public virtual void Prepare()
    {
      // strip out names from parameter markers
      string text;
      List<string> parameter_names = PrepareCommandText(out text);

      // ask our connection to send the prepare command
      MySqlField[] paramList = null;
      statementId = Driver.PrepareStatement(text, ref paramList);

      // now we need to assign our field names since we stripped them out
      // for the prepare
      for (int i = 0; i < parameter_names.Count; i++)
      {
        //paramList[i].ColumnName = (string) parameter_names[i];
        string parameterName = (string)parameter_names[i];
        MySqlParameter p = Parameters.GetParameterFlexible(parameterName, false);
        if (p == null)
          throw new InvalidOperationException(
              String.Format(Resources.ParameterNotFoundDuringPrepare, parameterName));
        p.Encoding = paramList[i].Encoding;
        parametersToSend.Add(p);
      }

      // now prepare our null map
      int numNullBytes = 0;
      if (paramList != null && paramList.Length > 0)
      {
        nullMap = new BitArray(paramList.Length);
        numNullBytes = (nullMap.Count + 7) / 8;
      }

      packet = new MySqlPacket(Driver.Encoding);

      // write out some values that do not change run to run
      packet.WriteByte(0);
      packet.WriteInteger(statementId, 4);
      packet.WriteByte((byte)0); // flags; always 0 for 4.1
      packet.WriteInteger(1, 4); // interation count; 1 for 4.1
      nullMapPosition = packet.Position;
      packet.Position += numNullBytes;  // leave room for our null map
      packet.WriteByte(1); // rebound flag
      // write out the parameter types
      foreach (MySqlParameter p in parametersToSend)
        packet.WriteInteger(p.GetPSType(), 2);
      dataPosition = packet.Position;
    }
開發者ID:jimmy00784,項目名稱:mysql-connector-net,代碼行數:47,代碼來源:PreparableStatement.cs


注:本文中的MySql.Data.MySqlClient.MySqlPacket類示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。