当前位置: 首页>>代码示例>>C#>>正文


C# NpgsqlConnection.BeginTextImport方法代码示例

本文整理汇总了C#中Npgsql.NpgsqlConnection.BeginTextImport方法的典型用法代码示例。如果您正苦于以下问题:C# NpgsqlConnection.BeginTextImport方法的具体用法?C# NpgsqlConnection.BeginTextImport怎么用?C# NpgsqlConnection.BeginTextImport使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Npgsql.NpgsqlConnection的用法示例。


在下文中一共展示了NpgsqlConnection.BeginTextImport方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: CancelTextImport

        public void CancelTextImport()
        {
            using (var conn = new NpgsqlConnection(ConnectionString))
            {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (field_text TEXT, field_int2 SMALLINT, field_int4 INTEGER)", conn);

                var writer = (NpgsqlCopyTextWriter)conn.BeginTextImport("COPY data (field_text, field_int4) FROM STDIN");
                writer.Write("HELLO\t1\n");
                writer.Cancel();
                Assert.That(ExecuteScalar(@"SELECT COUNT(*) FROM data", conn), Is.EqualTo(0));
            }
        }
开发者ID:neisbut,项目名称:npgsql,代码行数:13,代码来源:CopyTests.cs

示例2: Insert

        public void Insert(IEnumerable items, string tableName, Action<long> notifyRowsCopied = null,
            Action<Exception> onError = null)
        {
            var targetMethod = typeof (ObjectReader).GetMethod("Create", BindingFlags.Static | BindingFlags.Public);
            var targetGenericMethod = targetMethod.MakeGenericMethod(new Type[] {_type});

            var castMethod = typeof (Enumerable).GetMethod("Cast", BindingFlags.Static | BindingFlags.Public);
            var castGenericMethod = castMethod.MakeGenericMethod(new Type[] {_type});

            var destinationColumnsString =
                ColumnMappings.GetSqlBulkInsertMappings()
                    .Select(x => x.DestinationColumn)
                    .Aggregate((a, b) => a + "," + b);
            var sourceColumnsArray = ColumnMappings.GetSqlBulkInsertMappings().Select(x => x.SourceColumn).ToArray();

            var objectReader = (ObjectReader) targetGenericMethod.Invoke(null,
                new[] {castGenericMethod.Invoke(null, new[] {items}), sourceColumnsArray});

            using (var connection = new NpgsqlConnection(_connectionString))
            {

                try
                {
                    connection.Open();
                }
                catch (Exception x)
                {
                    Log.Error(x);
                    if (onError == null) throw;
                    onError(x);
                }

                var copyCommand = string.Format(CultureInfo.InvariantCulture, "COPY {0}({1}) FROM STDIN WITH CSV", tableName,
                    destinationColumnsString);

                using (var writer = connection.BeginTextImport(copyCommand))
                {

                    Log.DebugFormat("Starting bulk insert into '{0}'", tableName);
                    try
                    {
                        var row = 0;
                        IDataReader reader = objectReader as IDataReader;
                        while (reader.Read())
                        {
                            for (var i = 0; i < reader.FieldCount; i++)
                            {
                                if (i > 0)
                                    writer.Write(CsvDelimiter);
                                object value = reader.GetValue(i);
                                if (value != null)
                                {
                                    writer.Write(CsvQuote);
                                    writer.Write(_csvRegex.Replace(value.ToString(), CsvReplacement));
                                    writer.Write(CsvQuote);
                                }
                            }
                            writer.WriteLine();

                            row++;
                            if (row%NotifyAfter == 0)
                            {
                                if (notifyRowsCopied != null)
                                {
                                    notifyRowsCopied(row);
                                }
                            }
                        }
                        writer.Flush();
                    }
                    catch (Exception x)
                    {
                        Log.ErrorFormat("Error bulk inserting", x);
                        if (onError == null) throw;

                        onError(x);
                    }
                }
            }
        }
开发者ID:KyleGobel,项目名称:Chronos,代码行数:80,代码来源:PostgresBulkInserter.cs

示例3: CloseDuringCopy

        public void CloseDuringCopy()
        {
            // TODO: Check no broken connections were returned to the pool
            using (var conn = new NpgsqlConnection(ConnectionString)) {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (field_text TEXT, field_int2 SMALLINT, field_int4 INTEGER)", conn);
                conn.BeginBinaryImport("COPY data (field_text, field_int4) FROM STDIN BINARY");
            }

            using (var conn = new NpgsqlConnection(ConnectionString)) {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (field_text TEXT, field_int2 SMALLINT, field_int4 INTEGER)", conn);
                conn.BeginBinaryExport("COPY data (field_text, field_int2) TO STDIN BINARY");
            }

            using (var conn = new NpgsqlConnection(ConnectionString)) {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (field_text TEXT, field_int2 SMALLINT, field_int4 INTEGER)", conn);
                conn.BeginRawBinaryCopy("COPY data (field_text, field_int4) FROM STDIN BINARY");
            }

            using (var conn = new NpgsqlConnection(ConnectionString)) {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (field_text TEXT, field_int2 SMALLINT, field_int4 INTEGER)", conn);
                conn.BeginRawBinaryCopy("COPY data (field_text, field_int4) TO STDIN BINARY");
            }

            using (var conn = new NpgsqlConnection(ConnectionString)) {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (field_text TEXT, field_int2 SMALLINT, field_int4 INTEGER)", conn);
                conn.BeginTextImport("COPY data (field_text, field_int4) FROM STDIN");
            }

            using (var conn = new NpgsqlConnection(ConnectionString)) {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (field_text TEXT, field_int2 SMALLINT, field_int4 INTEGER)", conn);
                conn.BeginTextExport("COPY data (field_text, field_int4) TO STDIN");
            }
        }
开发者ID:neisbut,项目名称:npgsql,代码行数:39,代码来源:CopyTests.cs


注:本文中的Npgsql.NpgsqlConnection.BeginTextImport方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。