Modify transaction fields

When submitting a transaction to the Hedera network, various fields can be modified, such as the transaction ID, consensus time, memo field, account ID of the node, and the maximum fee. These values can be set using methods provided by the SDKs. However, they are not required as the SDK can automatically create or use default values.

Note: The total size for a given transaction is limited to 6KiB.

Fields

Description

Transaction ID

Set the ID for this transaction. The transaction ID includes the operator's account ( the account paying the transaction fee). If two transactions have the same transaction ID, they won't both have an effect. One will complete normally and the other will fail with a duplicate transaction status.

Normally, you should not use this method. Just before a transaction is executed, a transaction ID will be generated from the operator on the client.

Valid Duration

Set the duration that this transaction is valid for

Note: Max network valid duration is 180 seconds. SDK default value is 120 seconds. The minium valid duration period is 15 seconds.

Memo

Set a note or description that should be recorded in the transaction record (maximum length of 100 characters). Anyone can view this memo on the network

Node ID

Set the account ID of the node that this transaction will be submitted to.

Max transaction fee

Set the max transaction fee for the operator (transaction fee payer account) is willing to pay

Default: 2 hbar

Note: The SDKs do not require you to set these fields when submitting a transaction to a Hedera network. All methods below are optional and can be used to modify any fields.

Method
Type

setTransactionID(<transactionId>)

TransactionID

setTransactionValidDuration(<validDuration>)

Duration

setTransactionMemo(<memo>)

String

setNodeAccountIds(<nodeAccountIds>)

List<AccountId>

setMaxTransactionFee(<maxTransactionFee>)

Hbar

setGrpcDeadline(<grpcDeadline>)

Duration

setRegenerateTransactionId(<regenerateTransactionId>)

boolean

Account Alias

If an alias is set during account creation, it becomes immutable, meaning it cannot be changed. If you plan to update or rotate keys in the future, do not set the alias at the time of initial account creation. The alias can be set after finalizing all key updates.

//Create the transaction and set the transaction properties
Transaction transaction = new AccountCreateTransaction() //Any transaction can be applied here
    .setKey(ecdsaPublicKey)
    //Do NOT set an alias if you need to update/rotate keys in the future
    .setAlias(ecdsaPublicKey.toEvmAddress())
    .setInitialBalance(new Hbar(1))
    .setMaxTransactionFee(new Hbar(2)) //Set the max transaction fee to 2 hbar
    .setTransactionMemo("Transaction memo"); //Set the node ID to submit the transaction to
    
//v2.0.0

Get transaction properties

Method
Type

getTransactionID()

TransactionID

getTransactionValidDuration()

Duration

getTransactionMemo()

String

getNodeAccountId()

AccountID

getMaxTransactionFee()

Hbar

getTransactionHash()

byte[ ]

getTransactionHashPerNode()

Map<AccountId, byte [ ]>

getSignatures()

Map<AccountId, Map<PublicKey, byte [ ]>>

//Create the transaction and set the transaction properties
Transaction transaction = new AccountCreateTransaction() //Any transaction can be applied here
    .setInitialBalance(Hbar.fromTinybars(1000))
    .setMaxTransactionFee(new Hbar(50)) //Set the max transaction fee to 50 hbar
    .setNodeAccountId(new AccountId(3)) //Set the node ID to submit the transaction to
    .setTransactionMemo("Transaction memo"); //Add a transaction memo
    
Hbar maxTransactionFee = transaction.getMaxTransactionFee();
//v2.0.0

Last updated