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


C# NpgsqlConnection.BeginTransaction方法代碼示例

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


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

示例1: CleanTables

        public static void CleanTables(NpgsqlConnection connection)
        {
            if (connection == null) throw new ArgumentNullException(nameof(connection));

			string script = null;

#if (NETCORE1 || NETCORE50 || NETSTANDARD1_5 || NETSTANDARD1_6)
			script = GetStringResource(
			  typeof(PostgreSqlTestObjectsInitializer).GetTypeInfo().Assembly,
			  $"Hangfire.PostgreSql.NetCore.Tests.Clean.sql").Replace("'hangfire'", string.Format("'{0}'", ConnectionUtils.GetSchemaName()));
#else
               script = GetStringResource(
                typeof (PostgreSqlTestObjectsInitializer).Assembly,
                "Hangfire.PostgreSql.Tests.Clean.sql").Replace("'hangfire'", string.Format("'{0}'", ConnectionUtils.GetSchemaName()));
#endif

			//connection.Execute(script);

			using (var transaction = connection.BeginTransaction(IsolationLevel.Serializable))
			using (var command = new NpgsqlCommand(script, connection, transaction))
			{
				command.CommandTimeout = 120;
				try
				{
					command.ExecuteNonQuery();
					transaction.Commit();
				}
				catch (NpgsqlException)
				{
					throw;
				}
			}
		}
開發者ID:ofirgeller,項目名稱:Hangfire.PostgreSql,代碼行數:33,代碼來源:PostgreSqlTestObjectsInitializer.cs

示例2: CleanTables

        public static void CleanTables(NpgsqlConnection connection)
        {
            if (connection == null) throw new ArgumentNullException("connection");

            var script = GetStringResource(
                typeof (PostgreSqlTestObjectsInitializer).Assembly,
                "Hangfire.PostgreSql.Tests.Clean.sql").Replace("'hangfire'", string.Format("'{0}'", ConnectionUtils.GetSchemaName()));

			//connection.Execute(script);

			using (var transaction = connection.BeginTransaction(IsolationLevel.Serializable))
			using (var command = new NpgsqlCommand(script, connection, transaction))
			{
				command.CommandTimeout = 120;
				try
				{
					command.ExecuteNonQuery();
					transaction.Commit();
				}
				catch (NpgsqlException ex)
				{
					throw;
				}
			}
		}
開發者ID:ahydrax,項目名稱:Hangfire.PostgreSql,代碼行數:25,代碼來源:PostgreSqlTestObjectsInitializer.cs

示例3: Main

    static void Main(string[] args)
    {
        // Connect to a PostgreSQL database
         NpgsqlConnection conn = new NpgsqlConnection("Server=127.0.0.1;User Id=postgres; " +
             "Password=1905;Database=Lab3;");
         conn.Open();

         // Start a transaction as it is required to work with result sets (cursors) in PostgreSQL
         NpgsqlTransaction tran = conn.BeginTransaction();

         // Define a command to call add_ogrenci() procedure
         NpgsqlCommand command1 = new NpgsqlCommand("add_ogrenci(9060256,Fatih,Taştemur,01-01-1991,Ankara,50693671313 )", conn);
         command1.CommandType = CommandType.StoredProcedure;

          NpgsqlCommand command2 = new NpgsqlCommand("count_ogrenci", conn);
         command2.CommandType = CommandType.StoredProcedure;

         // Execute the procedure and obtain a result set
         NpgsqlDataReader dr1 = command1.ExecuteReader();
         NpgsqlDataReader dr2 = command2.ExecuteReader();

         // Output
         while (dr1.Read())
            Console.WriteLine("Adding records to a successful");

         while (dr2.Read())
             return sayi;

         tran.Commit();
         conn.Close();
    }
開發者ID:slymnkbdyi,項目名稱:c-sharp,代碼行數:31,代碼來源:StoredProcedure.cs

示例4: PostgresProcessor

 public PostgresProcessor(NpgsqlConnection connection, IMigrationGenerator generator, IAnnouncer announcer, IMigrationProcessorOptions options)
     : base(generator, announcer, options)
 {
     Connection = connection;
     connection.Open();
     Transaction = connection.BeginTransaction();
 }
開發者ID:elfrostie,項目名稱:fluentmigrator,代碼行數:7,代碼來源:PostgresProcessor.cs

示例5: Salvarcliente

 public int Salvarcliente(string nome, int codempresa)
 {
     using (var conn = new NpgsqlConnection(Connectionstring))
     {
         conn.Open();
         using (var trans  = conn.BeginTransaction())
         {
             try
             {
                 int id;
                 using (var cmd = new NpgsqlCommand("SELECT MIN(PORT_VNC) FROM PORTAS WHERE PORT_VNC NOT iN(SELECT CLIE_IDVNC FROM CLIENTE)", conn, trans))
                 {
                    id = int.Parse(cmd.ExecuteScalar().ToString());
                     
                 }
                 using (
                     var cmd =
                         new NpgsqlCommand(
                             "INSERT INTO cliente (clie_nome,clie_idvnc, empr_codigo) values ('" + nome + "'," + id + ","+codempresa+")", conn,
                             trans))
                 {
                     cmd.ExecuteNonQuery();
                     trans.Commit();
                     return id;
                 }
             }
             catch (Exception)
             {
                 trans.Rollback();
                 return 0;
             }
         }
     }
 }
開發者ID:thiagomoreiraboby,項目名稱:SuporteOnline,代碼行數:34,代碼來源:Clientes.cs

示例6: Append

        public void Append(string name, byte[] data, long expectedVersion)
        {
            using (var conn = new NpgsqlConnection(_connectionString))
            {
                conn.Open();
                using (var tx = conn.BeginTransaction())
                {
                    var version = MakeSureLastVersionMatches(name, expectedVersion, conn, tx);

                    const string txt =
                           @"INSERT INTO ES_Events2 (CustomerId, Name, Version, Data)
                                VALUES(:customerId, :name, :version, :data)";

                    using (var cmd = new NpgsqlCommand(txt, conn, tx))
                    {
                        cmd.Parameters.AddWithValue(":name", name);
                        cmd.Parameters.AddWithValue(":version", version+1);
                        cmd.Parameters.AddWithValue(":data", data);
                        cmd.Parameters.AddWithValue(":customerId", customerId);
                        cmd.ExecuteNonQuery();
                    }
                    tx.Commit();
                }
            }
        }
開發者ID:pshomov,項目名稱:frog,代碼行數:25,代碼來源:SqlEventStore.cs

示例7: SalvarGrupo

 public void SalvarGrupo(GrupclienteDto entidade)
 {
     using (var conn = new NpgsqlConnection(Connectionstring))
     {
         conn.Open();
         using (var trans = conn.BeginTransaction())
         {
             try
             {
                 using (
                     var cmd =
                         new NpgsqlCommand(
                             "INSERT INTO grupcliente (grcl_nome, grcl_ativo,empr_codigo) values ('" + entidade.grcl_nome + "'," + entidade.grcl_ativo + ","+entidade.empr_codigo+")", conn,
                             trans))
                 {
                     cmd.ExecuteNonQuery();
                     trans.Commit();
                 }
             }
             catch (Exception)
             {
                 trans.Rollback();
             }
         }
     }
 }
開發者ID:thiagomoreiraboby,項目名稱:SuporteOnline,代碼行數:26,代碼來源:Clientes.cs

示例8: NpgsqlConnection

        //Ska detta vara med?
        /*   public static List<string> GetGolfSpelarInfo(int GolfId)
        {
            List<string> medlemslista = new List<string>();
            ConnectionStringSettings settings = ConfigurationManager.ConnectionStrings[conString];
            NpgsqlConnection conn = new NpgsqlConnection(settings.ConnectionString);
            conn.Open();
            NpgsqlCommand command2 = new NpgsqlCommand(@"SELECT *
                                                        FROM
                                                          golfspelare
                                                           WHERE
                                                          golf_id = :GolfId;
                                                        ", conn);

            command2.Parameters.Add(new NpgsqlParameter("GolfId", DbType.Int32));
            command2.Parameters[0].Value = Convert.ToString(GolfId);
            NpgsqlDataReader dr = command2.ExecuteReader();
            while (dr.Read())
            {
                medlemslista.Add((string)dr["*"]);
            }
            conn.Close();
            return medlemslista;
        }*/
        public static void AddSpelareTillTävling(string Fornamn, string Efternamn, string Tävlingsnamn)
        {
            ConnectionStringSettings settings = ConfigurationManager.ConnectionStrings[conString];
            NpgsqlConnection conn = new NpgsqlConnection(settings.ConnectionString);
            NpgsqlTransaction trans = null;
            try
            {
                conn.Open();
                trans = conn.BeginTransaction();

                NpgsqlCommand command3 = new NpgsqlCommand(@"SELECT golf_id
                                                        FROM golfspelare
                                                        WHERE fornamn = :Fornamn
                                                        AND efternamn =:Efternamn", conn);
                command3.Parameters.Add(new NpgsqlParameter("Fornamn", DbType.String));
                command3.Parameters[0].Value = Fornamn;
                command3.Parameters.Add(new NpgsqlParameter("Efternamn", DbType.String));
                command3.Parameters[1].Value = Efternamn;
                command3.Transaction = trans;
                int GolfId = (int)command3.ExecuteScalar();

                //Tävlingsnamn är tomt när den anropas
                NpgsqlCommand command4 = new NpgsqlCommand(@"SELECT id
                                                        FROM tavling
                                                        WHERE tavlingsnamn = :TävlingsNamn", conn);
                command4.Parameters.Add(new NpgsqlParameter("TävlingsNamn", DbType.String));
                command4.Parameters[0].Value = Tävlingsnamn;
                command4.Transaction = trans;
                int TävlingsID = (int)command4.ExecuteScalar();

             /*       NpgsqlCommand command4 = new NpgsqlCommand(@"SELECT id
                                                        FROM tavling
                                                        WHERE tavlingsnamn = :TävlingsNamn", conn);
                command4.Parameters.Add(new NpgsqlParameter("tavlingsnamn", DbType.String));
                command4.Parameters[0].Value = Tävlingsnamn;
                command4.Transaction = trans;
                int TävlingsID = (int)command4.ExecuteScalar(); */

                NpgsqlCommand command5 = new NpgsqlCommand(@"INSERT INTO spelar_resultat (golf_id, tavlings_id)
                                                        VALUES (:GolfId, :TävlingsID)", conn);
                command5.Parameters.Add(new NpgsqlParameter("GolfId", DbType.Int32));
                command5.Parameters[0].Value = GolfId;
                command5.Parameters.Add(new NpgsqlParameter("TävlingsID", DbType.Int32));
                command5.Parameters[1].Value = TävlingsID;
                command5.Transaction = trans;
                int numberOfAffectedRows = command5.ExecuteNonQuery();
                trans.Commit();
            }
            catch (NpgsqlException ex)
            {
                trans.Rollback();
            }
            finally
            {
                conn.Close();
            }
        }
開發者ID:rikardw,項目名稱:golfkoll,代碼行數:81,代碼來源:Databas.cs

示例9: PostgreSqlTransaction

        public PostgreSqlTransaction(NpgsqlConnection connection)
        {
            if (connection.State != ConnectionState.Open)
            {
                connection.Open();
            }

            _transaction = connection.BeginTransaction(IsolationLevel.Serializable);
        }
開發者ID:mantasaudickas,項目名稱:database-migrator,代碼行數:9,代碼來源:PostgreSqlTransaction.cs

示例10: DownloadQuestao

        public void DownloadQuestao(Dominio.Questao questao)
        {
            Dominio.Configuracao configuracao = new Dominio.Configuracao();

            string caminhoEntrada = System.IO.Path.Combine(configuracao.CaminhoSalvarSubmissoes, questao.ArquivoEntrada);
            string caminhoSaida = System.IO.Path.Combine(configuracao.CaminhoSalvarSubmissoes, questao.ArquivoSaida);

            NpgsqlConnection conexao = new NpgsqlConnection("Server=187.45.196.224;Database=bubblesort9;User ID=bubblesort9;Password=BSboca;");

            NpgsqlTransaction transacao = null;
            try
            {
                conexao.Open();

                transacao = conexao.BeginTransaction();

                LargeObjectManager lbm = new LargeObjectManager(conexao);

                LargeObject lo = lbm.Open(questao.IdArquivoEntrada, LargeObjectManager.READ);

                FileStream fsout = File.OpenWrite(caminhoEntrada);

                byte[] buf = new byte[lo.Size()];

                buf = lo.Read(lo.Size());

                fsout.Write(buf, 0, (int)lo.Size());
                fsout.Flush();
                fsout.Close();
                lo.Close();

                lo = lbm.Open(questao.IdArquivoSaida, LargeObjectManager.READ);

                fsout = File.OpenWrite(caminhoSaida);

                byte[] buffer = new byte[lo.Size()];

                buffer = lo.Read(lo.Size());

                fsout.Write(buffer, 0, (int)lo.Size());
                fsout.Flush();
                fsout.Close();
                lo.Close();
                transacao.Commit();
            }
            catch
            {
                if (transacao != null)
                    transacao.Rollback();
                throw;
            }
            finally
            {
                conexao.Close();
            }
        }
開發者ID:danimaribeiro,項目名稱:Auto-Judge-Boca-Windows,代碼行數:56,代碼來源:RepositorioQuestao.cs

示例11: GetConnection

        /// <summary>
        /// Gets a fresh, open and ready-to-use connection wrapper
        /// </summary>
        public async Task<PostgresConnection> GetConnection()
        {
            var connection = new NpgsqlConnection(_connectionString);
            
            await connection.OpenAsync();

            var currentTransaction = connection.BeginTransaction(IsolationLevel.ReadCommitted);

            return new PostgresConnection(connection, currentTransaction);
        }
開發者ID:RichieYang,項目名稱:Rebus,代碼行數:13,代碼來源:PostgresConnectionHelper.cs

示例12: SaveExchangeRates

        public static long SaveExchangeRates(string catalog, int officeId, string baseCurrency, IEnumerable<ExchangeRate> exchangeRates)
        {
            using (NpgsqlConnection connection = new NpgsqlConnection(DbConnection.GetConnectionString(catalog)))
            {
                connection.Open();

                using (NpgsqlTransaction transaction = connection.BeginTransaction())
                {
                    try
                    {
                        string sql = "UPDATE core.exchange_rates SET status = false WHERE [email protected]";
                        using (NpgsqlCommand command = new NpgsqlCommand(sql, connection))
                        {
                            command.Parameters.AddWithValue("@OfficeId", officeId);
                            command.ExecuteNonQuery();
                        }

                        sql = "INSERT INTO core.exchange_rates(office_id, status) SELECT @OfficeId, true RETURNING exchange_rate_id;";

                        long exchangeRateId;
                        using (NpgsqlCommand er = new NpgsqlCommand(sql, connection))
                        {
                            er.Parameters.AddWithValue("@OfficeId", officeId);

                            exchangeRateId = Conversion.TryCastLong(er.ExecuteScalar());
                        }

                        foreach (ExchangeRate exchangeRate in exchangeRates)
                        {
                            sql =
                                "INSERT INTO core.exchange_rate_details(exchange_rate_id, local_currency_code, foreign_currency_code, unit, exchange_rate) " +
                                "SELECT @ExchangeRateId, @LocalCurrencyCode, @ForiegnCurrencyCode, 1, @ExchangeRate;";
                            using (NpgsqlCommand rate = new NpgsqlCommand(sql, connection))
                            {
                                rate.Parameters.AddWithValue("@ExchangeRateId", exchangeRateId);
                                rate.Parameters.AddWithValue("@LocalCurrencyCode", baseCurrency);
                                rate.Parameters.AddWithValue("@ForiegnCurrencyCode", exchangeRate.CurrencyCode);
                                rate.Parameters.AddWithValue("@ExchangeRate", exchangeRate.Rate);

                                rate.ExecuteNonQuery();
                            }
                        }

                        transaction.Commit();
                        return exchangeRateId;
                    }
                    catch (NpgsqlException ex)
                    {
                        Log.Warning(@"Could not update exchange rate. {Exception}", ex);
                        transaction.Rollback();
                        throw;
                    }
                }
            }
        }
開發者ID:roczj,項目名稱:mixerp,代碼行數:55,代碼來源:ExchangeRates.cs

示例13: Connection

        /// <summary>
        /// Initializes a new instance of the <see cref="Connection" /> class.
        /// </summary>
        /// <param name="connectionInfo">The connection information.</param>
        /// <param name="options">The options.</param>
        public Connection(IConnectionInformation connectionInfo,
            PostgreSqlMessageQueueTransportOptions options)
        {
            NpgsqlConnection = new NpgsqlConnection(connectionInfo.ConnectionString);
            NpgsqlConnection.Open();

            if (options.EnableHoldTransactionUntilMessageCommited)
            {
                NpgsqlTransaction = NpgsqlConnection.BeginTransaction(IsolationLevel.ReadCommitted);
            }
        }
開發者ID:blehnen,項目名稱:DotNetWorkQueue,代碼行數:16,代碼來源:Connection.cs

示例14: Setup

        public void Setup()
        {
            OnSetupBeforeTransaction();

            connection = new NpgsqlConnection("Server=127.0.0.1;Port=5432;Database=sampledb;User Id=philipp;Password=test_pwd;");
            connection.Open();

            transaction = connection.BeginTransaction();

            OnSetupInTransaction();
        }
開發者ID:bytefish,項目名稱:PostgreSQLCopyHelper,代碼行數:11,代碼來源:TransactionalTestBase.cs

示例15: Save

        public static bool Save(string catalog, int userId, string book, long id, Collection<Attachment> attachments)
        {
            const string sql =
                "INSERT INTO core.attachments(user_id, resource, resource_key, resource_id, original_file_name, file_extension, file_path, comment) " +
                "SELECT @UserId, core.attachment_lookup.resource, core.attachment_lookup.resource_key, @ResourceId, @OriginalFileName, @FileExtension, @FilePath, @Comment" +
                " FROM core.attachment_lookup WHERE [email protected];";

            using (NpgsqlConnection connection = new NpgsqlConnection(DbConnection.GetConnectionString(catalog)))
            {
                connection.Open();

                using (NpgsqlTransaction transaction = connection.BeginTransaction())
                {
                    if (attachments != null && attachments.Count > 0)
                    {
                        try
                        {
                            foreach (Attachment attachment in attachments)
                            {
                                using (NpgsqlCommand attachmentCommand = new NpgsqlCommand(sql, connection))
                                {
                                    attachmentCommand.Parameters.AddWithValue("@UserId", userId);
                                    attachmentCommand.Parameters.AddWithValue("@Book", book);
                                    attachmentCommand.Parameters.AddWithValue("@ResourceId", id);
                                    attachmentCommand.Parameters.AddWithValue("@OriginalFileName",
                                        attachment.OriginalFileName);
                                    attachmentCommand.Parameters.AddWithValue("@FileExtension",
                                        Path.GetExtension(attachment.OriginalFileName));
                                    attachmentCommand.Parameters.AddWithValue("@FilePath", attachment.FilePath);
                                    attachmentCommand.Parameters.AddWithValue("@Comment", attachment.Comment);

                                    attachmentCommand.ExecuteNonQuery();
                                }
                            }

                            transaction.Commit();
                            return true;
                        }
                        catch (NpgsqlException)
                        {
                            Log.Warning(
                                @"Could not insert attachment into database. Book: {Book}, Id: {Id}, Attachments: {Attachments}.\n{Sql}",
                                book, id, attachments, sql);

                            transaction.Rollback();
                            return false;
                        }
                    }
                }
            }

            return false;
        }
開發者ID:roczj,項目名稱:mixerp,代碼行數:53,代碼來源:Attachments.cs


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