Data Types
A Data Type refers to how the data is stored in memory and how many bytes that data needs.
The data type of a variable (or object) tells the compiler the size of the object.
You should always try and use the data type that uses the smallest number of bytes.
All variables must have an associated data type which determines what data can be stored in it.
Array | (a) array of Integer, Double, String (av) array as a single variant |
Boolean (True or False / 0) | (b) zero (and default value) is False, everything else is True, use NOT to toggle 2 bytes (16 bits) Conversion - CBool |
Byte (0 to 255) | (by) very small positive integers, use Long instead 1 byte (8 bits) Conversion - CByte |
Currency (- 9.2 E+14 to + 9.2 E+14) | (c) scaled integer, use Double instead 8 bytes (64 bits) Conversion - CCur, Declaration Character - @ |
Date (Jan 1 100 to Dec 31 9999) | (dt) floating point numbers 8 bytes (64 bits) Conversion - CDate |
Decimal* (- 7.9 E+28 to + 7.9 E+28) | (dv) Variant subtype Must be declared as a Variant and then converted using the CDec function 14 bytes (112 bits) Conversion - CDec |
Double (- 1.8 E+308 to + 4.9 E+324) | (db) double precision floating point for decimals 8 bytes (64 bits) Conversion - CDbl, Declaration Character - # |
Integer (- 32,768 to + 32,767) | (i) small integers, use Long instead 2 bytes (16 bits) Conversion - CInt, Declaration Character - % |
Long (- 2.1 E+9 to + 2.1 E+9) | (l) very large integers 4 bytes (32 bits) Conversion - CLng, Declaration Character - & |
LongLong | (ll) Added in Office 2010, VBA 7.0 Conversion - CLngLng, Declaration Character - ^ |
LongPtr | (lp) Added in Office 2010, VBA 7.0 LongLong on 64 bit, Long on 32 bit Conversion - CLngPtr |
Object | (o) stored as a reference to an object, default value is Nothing 4 bytes (32 bits) |
Single (- 1.3 E+38 to + 1.3 E+38) | (sg) single precision floating point for decimals, use Double instead 4 bytes (32 bits) Conversion - CSng, Declaration Character - ! |
String | (s) fixed and variable length, default value "" 10 bytes + length Conversion - CStr, Declaration Character - $ |
User Defined | (ud) for the variables (type_) for the actual user defined type |
Variant | (v) any data type, often used for arrays, default value is Empty 16 - 22 bytes |
Array (a) array of Integer, Double, String (av) array as a single variant |
Boolean (True or False / 0) (b) zero (and default value) is False, everything else is True, use NOT to toggle 2 bytes (16 bits) Conversion - CBool |
Byte (0 to 255) (by) very small positive integers, use Long instead 1 byte (8 bits) Conversion - CByte |
Currency (- 9.2 E+14 to + 9.2 E+14) (c) scaled integer, use Double instead 8 bytes (64 bits) Conversion - CCur, Declaration Character - @ |
Date (Jan 1 100 to Dec 31 9999) (dt) floating point numbers 8 bytes (64 bits) Conversion - CDate |
Decimal* (- 7.9 E+28 to + 7.9 E+28) (dv) Variant subtype Must be declared as a Variant and then converted using the CDec function 14 bytes (112 bits) Conversion - CDec |
Double (- 1.8 E+308 to + 4.9 E+324) (db) double precision floating point for decimals 8 bytes (64 bits) Conversion - CDbl, Declaration Character - # |
Integer (- 32,768 to + 32,767) (i) small integers, use Long instead 2 bytes (16 bits) Conversion - CInt, Declaration Character - % |
Long (- 2.1 E+9 to + 2.1 E+9) (l) very large integers 4 bytes (32 bits) Conversion - CLng, Declaration Character - & |
LongLong (ll) Added in Office 2010, VBA 7.0 Conversion - CLngLng, Declaration Character - ^ |
LongPtr (lp) Added in Office 2010, VBA 7.0 LongLong on 64 bit, Long on 32 bit Conversion - CLngPtr |
Object (o) stored as a reference to an object, default value is Nothing 4 bytes (32 bits) |
Single (- 1.3 E+38 to + 1.3 E+38) (sg) single precision floating point for decimals, use Double instead 4 bytes (32 bits) Conversion - CSng, Declaration Character - ! |
String (s) fixed and variable length, default value "" 10 bytes + length Conversion - CStr, Declaration Character - $ |
User Defined (ud) for the variables (type_) for the actual user defined type |
Variant (v) any data type, often used for arrays, default value is Empty 16 - 22 bytes |
Data Type Characters
These are also known as Type Declaration Suffixes
It is possible declare variables by appending a special character to the end of the variable name.
Dim iNumber% 'integer
This method of declaring variables should not be used and is only available for backwards compatibility purposes.
© 2025 Better Solutions Limited. All Rights Reserved. © 2025 Better Solutions Limited TopNext