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


C# NpgsqlConnection.BeginBinaryImport方法代碼示例

本文整理匯總了C#中Npgsql.NpgsqlConnection.BeginBinaryImport方法的典型用法代碼示例。如果您正苦於以下問題:C# NpgsqlConnection.BeginBinaryImport方法的具體用法?C# NpgsqlConnection.BeginBinaryImport怎麽用?C# NpgsqlConnection.BeginBinaryImport使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Npgsql.NpgsqlConnection的用法示例。


在下文中一共展示了NpgsqlConnection.BeginBinaryImport方法的5個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C#代碼示例。

示例1: CancelBinaryImport

        public void CancelBinaryImport()
        {
            using (var conn = new NpgsqlConnection(ConnectionString))
            {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (field_text TEXT, field_int2 SMALLINT, field_int4 INTEGER)", conn);
                using (var writer = conn.BeginBinaryImport("COPY data (field_text, field_int4) FROM STDIN BINARY"))
                {
                    writer.StartRow();
                    writer.Write("Hello");
                    writer.Write(8);

                    writer.Cancel();
                }
                Assert.That(ExecuteScalar(@"SELECT COUNT(*) FROM data", conn), Is.EqualTo(0));
            }
        }
開發者ID:neisbut,項目名稱:npgsql,代碼行數:17,代碼來源:CopyTests.cs

示例2: CreateAndFillEvents

		private void CreateAndFillEvents()
		{
			var creator = new TableBuilder(PostgresFixture.ConnectionString);
			creator.CreateTable(typeof(Guid), StreamName);

			using (var connection = new NpgsqlConnection(PostgresFixture.ConnectionString))
			{
				connection.Open();

				var id = Guid.NewGuid();

				var events = Enumerable
					.Range(0, TotalRecords)
					.Select(i => i.AsSequence())
					.Select(seq => new TestEvent { AggregateID = id, Sequence = seq, Stamp = DefaultStamper.Now() });

				using (var writer = connection.BeginBinaryImport("COPY importstream_events(aggregateid, sequence, eventtype, event) from STDIN (format binary)"))
				{
					foreach (var @event in events)
					{
						writer.StartRow();

						writer.Write(@event.AggregateID.ToString(), NpgsqlDbType.Uuid);
						writer.Write((int)@event.Sequence);
						writer.Write(@event.GetType().AssemblyQualifiedName);
						writer.Write(Serializer.Serialize(@event));
					}
				}
			}
		}
開發者ID:Pondidum,項目名稱:Ledger.Stores.Postgres,代碼行數:30,代碼來源:PostgresStoreReaderTests.cs

示例3: UnexpectedExceptionBinaryImport

        public void UnexpectedExceptionBinaryImport()
        {
            var conn = new NpgsqlConnection(ConnectionString);
            conn.Open();
            ExecuteNonQuery("CREATE TEMP TABLE data (blob BYTEA)", conn);

            var data = new byte[conn.BufferSize + 10];

            var writer = conn.BeginBinaryImport("COPY data (blob) FROM STDIN BINARY");
            ExecuteNonQuery(string.Format("SELECT pg_terminate_backend({0})", conn.ProcessID));
            Thread.Sleep(50);
            Assert.That(() =>
            {
                writer.StartRow();
                writer.Write(data);
                writer.Dispose();
            }, Throws.Exception.TypeOf<IOException>());
            Assert.That(conn.FullState, Is.EqualTo(ConnectionState.Broken));
        }
開發者ID:neisbut,項目名稱:npgsql,代碼行數:19,代碼來源:CopyTests.cs

示例4: ImportDirectBuffer

        public void ImportDirectBuffer()
        {
            using (var conn = new NpgsqlConnection(ConnectionString))
            {
                conn.Open();
                ExecuteNonQuery("CREATE TEMP TABLE data (blob BYTEA)", conn);

                using (var writer = conn.BeginBinaryImport("COPY data (blob) FROM STDIN BINARY"))
                {
                    // Big value - triggers use of the direct buffer optimization
                    var data = new byte[conn.BufferSize + 10];

                    writer.StartRow();
                    writer.Write(data);
                    writer.StartRow();
                    writer.Write(data);
                    writer.Dispose();
                }
            }
        }
開發者ID:neisbut,項目名稱:npgsql,代碼行數:20,代碼來源:CopyTests.cs

示例5: 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.BeginBinaryImport方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。