亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? sqliteconvert.cs

?? sqlite 3.3.8 支持加密的版本
?? CS
?? 第 1 頁 / 共 2 頁
字號:
?/********************************************************
 * ADO.NET 2.0 Data Provider for SQLite Version 3.X
 * Written by Robert Simpson (robert@blackcastlesoft.com)
 * 
 * Released to the public domain, use at your own risk!
 ********************************************************/

namespace System.Data.SQLite
{
  using System;
  using System.Runtime.InteropServices;
  using System.Collections.Generic;
  using System.ComponentModel;
  using System.Globalization;
  using System.Text;

#if !PLATFORM_COMPACTFRAMEWORK 
  using System.ComponentModel.Design;
#endif

  /// <summary>
  /// SQLite has very limited types, and is inherently text-based.  The first 5 types below represent the sum of all types SQLite
  /// understands.  The DateTime extension to the spec is for internal use only.
  /// </summary>
  public enum TypeAffinity
  {
    /// <summary>
    /// Not used
    /// </summary>
    Uninitialized = 0,
    /// <summary>
    /// All integers in SQLite default to Int64
    /// </summary>
    Int64 = 1,
    /// <summary>
    /// All floating point numbers in SQLite default to double
    /// </summary>
    Double = 2,
    /// <summary>
    /// The default data type of SQLite is text
    /// </summary>
    Text = 3,
    /// <summary>
    /// Typically blob types are only seen when returned from a function
    /// </summary>
    Blob = 4,
    /// <summary>
    /// Null types can be returned from functions
    /// </summary>
    Null = 5,
    /// <summary>
    /// Used internally by this provider
    /// </summary>
    DateTime = 10,
    /// <summary>
    /// Used internally
    /// </summary>
    None = 11,
  }

  /// <summary>
  /// This implementation of SQLite for ADO.NET can process date/time fields in databases in only one of two formats.  Ticks and ISO8601.
  /// Ticks is inherently more accurate, but less compatible with 3rd party tools that query the database, and renders the DateTime field
  /// unreadable without post-processing.
  /// ISO8601 is more compatible, readable, fully-processable, but less accurate as it doesn't provide time down to fractions of a second.
  /// </summary>
  public enum SQLiteDateFormats
  {
    /// <summary>
    /// Using ticks is more accurate but less compatible with other viewers and utilities that access your database.
    /// </summary>
    Ticks = 0,
    /// <summary>
    /// The default format for this provider.
    /// </summary>
    ISO8601 = 1,
  }

  /// <summary>
  /// Struct used internally to determine the datatype of a column in a resultset
  /// </summary>
  internal struct SQLiteType
  {
    /// <summary>
    /// The DbType of the column, or DbType.Object if it cannot be determined
    /// </summary>
    internal DbType Type;
    /// <summary>
    /// The affinity of a column, used for expressions or when Type is DbType.Object
    /// </summary>
    internal TypeAffinity Affinity;
  }

  internal struct SQLiteTypeNames
  {
    internal SQLiteTypeNames(string newtypeName, DbType newdataType)
    {
      typeName = newtypeName;
      dataType = newdataType;
    }

    internal string typeName;
    internal DbType dataType;
  }

  /// <summary>
  /// This base class provides datatype conversion services for the SQLite provider.
  /// </summary>
  public abstract class SQLiteConvert
  {
    /// <summary>
    /// An array of ISO8601 datetime formats we support conversion from
    /// </summary>
    private static string[] _datetimeFormats = new string[] {
      "yyyy-MM-dd HH:mm:ss.fffffff",
      "yyyy-MM-dd HH:mm:ss",
      "yyyy-MM-dd HH:mm",                               
      "yyyyMMddHHmmss",
      "yyyyMMddHHmm",
      "yyyyMMddTHHmmssfffffff",
      "yyyy-MM-dd",
      "yy-MM-dd",
      "yyyyMMdd",
      "HH:mm:ss",
      "HH:mm",
      "THHmmss",
      "THHmm",
      "yyyy-MM-dd HH:mm:ss.fff",
      "yyyy-MM-ddTHH:mm",
      "yyyy-MM-ddTHH:mm:ss",
      "yyyy-MM-ddTHH:mm:ss.fff",
      "yyyy-MM-ddTHH:mm:ss.ffffff",
      "HH:mm:ss.fff"
    };

    /// <summary>
    /// An UTF-8 Encoding instance, so we can convert strings to and from UTF-8
    /// </summary>
    private Encoding _utf8 = new UTF8Encoding();
    /// <summary>
    /// The default DateTime format for this instance
    /// </summary>
    internal SQLiteDateFormats _datetimeFormat;
    /// <summary>
    /// Initializes the conversion class
    /// </summary>
    /// <param name="fmt">The default date/time format to use for this instance</param>
    internal SQLiteConvert(SQLiteDateFormats fmt)
    {
      _datetimeFormat = fmt;
    }

    #region UTF-8 Conversion Functions
    /// <summary>
    /// Converts a string to a UTF-8 encoded byte array sized to include a null-terminating character.
    /// </summary>
    /// <param name="sourceText">The string to convert to UTF-8</param>
    /// <returns>A byte array containing the converted string plus an extra 0 terminating byte at the end of the array.</returns>
    public byte[] ToUTF8(string sourceText)
    {
      Byte[] byteArray;
      int nlen = _utf8.GetByteCount(sourceText) + 1;

      byteArray = new byte[nlen];
      nlen = _utf8.GetBytes(sourceText, 0, sourceText.Length, byteArray, 0);
      byteArray[nlen] = 0;

      return byteArray;
    }

    /// <summary>
    /// Convert a DateTime to a UTF-8 encoded, zero-terminated byte array.
    /// </summary>
    /// <remarks>
    /// This function is a convenience function, which first calls ToString() on the DateTime, and then calls ToUTF8() with the
    /// string result.
    /// </remarks>
    /// <param name="dateTimeValue">The DateTime to convert.</param>
    /// <returns>The UTF-8 encoded string, including a 0 terminating byte at the end of the array.</returns>
    public byte[] ToUTF8(DateTime dateTimeValue)
    {
      return ToUTF8(ToString(dateTimeValue));
    }

    /// <summary>
    /// Converts a UTF-8 encoded IntPtr of the specified length into a .NET string
    /// </summary>
    /// <param name="nativestring">The pointer to the memory where the UTF-8 string is encoded</param>
    /// <param name="nativestringlen">The number of bytes to decode</param>
    /// <returns>A string containing the translated character(s)</returns>
    public virtual string ToString(IntPtr nativestring, int nativestringlen)
    {
      return UTF8ToString(nativestring, nativestringlen);
    }

    /// <summary>
    /// Converts a UTF-8 encoded IntPtr of the specified length into a .NET string
    /// </summary>
    /// <param name="nativestring">The pointer to the memory where the UTF-8 string is encoded</param>
    /// <param name="nativestringlen">The number of bytes to decode</param>
    /// <returns>A string containing the translated character(s)</returns>
    public virtual string UTF8ToString(IntPtr nativestring, int nativestringlen)
    {
      if (nativestringlen == 0) return "";

      byte[] byteArray = new byte[nativestringlen];

      Marshal.Copy(nativestring, byteArray, 0, nativestringlen);

      return _utf8.GetString(byteArray, 0, nativestringlen);
    }


    #endregion

    #region DateTime Conversion Functions
    /// <summary>
    /// Converts a string into a DateTime, using the current DateTimeFormat specified for the connection when it was opened.
    /// </summary>
    /// <remarks>
    /// Acceptable ISO8601 DateTime formats are:
    ///   yyyy-MM-dd HH:mm:ss
    ///   yyyyMMddHHmmss
    ///   yyyyMMddTHHmmssfffffff
    ///   yyyy-MM-dd
    ///   yy-MM-dd
    ///   yyyyMMdd
    ///   HH:mm:ss
    ///   THHmmss
    /// </remarks>
    /// <param name="dateText">The string containing either a Tick value or an ISO8601-format string</param>
    /// <returns>A DateTime value</returns>
    public DateTime ToDateTime(string dateText)
    {
      switch (_datetimeFormat)
      {
        case SQLiteDateFormats.Ticks:
          return new DateTime(Convert.ToInt64(dateText, CultureInfo.InvariantCulture));
        default:
          return DateTime.ParseExact(dateText, _datetimeFormats, DateTimeFormatInfo.InvariantInfo, DateTimeStyles.None);
      }
    }

    /// <summary>
    /// Converts a DateTime to a string value, using the current DateTimeFormat specified for the connection when it was opened.
    /// </summary>
    /// <param name="dateValue">The DateTime value to convert</param>
    /// <returns>Either a string consisting of the tick count for DateTimeFormat.Ticks, or a date/time in ISO8601 format.</returns>
    public string ToString(DateTime dateValue)
    {
      switch (_datetimeFormat)
      {
        case SQLiteDateFormats.Ticks:
          return dateValue.Ticks.ToString(CultureInfo.InvariantCulture);
        default:
          return dateValue.ToString(_datetimeFormats[0], CultureInfo.InvariantCulture);
      }
    }

    /// <summary>
    /// Internal function to convert a UTF-8 encoded IntPtr of the specified length to a DateTime.
    /// </summary>
    /// <remarks>
    /// This is a convenience function, which first calls ToString() on the IntPtr to convert it to a string, then calls
    /// ToDateTime() on the string to return a DateTime.
    /// </remarks>
    /// <param name="ptr">A pointer to the UTF-8 encoded string</param>
    /// <param name="len">The length in bytes of the string</param>
    /// <returns>The parsed DateTime value</returns>
    internal DateTime ToDateTime(IntPtr ptr, int len)
    {
      return ToDateTime(ToString(ptr, len));
    }
    #endregion

    /// <summary>
    /// Smart method of splitting a string.  Skips quoted elements, removes the quotes.
    /// </summary>
    /// <remarks>
    /// This split function works somewhat like the String.Split() function in that it breaks apart a string into
    /// pieces and returns the pieces as an array.  The primary differences are:
    /// <list type="bullet">
    /// <item><description>Only one character can be provided as a separator character</description></item>
    /// <item><description>Quoted text inside the string is skipped over when searching for the separator, and the quotes are removed.</description></item>
    /// </list>
    /// Thus, if splitting the following string looking for a comma:<br/>
    /// One,Two, "Three, Four", Five<br/>
    /// <br/>
    /// The resulting array would contain<br/>
    /// [0] One<br/>
    /// [1] Two<br/>
    /// [2] Three, Four<br/>
    /// [3] Five<br/>
    /// <br/>
    /// Note that the leading and trailing spaces were removed from each item during the split.
    /// </remarks>
    /// <param name="source">Source string to split apart</param>
    /// <param name="separator">Separator character</param>
    /// <returns>A string array of the split up elements</returns>
    public static string[] Split(string source, char separator)
    {
      char[] toks = new char[2] { '\"', separator };
      char[] quot = new char[1] { '\"' };

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区在线视频观看58| 国产乱码精品一区二区三区忘忧草 | 欧美视频一区二区三区在线观看| 日本aⅴ亚洲精品中文乱码| 91亚洲大成网污www| 老司机精品视频导航| 欧美美女直播网站| 青青草原综合久久大伊人精品优势| 日韩欧美一级二级| 国产福利电影一区二区三区| 成人免费在线观看入口| 在线亚洲高清视频| 蜜桃精品在线观看| www日韩大片| 七七婷婷婷婷精品国产| 亚洲女同女同女同女同女同69| 亚洲成av人在线观看| 69精品人人人人| 国内精品久久久久影院色| 精品国产三级a在线观看| 成人精品视频一区| 亚洲国产一区二区a毛片| 精品美女一区二区| 99久久婷婷国产综合精品 | 欧美区在线观看| 国产自产视频一区二区三区| 亚洲欧美日韩一区二区 | 国产精品国产自产拍在线| 欧美三级欧美一级| 国产成人99久久亚洲综合精品| 亚洲一区二区偷拍精品| 国产精品视频一二三区| 成人免费福利片| 日韩在线a电影| 国产精品久久久久永久免费观看 | 国产成人啪午夜精品网站男同| 一区二区三区四区精品在线视频| 日韩免费性生活视频播放| 欧美撒尿777hd撒尿| 亚洲精品国产a| 99热国产精品| 亚洲精品乱码久久久久| 91丨九色丨蝌蚪丨老版| 欧美一级国产精品| 亚洲欧美自拍偷拍色图| 不卡免费追剧大全电视剧网站| 欧美v亚洲v综合ⅴ国产v| 麻豆91精品视频| 日韩一区二区麻豆国产| 免费在线观看一区| 国产凹凸在线观看一区二区| 26uuu精品一区二区 | 奇米色777欧美一区二区| 欧美成人r级一区二区三区| 国产精品色一区二区三区| 亚洲男女毛片无遮挡| 日本精品视频一区二区| 婷婷久久综合九色国产成人 | 欧美日韩激情一区二区| 亚洲女人小视频在线观看| 国产午夜精品在线观看| 欧美一区二区成人6969| 欧美日韩免费一区二区三区| 99精品一区二区| 国产精品一区二区三区乱码| 蜜桃精品在线观看| 99精品1区2区| 亚洲夂夂婷婷色拍ww47| 在线播放视频一区| 97成人超碰视| 秋霞成人午夜伦在线观看| av一区二区三区黑人| 亚洲柠檬福利资源导航| 日韩一区二区免费在线电影| 成人美女视频在线观看18| 国产乱淫av一区二区三区| 一本色道久久综合亚洲91| 国产日韩欧美精品电影三级在线| 国产精品久99| 国产精品伦理一区二区| 国产精品蜜臀在线观看| 中文字幕不卡在线播放| 国产精品国产三级国产aⅴ无密码| 日本一区二区动态图| 国产精品女主播av| 成人免费在线视频观看| 亚洲综合免费观看高清完整版在线| 一区二区三区日韩精品视频| 国产在线精品视频| 国产精品乱码一区二区三区软件| 欧美电影免费提供在线观看| 欧美电视剧免费全集观看| 欧美一级高清片在线观看| 精品国产乱码久久久久久久| 欧美电影免费观看高清完整版在线 | 精品久久99ma| 久久精品视频一区二区| 成人免费一区二区三区视频 | 久久久久国产精品人| 国产日本欧洲亚洲| 日韩vs国产vs欧美| 美女诱惑一区二区| 国产成+人+日韩+欧美+亚洲| 不卡视频在线观看| 欧美日韩免费高清一区色橹橹| 91精品国产欧美日韩| 国产日韩精品一区二区浪潮av| 综合中文字幕亚洲| 午夜国产不卡在线观看视频| 中文字幕一区二区三区在线不卡| 欧美成人一区二区三区片免费| 精品免费视频一区二区| 日本一区二区在线不卡| 欧美亚一区二区| 免费日本视频一区| 99国内精品久久| 久久众筹精品私拍模特| 日韩伦理av电影| 看片网站欧美日韩| 91福利视频网站| 久久综合九色综合欧美98 | 欧美激情在线观看视频免费| 国产欧美日韩亚州综合| 亚洲五码中文字幕| 成人一区二区视频| 7777精品久久久大香线蕉 | 日韩高清不卡一区| 日本韩国一区二区| 国产日产欧美一区二区视频| 中文字幕精品—区二区四季| 555夜色666亚洲国产免| 久久er99热精品一区二区| 亚洲精品欧美二区三区中文字幕| 一区二区免费看| 国产精品美女一区二区在线观看| 午夜精品福利在线| www.综合网.com| 精品国产a毛片| 香蕉成人啪国产精品视频综合网| 成人伦理片在线| 久久嫩草精品久久久精品一| 首页欧美精品中文字幕| 一区二区不卡在线视频 午夜欧美不卡在 | 午夜影视日本亚洲欧洲精品| 国产精品99久久久久久久女警| 日韩写真欧美这视频| 精品国产髙清在线看国产毛片| 国产精品网站一区| 99麻豆久久久国产精品免费| 国产婷婷色一区二区三区四区| 日韩av电影免费观看高清完整版 | 91丝袜美女网| 欧美videos大乳护士334| 午夜精品免费在线| 日韩欧美成人午夜| 天堂精品中文字幕在线| 欧美网站一区二区| 亚洲一区二区在线免费观看视频| 国产精品久久久99| 国产揄拍国内精品对白| 欧美精品一区二区三区蜜臀| 久久国产欧美日韩精品| 中文字幕一区二区视频| 精品捆绑美女sm三区| 一区二区三区国产豹纹内裤在线| 三级欧美韩日大片在线看| 色哟哟日韩精品| 一区二区三区日韩欧美精品| 欧美在线免费观看视频| 日韩精品中文字幕在线不卡尤物| 欧美精品一区二区三区四区 | 久久久久亚洲蜜桃| 国产精品一二三| 91精品麻豆日日躁夜夜躁| 午夜精品一区在线观看| 国产成人精品免费网站| 久久久久免费观看| 国产精品一区一区| 福利电影一区二区| 亚洲欧美日韩国产另类专区| 91色|porny| 九色综合国产一区二区三区| 日韩美女视频一区二区| 91在线一区二区| 日韩综合小视频| 18欧美乱大交hd1984| 91精品在线免费观看| 奇米影视一区二区三区小说| 中文字幕日韩精品一区| 日韩一区二区三| bt欧美亚洲午夜电影天堂| 性久久久久久久久| 欧美激情在线看| 日韩欧美一区二区在线视频| 福利一区二区在线观看| 欧美性猛交xxxx乱大交退制版| 最近日韩中文字幕| 久久综合九色综合欧美98| 成人小视频免费观看| 精品一区二区三区香蕉蜜桃|