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


C# NpgsqlCommand.ExecuteReaderAsync方法代碼示例

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


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

示例1: Reader

 public async void Reader()
 {
     using (var cmd = new NpgsqlCommand("SELECT 1", Conn))
     using (var reader = await cmd.ExecuteReaderAsync())
     {
         await reader.ReadAsync();
         Assert.That(reader[0], Is.EqualTo(1));
     }
 }
開發者ID:Emill,項目名稱:Npgsql,代碼行數:9,代碼來源:AsyncTests.cs

示例2: Columnar

 public async void Columnar()
 {
     using (var cmd = new NpgsqlCommand("SELECT NULL, 2, 'Some Text'", Conn))
     using (var reader = await cmd.ExecuteReaderAsync(CommandBehavior.SequentialAccess))
     {
         await reader.ReadAsync();
         Assert.That(await reader.IsDBNullAsync(0), Is.True);
         Assert.That(await reader.GetFieldValueAsync<string>(2), Is.EqualTo("Some Text"));
     }
 }
開發者ID:Emill,項目名稱:Npgsql,代碼行數:10,代碼來源:AsyncTests.cs

示例3: Columnar

 public async void Columnar()
 {
     ExecuteNonQuery("INSERT INTO DATA (field_int4, field_text) VALUES (2, 'Some Text')");
     using (var cmd = new NpgsqlCommand("SELECT field_int2, field_int4, field_text FROM data", Conn))
     using (var reader = await cmd.ExecuteReaderAsync(CommandBehavior.SequentialAccess))
     {
         await reader.ReadAsync();
         Assert.That(await reader.IsDBNullAsync(0), Is.True);
         Assert.That(await reader.GetFieldValueAsync<string>(2), Is.EqualTo("Some Text"));
     }
 }
開發者ID:roji,項目名稱:Npgsql,代碼行數:11,代碼來源:AsyncTests.cs

示例4: buildEventPage

        private async Task<EventPage> buildEventPage(long lastEncountered, NpgsqlCommand cmd)
        {
            IList<IEvent> events = null;
            IList<long> sequences = new List<long>();

            using (var reader = await cmd.ExecuteReaderAsync(_token).ConfigureAwait(false))
            {
                while (await reader.ReadAsync(_token).ConfigureAwait(false))
                {
                    var seq = await reader.GetFieldValueAsync<long>(0, _token).ConfigureAwait(false);
                    sequences.Add(seq);
                }

                if (sequences.Any())
                {
                    await reader.NextResultAsync(_token).ConfigureAwait(false);

                    events = await _selector.ReadAsync(reader, _map, _token).ConfigureAwait(false);
                }
                else
                {
                    events = new List<IEvent>();
                }
            }

            return new EventPage(lastEncountered, sequences, events) {Count = events.Count};
        }
開發者ID:phillip-haydon,項目名稱:marten,代碼行數:27,代碼來源:Fetcher.cs

示例5: ExecuteReaderAsync

 public async void ExecuteReaderAsync(int rows)
 {
     for (var i = 0; i < rows; i++)
         ExecuteNonQuery("INSERT INTO DATA (field_int4) VALUES (10)");
     using (var metrics = TestMetrics.Start(TestRunTime, true))
     {
         while (!metrics.TimesUp)
         {
             using (var cmd = new NpgsqlCommand("SELECT field_int4 FROM data", Conn))
             using (var reader = await cmd.ExecuteReaderAsync())
             {
                 while (await reader.ReadAsync()) { }
             }
             metrics.IncrementIterations();
         }
     }
 }
開發者ID:Tradioyes,項目名稱:Npgsql,代碼行數:17,代碼來源:SpeedTests.cs

示例6: GetDriverByLastNameAsync

		public async Task<IEnumerable<Driver>> GetDriverByLastNameAsync(string theDriverName)
		{
			try
			{
				await Connection.OpenAsync().ConfigureAwait(false);

				var aPreparedCommand =
					new NpgsqlCommand(
						"SELECT id, firstname, lastname, address, city, state, postalcode, country, licensenumber, licensestate, customerid from driver where id = :value1", Connection);
				var aParam = new NpgsqlParameter("value1", NpgsqlDbType.Text) { Value = theDriverName };
				aPreparedCommand.Parameters.Add(aParam);

				var aReader = await aPreparedCommand.ExecuteReaderAsync().ConfigureAwait(false);

				if (!aReader.HasRows)
					return null;

				var aReturn = new List<Driver>();
				while (await aReader.ReadAsync().ConfigureAwait(false))
				{
					aReturn.Add(ReadDriver(aReader));
				}
				return aReturn;
			}
			catch (NpgsqlException)
			{
				return null;
			}
			catch (InvalidOperationException)
			{
				return null;
			}
			catch (SqlException)
			{
				return null;
			}
			catch (ConfigurationErrorsException)
			{
				return null;
			}
			finally
			{
				if (Connection.State == ConnectionState.Open)
					Connection.Close();
			}
		}
開發者ID:gblosser,項目名稱:FullStackReference,代碼行數:46,代碼來源:DriverRepository.cs

示例7: GetCustomerByNameAsync

		public async Task<Customer> GetCustomerByNameAsync(string theCustomerName)
		{
			try
			{
				await Connection.OpenAsync().ConfigureAwait(false);

				var aPreparedCommand =
					new NpgsqlCommand(
						"SELECT id, name, allowsadditionaldrivers, allowsadditions, hasmaxrentaldays, maxrentaldays from customer where name = :value1", Connection);
				var aParam = new NpgsqlParameter("value1", NpgsqlDbType.Text) { Value = theCustomerName };
				aPreparedCommand.Parameters.Add(aParam);

				var aReader = await aPreparedCommand.ExecuteReaderAsync().ConfigureAwait(false);

				if (!aReader.HasRows)
					return null;

				var aReturn = new Customer();
				while (await aReader.ReadAsync().ConfigureAwait(false))
				{
					aReturn = ReadCustomer(aReader);
				}
				return aReturn;
			}
			catch (NpgsqlException)
			{
				return null;
			}
			catch (InvalidOperationException)
			{
				return null;
			}
			catch (SqlException)
			{
				return null;
			}
			catch (ConfigurationErrorsException)
			{
				return null;
			}
			finally
			{
				if (Connection.State == ConnectionState.Open)
					Connection.Close();
			}
		}
開發者ID:gblosser,項目名稱:FullStackReference,代碼行數:46,代碼來源:CustomerRepository.cs

示例8: buildEventPage

        private async Task<EventPage> buildEventPage(long @from, NpgsqlCommand cmd)
        {
            IList<IEvent> events = null;
            IList<long> sequences = new List<long>();

            long nextKnown = 0;
            long lastKnown = 0;

            using (var reader = await cmd.ExecuteReaderAsync(_token).ConfigureAwait(false))
            {
                while (await reader.ReadAsync(_token).ConfigureAwait(false))
                {
                    var seq = await reader.GetFieldValueAsync<long>(0, _token).ConfigureAwait(false);
                    sequences.Add(seq);
                }

                if (sequences.Any())
                {
                    await reader.NextResultAsync(_token).ConfigureAwait(false);

                    events = await _selector.ReadAsync(reader, _map, null, _token).ConfigureAwait(false);
                }
                else
                {
                    events = new List<IEvent>();
                }

                nextKnown = await getLong(reader).ConfigureAwait(false);
                lastKnown = await getLong(reader).ConfigureAwait(false);
            }

            return new EventPage(@from, sequences, events)
            {
                Count = events.Count,
                NextKnownSequence = nextKnown,
                LastKnownSequence = lastKnown
            };
        }
開發者ID:JasperFx,項目名稱:marten,代碼行數:38,代碼來源:Fetcher.cs

示例9: GetLocationsForCustomerAsync

		public async Task<IEnumerable<Location>> GetLocationsForCustomerAsync(int theCustomerId)
		{
			try
			{
				await Connection.OpenAsync().ConfigureAwait(false);

				var aPreparedCommand = new NpgsqlCommand("SELECT id, customerid, name, address, city, state, postalcode, country, latitude, longitude  from location where customerid=:value1", Connection);
				aPreparedCommand.Parameters.AddWithValue("value1", theCustomerId);

				var aReader = await aPreparedCommand.ExecuteReaderAsync();

				if (!aReader.HasRows)
					return Enumerable.Empty<Location>();

				var aReturn = new List<Location>();
				while (await aReader.ReadAsync().ConfigureAwait(false))
				{
					aReturn.Add(ReadLocation(aReader));
				}
				return aReturn;
			}
			catch (NpgsqlException)
			{
				return Enumerable.Empty<Location>();
			}
			catch (InvalidOperationException ex)
			{
				return Enumerable.Empty<Location>();
			}
			catch (SqlException)
			{
				return Enumerable.Empty<Location>();
			}
			catch (ConfigurationErrorsException)
			{
				return Enumerable.Empty<Location>();
			}
			finally
			{
				if (Connection.State == ConnectionState.Open)
					Connection.Close();
			}
		}
開發者ID:gblosser,項目名稱:FullStackReference,代碼行數:43,代碼來源:LocationRepository.cs

示例10: GetLocationAsync

		public async Task<Location> GetLocationAsync(int theLocationId)
		{
			try
			{
				await Connection.OpenAsync().ConfigureAwait(false);

				var aPreparedCommand =
					new NpgsqlCommand(
						"SELECT id, customerid, name, address, city, state, postalcode, country, latitude, longitude from location where id = :value1", Connection);
				var aParam = new NpgsqlParameter("value1", NpgsqlDbType.Integer) { Value = theLocationId };
				aPreparedCommand.Parameters.Add(aParam);

				var aReader = await aPreparedCommand.ExecuteReaderAsync().ConfigureAwait(false);

				if (!aReader.HasRows)
					return null;

				var aReturn = new Location();
				while (await aReader.ReadAsync().ConfigureAwait(false))
				{
					aReturn = ReadLocation(aReader);
				}
				return aReturn;
			}
			catch (NpgsqlException)
			{
				return null;
			}
			catch (InvalidOperationException)
			{
				return null;
			}
			catch (SqlException)
			{
				return null;
			}
			catch (ConfigurationErrorsException)
			{
				return null;
			}
			finally
			{
				if (Connection.State == ConnectionState.Open)
					Connection.Close();
			}
		}
開發者ID:gblosser,項目名稱:FullStackReference,代碼行數:46,代碼來源:LocationRepository.cs

示例11: executeCallbacksAsync

        private static async Task executeCallbacksAsync(NpgsqlCommand cmd, CancellationToken tkn, BatchCommand batch, List<Exception> list)
        {
            using (var reader = await cmd.ExecuteReaderAsync(tkn).ConfigureAwait(false))
            {
                if (batch.Callbacks.Any())
                {
                    if (batch.Callbacks[0] != null)
                    {
                        await batch.Callbacks[0].PostprocessAsync(reader, list, tkn).ConfigureAwait(false);
                    }

                    for (int i = 1; i < batch.Callbacks.Count; i++)
                    {
                        await reader.NextResultAsync(tkn).ConfigureAwait(false);

                        if (batch.Callbacks[i] != null)
                        {
                            await batch.Callbacks[i].PostprocessAsync(reader, list, tkn).ConfigureAwait(false);
                        }
                    }
                }
            }
        }
開發者ID:danielmarbach,項目名稱:marten,代碼行數:23,代碼來源:UpdateBatch.cs

示例12: GetUserByEmailAsync

		public async Task<User> GetUserByEmailAsync(string theEmail)
		{
			try
			{
				await Connection.OpenAsync().ConfigureAwait(false);

				var aPreparedCommand =
					new NpgsqlCommand(
						"SELECT id, firstname, lastname, email, customerid, isemployee from appuser where email = :value1", Connection);
				var aParam = new NpgsqlParameter("value1", NpgsqlDbType.Text) { Value = theEmail };
				aPreparedCommand.Parameters.Add(aParam);

				var aReader = await aPreparedCommand.ExecuteReaderAsync().ConfigureAwait(false);

				if (!aReader.HasRows)
					return null;

				var aReturn = new User();
				while (await aReader.ReadAsync().ConfigureAwait(false))
				{
					aReturn = ReadUser(aReader);
				}
				return aReturn;
			}
			catch (NpgsqlException)
			{
				return null;
			}
			catch (InvalidOperationException)
			{
				return null;
			}
			catch (SqlException)
			{
				return null;
			}
			catch (ConfigurationErrorsException)
			{
				return null;
			}
			finally
			{
				if (Connection.State == ConnectionState.Open)
					Connection.Close();
			}
		}
開發者ID:gblosser,項目名稱:FullStackReference,代碼行數:46,代碼來源:UserRepository.cs

示例13: GetAutomobilesAsync

		public async Task<IEnumerable<Automobile>> GetAutomobilesAsync(IEnumerable<int> theAutomobileIds)
		{
			try
			{
				await Connection.OpenAsync().ConfigureAwait(false);

				var aPreparedCommand =
					new NpgsqlCommand(
						"SELECT id, vin, vehiclenumber, name, class, style, color, manufacturer, model, code, locationid from automobile where id = :value1", Connection);
				aPreparedCommand.Parameters.AddWithValue("value1", string.Join(",", theAutomobileIds));

				var aReader = await aPreparedCommand.ExecuteReaderAsync();

				if (!aReader.HasRows)
					return Enumerable.Empty<Automobile>().ToList();

				var aReturnList = new List<Automobile>();
				while (await aReader.ReadAsync())
				{
					aReturnList.Add(ReadAutomobile(aReader));
				}
				return aReturnList;
			}
			catch (NpgsqlException)
			{
				return Enumerable.Empty<Automobile>().ToList();
			}
			catch (InvalidOperationException)
			{
				return Enumerable.Empty<Automobile>().ToList();
			}
			catch (SqlException)
			{
				return Enumerable.Empty<Automobile>().ToList();
			}
			catch (ConfigurationErrorsException)
			{
				return Enumerable.Empty<Automobile>().ToList();
			}
			finally
			{
				if (Connection.State == ConnectionState.Open)
					Connection.Close();
			}
		}
開發者ID:gblosser,項目名稱:FullStackReference,代碼行數:45,代碼來源:AutomobileRepository.cs

示例14: GetAutomobileAsync

		public async Task<Automobile> GetAutomobileAsync(int theAutomobileId)
		{
			try
			{
				await Connection.OpenAsync().ConfigureAwait(false);

				var aPreparedCommand =
					new NpgsqlCommand(
						"SELECT id, vin, vehiclenumber, name, class, style, color, manufacturer, model, code, locationid from automobile where id = :value1", Connection);
				var aParam = new NpgsqlParameter("value1", NpgsqlDbType.Integer) { Value = theAutomobileId };
				aPreparedCommand.Parameters.Add(aParam);

				var aReader = await aPreparedCommand.ExecuteReaderAsync().ConfigureAwait(false);

				if (!aReader.HasRows)
					return null;

				var aReturn = new Automobile();
				while (await aReader.ReadAsync().ConfigureAwait(false))
				{
					aReturn = ReadAutomobile(aReader);
				}
				return aReturn;
			}
			catch (NpgsqlException)
			{
				return null;
			}
			catch (InvalidOperationException)
			{
				return null;
			}
			catch (SqlException)
			{
				return null;
			}
			catch (ConfigurationErrorsException)
			{
				return null;
			}
			finally
			{
				if (Connection.State == ConnectionState.Open)
					Connection.Close();
			}
		}
開發者ID:gblosser,項目名稱:FullStackReference,代碼行數:46,代碼來源:AutomobileRepository.cs


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