IBM Netezza SQL translation guide
IBM Netezza data warehousing is designed to work with Netezza-specific SQL syntax. Netezza SQL is based on Postgres 7.2. SQL scripts written for Netezza can't be used in a BigQuery data warehouse without alterations, because the SQL dialects vary.
This document details the similarities and differences in SQL syntax between Netezza and BigQuery in the following areas:
- Data types
- SQL language elements
- Query syntax
- Data manipulation language (DML)
- Data definition language (DDL)
- Stored procedures
- Functions
You can also use batch SQL translation to migrate your SQL scripts in bulk, or interactive SQL translation to translate ad-hoc queries. IBM Netezza SQL/NZPLSQL is supported by both tools in preview.
Data types
| Netezza | BigQuery | Notes | 
|---|---|---|
| INTEGER/INT/INT4 | INT64 | |
| SMALLINT/INT2 | INT64 | |
| BYTEINT/INT1 | INT64 | |
| BIGINT/INT8 | INT64 | |
| DECIMAL | NUMERIC | The DECIMALdata type
in Netezza is      an
alias for theNUMERICdata type. | 
| NUMERIC] | NUMERICINT64 | |
| NUMERIC(p,s) | NUMERIC | The NUMERICtype in
BigQuery does not
enforce custom digit or
scale bounds
(constraints) like
Netezza does. BigQuery
has fixed 9 digits
after the decimal,
while Netezza allows a
custom setup. In
Netezza, precisionpcan range from 1 to 38,
and scalesfrom 0 to
the precision. | 
| FLOAT(p) | FLOAT64 | |
| REAL/FLOAT(6) | FLOAT64 | |
| DOUBLE PRECISION/FLOAT(14) | FLOAT64 | |
| CHAR/CHARACTER | STRING | The STRINGtype in
BigQuery is
variable-length and
does not require
manually setting a max
character length as the
NetezzaCHARACTERandVARCHARtypes
require.   The default
value ofninCHAR(n)is 1. The maximum
character string size
is 64,000. | 
| VARCHAR | STRING | The STRINGtype in
BigQuery is
variable-length and
does not require
manually setting a max
character length as the
NetezzaCHARACTERandVARCHARtypes
require.  The maximum
character string size
is 64,000. | 
| NCHAR | STRING | The STRINGtype in
BigQuery is stored as
variable length UTF-8
encoded Unicode. The
maximum length is
16,000 characters. | 
| NVARCHAR | STRING | The STRINGtype in
BigQuery is stored as
variable-length
UTF-8-encoded Unicode.
The maximum length is
16,000 characters. | 
| VARBINARY | BYTES | |
| ST_GEOMETRY | GEOGRAPHY | |
| BOOLEAN/BOOL | BOOL | The BOOLtype in
BigQuery can only
acceptTRUE/FALSE,
unlike theBOOLtype
in Netezza, which can
accept a variety of
values like0/1,yes/no,true/false,on/off. | 
| DATE | DATE | |
| TIME | TIME | |
| TIMETZ/TIME WITH TIME ZONE | TIME | Netezza stores the TIMEdata type in UTC
and lets you pass
an offset from UTC
using theWITH TIME
ZONEsyntax. TheTIMEdata type in
BigQuery represents a
time that's independent
of any date or time
zone. | 
| TIMESTAMP | DATETIME | The Netezza TIMESTAMPtype does not include a
time zone, the same as
the BigQueryDATETIMEtype. | 
| ARRAY | There is no array data type in Netezza. The array type is instead stored in a varchar field. | 
Timestamp and date type formatting
When you convert date type formatting elements from Netezza to
GoogleSQL, you must pay particular attention to time zone
differences between TIMESTAMP and DATETIME, as summarized in the
following table:
| Netezza | BigQuery | 
|---|---|
| CURRENT_TIMESTAMPCURRENT_TIMETIMEinformation
in Netezza can have
different time zone
information, which
is defined using
theWITH TIME ZONEsyntax. | If possible, use the CURRENT_TIMESTAMPfunction,
which is formatted
correctly. However,
the output format
does not always show the
UTC time zone
(internally,
BigQuery does not
have a time zone).
TheDATETIMEobject in the
bq command-line tool and
Google Cloud console is
formatted using aTseparator
according to RFC
3339. However, in
Python and Java
JDBC, a space is
used as a separator.
Use the explicitFORMAT_DATETIMEfunction
to define the date
format correctly.
Otherwise, an
explicit cast is
made to a string,
for example:CAST(CURRENT_DATETIME() AS STRING)This also returns a space separator. | 
| CURRENT_DATE | CURRENT_DATE | 
| CURRENT_DATE-3 | BigQuery does not
support arithmetic
data operations.
Instead, use the DATE_ADDfunction. | 
SELECT statement
Generally, the Netezza SELECT statement is compatible with
BigQuery. The following table contains a list of exceptions:
| Netezza | BigQuery | 
|---|---|
| A SELECTstatement
      withoutFROMclause | Supports special case such as the following: 
 | 
| SELECT (subquery) AS flag, CASE WHEN flag = 1 THEN ... | In BigQuery, columns cannot reference
    the output of other columns
    defined within the same query. You must duplicate the logic or move
    the logic into a nested query. Option 1 SELECT (subquery) AS flag, CASE WHEN (subquery) = 1 THEN ... Option 2 
SELECT
  q.*,
  CASE WHEN flag = 1 THEN ...
FROM (
  SELECT
    (subquery) AS flag,
    ...
  ) AS q
 | 
Comparison operators
| Netezza | BigQuery | Description | 
|---|---|---|
| exp = exp2 | exp = exp2 | Equal | 
| exp <= exp2 | exp <= exp2 | Less than or equal to | 
| exp < exp2 | exp < exp2 | Less than | 
| exp <> exp2exp != exp2 | exp <> exp2exp != exp2 | Not equal | 
| exp >= exp2 | exp >= exp2 | Greater than or equal to | 
| exp > exp2 | exp > exp2 | Greater than | 
Built-in SQL functions
| Netezza | BigQuery | Description | 
|---|---|---|
| CURRENT_DATE | CURRENT_DATE | Get the current date (year, month, and day). | 
| CURRENT_TIME | CURRENT_TIME | Get the current time with fraction. | 
| CURRENT_TIMESTAMP | CURRENT_TIMESTAMP | Get the current system date and time, to the nearest full second. | 
| NOW | CURRENT_TIMESTAMP | Get the current system date and time, to the nearest full second. | 
| COALESCE(exp, 0) | COALESCE(exp, 0) | Replace NULLwith
zero. | 
| NVL(exp, 0) | IFNULL(exp, 0) | Replace NULLwith
zero. | 
| EXTRACT(DOY FROM
timestamp_expression) | EXTRACT(DAYOFYEAR FROM
timestamp_expression) | Return the number of days from the beginning of the year. | 
| ADD_MONTHS(date_expr,
num_expr) | DATE_ADD(date,
INTERVAL k MONTH) | Add months to a date. | 
| DURATION_ADD(date,
k) | DATE_ADD(date,
INTERVAL k DAY) | Perform addition on dates. | 
| DURATION_SUBTRACT(date,
k) | DATE_SUB(date,
INTERVAL k DAY) | Perform subtraction on dates. | 
| str1 || str2 | CONCAT(str1,
str2) | Concatenate strings. | 
Functions
This section compares Netezza and BigQuery functions.
Aggregate functions
| Netezza | BigQuery | 
|---|---|
| ANY_VALUE | |
| APPROX_COUNT_DISTINCT | |
| APPROX_QUANTILES | |
| APPROX_TOP_COUNT | |
| APPROX_TOP_SUM | |
| AVG | AVG | 
| intNand | BIT_AND | 
| intNnot | Bitwise not operator: ~ | 
| intNor | BIT_OR | 
| intNxor | BIT_XOR | 
| intNshl | |
| intNshr | |
| CORR | CORR | 
| COUNT | COUNT | 
| COUNTIF | |
| COVAR_POP | COVAR_POP | 
| COVAR_SAMP | COVAR_SAMP | 
| GROUPING | |
| LOGICAL_AND | |
| LOGICAL_OR | |
| MAX | MAX | 
| MIN | MIN | 
| MEDIAN | PERCENTILE_CONT(x, 0.5) | 
| STDDEV_POP | STDDEV_POP | 
| STDDEV_SAMP | STDDEV_SAMPSTDDEV | 
| STRING_AGG | |
| SUM | SUM | 
| VAR_POP | VAR_POP | 
| VAR_SAMP | VAR_SAMPVARIANCE | 
Analytical functions
| Netezza | BigQuery | 
|---|---|
| ANY_VALUE | |
| ARRAY_AGG | |
| ARRAY_CONCAT | ARRAY_CONCAT_AGG | 
| ARRAY_COMBINE | |
| ARRAY_COUNT | |
| ARRAY_SPLIT | |
| ARRAY_TYPE | |
| AVG | AVG | 
| intNand | BIT_AND | 
| intNnot | Bitwise not operator: ~ | 
| intNor | BIT_OR | 
| intNxor | BIT_XOR | 
| intNshl | |
| intNshr | |
| CORR | CORR | 
| COUNT | COUNT | 
| COUNTIF | |
| COVAR_POP | COVAR_POP | 
| COVAR_SAMP | COVAR_SAMP | 
| CUME_DIST | CUME_DIST | 
| DENSE_RANK | DENSE_RANK | 
| FIRST_VALUE | FIRST_VALUE | 
| LAG | LAG | 
| LAST_VALUE | LAST_VALUE | 
| LEAD | LEAD | 
| AND | LOGICAL_AND | 
| OR | LOGICAL_OR | 
| MAX | MAX | 
| MIN | MIN | 
| NTH_VALUE | |
| NTILE | NTILE | 
| PERCENT_RANK | PERCENT_RANK | 
| PERCENTILE_CONT | PERCENTILE_CONT | 
| PERCENTILE_DISC | PERCENTILE_DISC | 
| RANK | RANK | 
| ROW_NUMBER | ROW_NUMBER | 
| STDDEV | STDDEV | 
| STDDEV_POP | STDDEV_POP | 
| STDDEV_SAMP | STDDEV_SAMP | 
| STRING_AGG | |
| SUM | SUM | 
| VARIANCE | VARIANCE | 
| VAR_POP | VAR_POP | 
| VAR_SAMP | VAR_SAMPVARIANCE | 
| WIDTH_BUCKET | 
Date and time functions
String functions
| Netezza | BigQuery | 
|---|---|
| ASCII | TO_CODE_POINTS(string_expr)[OFFSET(0)] | 
| BYTE_LENGTH | |
| TO_HEX | |
| CHAR_LENGTH | |
| CHARACTER_LENGTH | |
| CODE_POINTS_TO_BYTES | |
| BTRIM | |
| CHR | CODE_POINTS_TO_STRING([numeric_expr]) | 
| CONCAT | |
| DBL_MP | |
| DLE_DST | |
| ENDS_WITH | |
| FORMAT | |
| FROM_BASE32 | |
| FROM_BASE64 | |
| FROM_HEX | |
| HEX_TO_BINARY | |
| HEX_TO_GEOMETRY | |
| INITCAP | |
| INSTR | |
| INT_TO_STRING | |
| LE_DST | |
| LENGTH | LENGTH | 
| LOWER | LOWER | 
| LPAD | LPAD | 
| LTRIM | LTRIM | 
| NORMALIZE | |
| NORMALIZE_AND_CASEFOLD | |
| PRI_MP | |
| REGEXP_CONTAINS | |
| REGEXP_EXTRACT | REGEXP_EXTRACT | 
| REGEXP_EXTRACT_ALL | REGEXP_EXTRACT_ALL | 
| REGEXP_EXTRACT_ALL_SP | |
| REGEXP_EXTRACT_SP | |
| REGEXP_INSTR | STRPOS(col,REGEXP_EXTRACT()) | 
| REGEXP_LIKE | |
| REGEXP_MATCH_COUNT | |
| REGEXP_REPLACE | REGEXP_REPLACE | 
| REGEXP_REPLACE_SP | IF(REGEXP_CONTAINS,1,0) | 
| REGEXP_EXTRACT | |
| REPEAT | REPEAT | 
| REPLACE | |
| REVERSE | |
| RPAD | RPAD | 
| RTRIM | RTRIM | 
| SAFE_CONVERT_BYTES_TO_STRING | |
| SCORE_MP | |
| SEC_MP | |
| SOUNDEX | |
| SPLIT | |
| STARTS_WITH | |
| STRING_TO_INT | |
| STRPOS | STRPOS | 
| SUBSTR | SUBSTR | 
| TO_BASE32 | |
| TO_BASE64 | |
| TO_CHAR | |
| TO_DATE | |
| TO_NUMBER | |
| TO_TIMESTAMP | |
| TO_CODE_POINTS | |
| TO_HEX | |
| TRANSLATE | |
| TRIM | |
| UPPER | UPPER | 
| UNICODE | |
| UNICODES | 
Math functions
| Netezza | BigQuery | 
|---|---|
| ABS | ABS | 
| ACOS | ACOS | 
| ACOSH | |
| ASIN | ASIN | 
| ASINH | |
| ATAN | ATAN | 
| ATAN2 | ATAN2 | 
| ATANH | |
| CEILDCEIL | CEIL | 
| CEILING | |
| COS | COS | 
| COSH | |
| COT | COT | 
| DEGREES | |
| DIV | |
| EXP | EXP | 
| FLOORDFLOOR | FLOOR | 
| GREATEST | GREATEST | 
| IEEE_DIVIDE | |
| IS_INF | |
| IS_NAN | |
| LEAST | LEAST | 
| LN | LN | 
| LOG | LOG | 
| LOG10 | |
| MOD | MOD | 
| NULLIF(expr, 0) | |
| PI | ACOS(-1) | 
| POWFPOW | POWERPOW | 
| RADIANS | |
| RANDOM | RAND | 
| ROUND | ROUND | 
| SAFE_DIVIDE | |
| SETSEED | |
| SIGN | SIGN | 
| SIN | SIN | 
| SINH | |
| SQRTNUMERIC_SQRT | SQRT | 
| TAN | TAN | 
| TANH | |
| TRUNC | TRUNC | 
| IFNULL(expr, 0) | 
DML syntax
This section compares Netezza and BigQuery DML syntax.
INSERT statement
| Netezza | BigQuery | 
|---|---|
| INSERT INTO table VALUES (...); | INSERT INTO table (...) VALUES (...); Netezza offers a DEFAULTkeyword and other constraints
for columns. In BigQuery, omitting column names in theINSERTstatement is valid only if all columns are
given. | 
| INSERT INTO table (...) VALUES (...); INSERT INTO table (...) VALUES (...); | INSERT INTO table VALUES (), (); BigQuery imposes DML quotas, which restrict the number of DML statements you can execute daily. To make the best use of your quota, consider the following approaches: 
 
 
 | 
DML scripts in BigQuery have slightly different consistency
semantics than the equivalent statements in Netezza. Also note that
BigQuery does not offer constraints apart from NOT
NULL.
For an overview of snapshot isolation and session and transaction handling, see Consistency guarantees and transaction isolation.
UPDATE statement
In Netezza, the WHERE clause is optional, but in BigQuery it is
necessary.
| Netezza | BigQuery | 
|---|---|
| UPDATE tbl SET tbl.col1=val1; | Not supported without the WHEREclause.
      Use aWHERE trueclause to update all rows. | 
| UPDATE A SET y = B.y, z = B.z + 1 FROM B WHERE A.x = B.x AND A.y IS NULL; | UPDATE A SET y = B.y, z = B.z + 1 FROM B WHERE A.x = B.x AND A.y IS NULL; | 
| UPDATE A alias SET x = x + 1 WHERE f(x) IN (0, 1) | UPDATE A SET x = x + 1 WHERE f(x) IN (0, 1); | 
| UPDATE A SET z = B.z FROM B WHERE A.x = B.x AND A.y = B.y | UPDATE A SET z = B.z FROM B WHERE A.x = B.x AND A.y = B.y; | 
For examples, see
UPDATE examples.
Because of DML quotas,
we recommend that you use larger MERGE statements instead of multiple single
UPDATE and INSERT statements. DML scripts in BigQuery have
slightly different consistency semantics than equivalent statements in Netezza.
For an overview of snapshot isolation and session and transaction handling, see
Consistency guarantees and transaction isolation.
DELETE and TRUNCATE statements
The DELETE and TRUNCATE statements are both ways to remove rows from a table
without affecting the table schema or indexes. The TRUNCATE statement has the
same effect as the DELETE statement, but is much faster than the DELETE
statement for large tables. The TRUNCATE statement is supported in Netezza but
not supported in BigQuery. However, you can use DELETE
statements in both Netezza and BigQuery.
In BigQuery, the DELETE statement must have a WHERE clause.
In Netezza, the WHERE clause is optional. If the WHERE clause is not
specified, all the rows in the Netezza table are deleted.
| Netezza | BigQuery | Description | 
|---|---|---|
| BEGIN; LOCK TABLE A IN EXCLUSIVE MODE; DELETE FROM A; INSERT INTO A SELECT * FROM B; COMMIT; | Replacing the contents of a table with query output is
      the equivalent of a transaction. You can do this with either a queryor a copy (cp)
operation.bq query \ bq cp \ | Replace the contents of a table with the results of a query. | 
| DELETE FROM database.table | DELETE FROM table WHERE TRUE; | In Netezza, when a delete statement is run, the rows
      are not deleted physically but only marked for deletion. Running the GROOM TABLEornzreclaimcommands later removes
      the rows marked for deletion and reclaims the corresponding disk space. | 
| GROOM
TABLE | Netezza uses the GROOM TABLEcommand to
      reclaim disk space by removing rows marked for deletion. | 
MERGE statement
A MERGE statement must match at most one source row for each target row. DML
scripts in BigQuery have slightly different consistency semantics
than the equivalent statements in Netezza. For an overview of snapshot isolation
and session and transaction handling, see
Consistency guarantees and transaction isolation.
For examples, see
BigQuery MERGE examples
and
Netezza MERGE examples.
DDL syntax
This section compares Netezza and BigQuery DDL syntax.
CREATE TABLE statement
| Netezza | BigQuery | Description | 
|---|---|---|
| TEMPTEMPORARY | With BigQuery's DDL
support, you can
create a table from
the results of a query
and specify its
expiration at creation
time. For example, for
three days: CREATE TABLE'my-project.public_dump.vtemp'OPTIONS(expiration_timestamp=TIMESTAMP_ADD(CURRENT_TIMESTAMP(),INTERVAL 3 DAY)) | Create tables temporary to a session. | 
| ZONE MAPS | Not supported. | Quick search for WHEREcondition. | 
| DISTRIBUTE ON | PARTITION BY | Partitioning.
This is not a direct translation. DISTRIBUTE ONshares data
between nodes, usually with a unique key for even distribution,
whilePARTITION BYprunes data into segments. | 
| ORGANIZE ON | CLUSTER BY | Both Netezza and BigQuery support up to four keys for clustering. Netezza clustered base tables (CBT) provide equal precedence to each of the clustering columns. BigQuery gives precedence to the first column on which the table is clustered, followed by the second column, and so on. | 
| ROW SECURITY | Authorized View | Row-level security. | 
| CONSTRAINT | Not supported | Check constraints. | 
DROP statement
| Netezza | BigQuery | Description | 
|---|---|---|
| DROP TABLE | DROP TABLE | |
| DROP DATABASE | DROP DATABASE | |
| DROP VIEW | DROP VIEW | 
Column options and attributes
| Netezza | BigQuery | Description | 
|---|---|---|
| NULLNOT NULL | NULLABLEREQUIRED | Specify if the column is
allowed to contain NULLvalues. | 
| REFERENCES | Not supported | Specify column constraint. | 
| UNIQUE | Not supported | Each value in the column must be unique. | 
| DEFAULT | Not supported | Default value for all values in the column. | 
Temporary tables
Netezza supports
TEMPORARY tables
that exist during the duration of a session.
To build a temporary table in BigQuery, do the following:
- Create a dataset that has a short time to live (for example, 12 hours).
- Create the temporary table in the dataset, with a table name prefix of - temp. For example, to create a table that expires in one hour, do this:- CREATE TABLE temp.name (col1, col2, ...) OPTIONS(expiration_timestamp = TIMESTAMP_ADD(CURRENT_TIMESTAMP(), INTERVAL 1 HOUR)); 
- Start reading and writing from the temporary table. 
You can also remove duplicates independently in order to find errors in downstream systems.
Note that BigQuery does not support DEFAULT and IDENTITY
(sequences) columns.
Procedural SQL statements
Netezza uses the NZPLSQL scripting language to work with stored procedures. NZPLSQL is based on Postgres' PL/pgSQL language. This section describes how to convert procedural SQL statements used in stored procedures, functions, and triggers from Netezza to BigQuery.
CREATE PROCEDURE statement
Netezza and BigQuery both support creating stored procedures
by using the
CREATE PROCEDURE
statement. For more information, see
Work with SQL stored procedures.
Variable declaration and assignment
| Netezza | BigQuery | Description | 
|---|---|---|
| DECLARE var
datatype(len) [DEFAULT
value]; | DECLARE | Declare variable. | 
| SET var = value; | SET | Assign value to variable. | 
Exception handlers
Netezza supports exception handlers that can be triggered for certain error conditions. BigQuery does not support condition handlers.
| Netezza | BigQuery | Description | 
|---|---|---|
| EXCEPTION | Not supported | Declare SQL exception handler for general errors. | 
Dynamic SQL statements
Netezza supports dynamic SQL queries inside stored procedures. BigQuery does not support dynamic SQL statements.
| Netezza | BigQuery | Description | 
|---|---|---|
| EXECUTE IMMEDIATEsql_str; | EXECUTE IMMEDIATEsql_str; | Execute dynamic SQL. | 
Flow-of-control statements
| Netezza | BigQuery | Description | 
|---|---|---|
| IF THEN ELSE STATEMENTIFconditionTHEN ...ELSE ...END IF; | IFconditionTHEN ...ELSE ...END IF; | Execute conditionally. | 
| Iterative Control FOR var AS SELECT ...DOstmtsEND FOR;FOR var AS cur CURSORFOR SELECT ...DO stmts END FOR; | Not supported | Iterate over a collection of rows. | 
| Iterative Control LOOP stmts END LOOP; | LOOPsql_statement_list END LOOP; | Loop block of statements. | 
| EXIT WHEN | BREAK | Exit a procedure. | 
| WHILE *condition* LOOP | WHILEconditionDO ...END WHILE | Execute a loop of statements until a while condition fails. | 
Other statements and procedural language elements
| Netezza | BigQuery | Description | 
|---|---|---|
| CALLproc(param,...) | Not supported | Execute a procedure. | 
| EXECproc(param,...) | Not supported | Execute a procedure. | 
| EXECUTEproc(param,...) | Not supported | Execute a procedure. | 
Multi-statement and multi-line SQL statements
Both Netezza and BigQuery support transactions (sessions) and therefore support statements separated by semicolons that are consistently executed together. For more information, see Multi-statement transactions.
Other SQL statements
| Netezza | BigQuery | Description | 
|---|---|---|
| GENERATE
STATISTICS | Generate statistics for all the tables in the current database. | |
| GENERATE
STATISTICS ON
table_name | Generate statistics for a specific table. | |
| GENERATE
STATISTICS ON
table_name(col1,col4) | Either use
statistical functions
like MIN, MAX, AVG,etc., use the UI, or
use the Cloud Data Loss Prevention API. | Generate statistics for specific columns in a table. | 
| GENERATE
STATISTICS ON
table_name | APPROX_COUNT_DISTINCT(col) | Show the number of unique values for columns. | 
| INSERT INTO
table_name | INSERT INTO
table_name | Insert a row. | 
| LOCK TABLEtable_name FOREXCLUSIVE; | Not supported | Lock row. | 
| SET SESSIONCHARACTERISTICS ASTRANSACTION ISOLATION
LEVEL... | BigQuery always uses Snapshot Isolation. For details, see Consistency guarantees and transaction isolation. | Define the transaction isolation level. | 
| BEGIN TRANSACTIONEND TRANSACTIONCOMMIT | BigQuery always uses Snapshot Isolation. For details, see Consistency guarantees and transaction isolation. | Define the transaction boundary for multi-statement requests. | 
| EXPLAIN... | Not supported. Similar features in the query plan and timeline | Show query plan for a SELECTstatement. | 
| User Views
metadata System Views metadata | SELECT* EXCEPT(is_typed)FROMmydataset.INFORMATION_SCHEMA.TABLES;BigQuery Information Schema | Query objects in the database | 
Consistency guarantees and transaction isolation
Both Netezza and BigQuery are atomic, that is,
ACID compliant on
a per-mutation level across many rows. For example, a MERGE operation is
completely atomic, even with multiple inserted values.
Transactions
Netezza syntactically accepts all four modes of ANSI SQL
transaction isolation.
However, regardless of what mode is specified, only the SERIALIZABLE mode is
used, which provides the highest possible level of consistency. This mode also
avoids dirty, non repeatable, and phantom reads between concurrent transactions.
Netezza does not use conventional
locking
to enforce consistency. Instead, it uses
serialization dependency checking,
a form of optimistic concurrency control to automatically roll back the latest
transaction when two transactions attempt to modify the same data.
BigQuery also supports transactions. BigQuery helps ensure optimistic concurrency control (first to commit has priority) with snapshot isolation, in which a query reads the last committed data before the query starts. This approach ensures the same level of consistency on a per-row, per-mutation basis and across rows within the same DML statement, yet avoids deadlocks. In the case of multiple DML updates against the same table, BigQuery switches to pessimistic concurrency control. Load jobs can run completely independently and append to tables.
Rollback
Netezza supports the
ROLLBACK TRANSACTION statement
to abort the current transaction and rollback all the changes made in the
transaction.
In BigQuery, you can use the
ROLLBACK TRANSACTION statement.
Database limits
| Limit | Netezza | BigQuery | 
|---|---|---|
| Tables per database | 32,000 | Unrestricted | 
| Columns per table | 1600 | 10000 | 
| Maximum row size | 64 KB | 100 MB | 
| Column and table name length | 128 bytes | 16,384 Unicode characters | 
| Rows per table | Unlimited | Unlimited | 
| Maximum SQL request length | 1 MB (maximum
unresolved standard
SQL query length). 12 MB (maximum resolved legacy and standard SQL query length). Streaming: 10 MB (HTTP request size limit) 10,000 (maximum rows per request) | |
| Maximum request and response size | 10 MB (request) and 10 GB (response) or virtually unlimited if using pagination or the Cloud Storage API. | |
| Maximum number of concurrent sessions | 63 concurrent read-write transactions. 2000 concurrent connections to the server. | 100 concurrent queries (can be raised with slot reservation), 300 concurrent API requests per user. | 
What's next
- Get step-by-step instructions to Migrate from IBM Netezza to BigQuery.