SQLFlow is a bridge that connects a SQL engine (e.g., MySQL, Hive, or MaxCompute) and TensorFlow and other machine learning toolkits. SQLFlow extends the SQL syntax to enable model training, prediction, and analysis.
This language guide elaborates SQLFlow extended syntax and feature column API. For specific examples, please refer to the tutorial.
Let's assume iris flower data set stored in table iris.train
. The first four columns (petal_length, petal_width, sepal_length, sepal_width) represent the features and the last column (class) represents the labels.
sepal_length | sepal_width | petal_length | petal_width | class |
---|---|---|---|---|
6.4 | 2.8 | 5.6 | 2.2 | 2 |
5.0 | 2.3 | 3.3 | 1.0 | 1 |
... | ... | ... | ... |
Let's train a DNNClassifier
, which has two hidden layers where each layer has ten hidden units, and then save the trained model into table sqlflow_models.my_dnn_model
for making predictions later on.
Instead of writing a Python program with a lot of boilerplate code, this can be achieved easily via the following statement in SQLFlow.
SELECT * FROM iris.train
TO TRAIN DNNClassifer
WITH hidden_units = [10, 10], n_classes = 3, EPOCHS = 10
COLUMN sepal_length, sepal_width, petal_length, petal_width
LABEL class
INTO sqlflow_models.my_dnn_model;
SQLFlow will then parse the above statement and translate it to an equivalent Python program.
A SQLFlow training statement consists of a sequence of select, train, column, label, and into clauses.
SELECT select_expr [, select_expr ...]
FROM table_references
[WHERE where_condition]
[LIMIT row_count]
TO TRAIN model_identifier
[WITH
model_attr_expr [, model_attr_expr ...]
[, train_attr_expr ...]]
COLUMN column_expr [, column_expr ...]
| COLUMN column_expr [, column_expr ...] FOR column_name
[COLUMN column_expr [, column_expr ...] FOR column_name ...]
[LABEL label_expr]
INTO table_references;
The select statement describes the data retrieved from a particular table, e.g., SELECT * FROM iris.train
.
SELECT select_expr [, select_expr ...]
FROM table_references
[WHERE where_condition]
[LIMIT row_count]
According to ANSI SQL Standards,
- each select_expr indicates a column that you want to retrieve. There must be at least one select_expr.
- table_references indicates the table from which to retrieve rows.
- where_condition is an expression that evaluates to true for each row to be selected.
- row_count indicates the maximum number of rows to be retrieved.
For example, if you want to quickly prototype a binary classifier on a subset of the sample data, you can write the following statement:
SELECT *
FROM iris.train
WHERE class = 0 OR class = 1
LIMIT 1000
TO TRAIN ...
The train clause describes the specific model type and the way the model is trained, e.g. TO TRAIN DNNClassifer WITH hidden_units = [10, 10], n_classes = 3, EPOCHS = 10
.
TO TRAIN model_identifier
WITH
model_attr_expr [, model_attr_expr ...]
[, train_attr_expr ...]
- model_identifier indicates the model type. e.g.
DNNClassifier
. Please refer to Models for a complete list of supported models. - model_attr_expr indicates the model attribute. e.g.
model.n_classes = 3
. Please refer to Models for details. - train_attr_expr indicates the training attribute. e.g.
train.epoch = 10
. Please refer to Hyperparameters for details.
For example, if you want to train a DNNClassifier
, which has two hidden layers where each layer has ten hidden units, with ten epochs, you can write the following statement:
SELECT ...
TO TRAIN DNNClassifer
WITH
model.hidden_units = [10, 10],
model.n_classes = 3,
train.epoch = 10
...
The column clause indicates the field name for training features, along with their optional pre-processing methods, e.g. COLUMN sepal_length, sepal_width, petal_length, petal_width
.
COLUMN column_expr [, column_expr ...]
| COLUMN column_expr [, column_expr ...] FOR column_name
[COLUMN column_expr [, column_expr ...] FOR column_name ...]
- column_expr indicates the field name and the preprocessing method on the field content. e.g.
sepal_length
,DENSE(dense, 3)
. Please refer to Feature columns for preprocessing details. - column_name indicates the feature column names for the model inputs. Some models such as DNNLinearCombinedClassifier have
linear_feature_columns
anddnn_feature_columns
as feature column input.
For example, if you want to use fields sepal_length
, sepal_width
, petal_length
, and petal_width
as the features without any pre-processing, you can write the following statement:
SELECT ...
TO TRAIN ...
COLUMN sepal_length, sepal_width, petal_length, petal_width
...
The label clause indicates the field name for the training label, along with their optional pre-processing methods, e.g. LABEL class
.
LABEL label_expr
- label_expr indicates the field name and the pre-processing method on the field content, e.g.
class
. For unsupervised learning job, we should skip the label clause.
Note: some field names may look like SQLFlow keywords. For example, the table may contain a field named "label". You can use double quotes around the name LABEL "label"
to work around the parsing error.
The into clause indicates the table name to save the trained model into:
INTO table_references
- table_references indicates the table to save the trained model. e.g.
sqlflow_model.my_dnn_model
.
Note: SQLFlow team is actively working on supporting saving model to third-party storage services such as AWS S3, Google Storage, and Alibaba OSS.
SQLFlow supports specifying various feature columns in the column clause and label clause. Below are the currently supported feature columns:
feature column type | usage | field type | example |
---|---|---|---|
X | field | int/float/double | 3.14 |
DENSE | DENSE(field, n[,delimiter]) | string/varchar[n] | "0.2,1.7,0.6" |
SPARSE | SPARSE(field, n[,delimiter]) | string/varchar[n] | "3,5,7" |
CATEGORY_ID | CATEGORY_ID(field, n[,delimiter]) | string/varchar[n] | "66,67,42,68,48,69,70" |
SEQ_CATEGORY_ID | SEQ_CATEGORY_ID(field, n[, delimiter]) | string/varchar[n] | "20,48,80,81,82,0,0,0,0" |
EMBEDDING | EMBEDDING(category_column, dimension[, combiner]) | X | X |
DENSE(field, n[, delimiter=comma])
/*
DENSE converts a delimiter separated string to a n dimensional dense tensor.
field:
A string specifying the field name of the standard select result.
e.g. dense, column1.
n:
An integer specifying the tensor dimension.
e.g. 12, [3,4].
delimiter:
A string specifying the delimiter.
default: comma.
Example:
DENSE(dense, 3). "0.2,1.7,0.6" => Tensor(0.2, 1.7, 0.6)
Error:
Invalid field type. Field type has to be string/varchar[n].
Invalid dimension. E.g. convert "0.2,1.7,0.6" to dimension 2.
*/
SPARSE(field, n[, delimiter=comma])
/*
SPARSE converts a delimiter separated string to a n dimensional sparse tensor,
whose values are 0 or 1. The numbers in the string are the indices where the
tensor values are 1.
field:
A string specifying the field name of the standard select result.
e.g. sparse_column, column1.
n:
An integer specifying the tensor dimension.
e.g. 12.
delimiter:
A string specifying the delimiter.
default: comma.
Example:
SPARSE(sparse_column, 8). "3,5,7" => Tensor(0, 0, 0, 1, 0, 1, 0, 1)
Error:
Invalid field type. Field type has to be string/varchar[n].
*/
CATEGORY_ID(field, n[, delimiter=comma])
/*
CATEGORY_ID splits the input field by delimiter and returns identity values.
field:
A string specifying the field name of the standard select result.
e.g. title, id, column1.
n:
An integer specifying the number of buckets
e.g. 12, 10000.
delimiter:
A string specifying the delimiter.
default: comma.
Example:
CATEGORY_ID(title, 100). "1,2,3,4" => Tensor(1, 2, 3, 4)
Error:
Invalid field type. Field type has to be string/varchar[n].
*/
SEQ_CATEGORY_ID(field, n[, delimiter=comma])
/*
SEQ_CATEGORY_ID splits the input field by delimiter and returns identity values.
field:
A string specifying the field name of the standard select result.
e.g. title, id, column1.
n:
An integer specifying the number of buckets
e.g. 12, 10000.
delimiter:
A string specifying the delimiter.
default: comma.
Example:
SEQ_CATEGORY_ID(title, 100). "1,2,3,4" => Tensor(1, 2, 3, 4)
Error:
Invalid field type. Field type has to be string/varchar[n].
*/
EMBEDDING(category_column, n[, combiner])
/*
EMBEDDING converts a delimiter separated string to an n-dimensional tensor.
category_column:
A category column created by CATEGORY_ID*
e.g. CATEGORY_ID(title, 100).
n:
An integer specifying the dimension of the embedding, must be > 0.
e.g. 12, 100.
combiner:
A string specifying how to reduce if there are multiple entries in a single row.
Example:
EMBEDDING(CATEGORY_ID(news_title,16000,COMMA), 3, mean). "1,2,3" => Tensor(0.2, 1.7, 0.6)
*/
A SQLFlow prediction statement consists of a sequence of select, predict, and using clauses.
SELECT select_expr [, select_expr ...]
FROM table_references
[WHERE where_condition]
[LIMIT row_count]
TO PREDICT result_table_reference
[WITH
attr_expr [, attr_expr ...]]
USING model_table_reference;
Please be aware that the SELECT ...
statement before the TO PREDICT ...
and TO EXPLAIN ...
clause must generate the same data schema as the one before the TO TRAIN
clause does. This requirement ensures that the data used in prediction has the same schema as those used in training.
The select statement syntax is the same as the select statement syntax in the training syntax. SQLFlow uses the column name to guarantee the prediction data has the same order as the training data. For example, if we have used c1
, c2
, c3
and label
column to train a model, the select statement in the prediction job should also retrieve columns that contain exactly the same names.
The predict clause describes the result table that a prediction job should write to, the table a prediction job should load the model from, and necessary configuration attributes for a prediction job.
TO PREDICT result_table_reference
[WITH
attr_expr [, attr_expr ...]]
USING model_table_reference;
- result_table_reference indicates the table to store the prediction result. Please be aware that all the data retrieved by the select statement plus the prediction result will be stored.
- attr_expr indicates the configuration attributes, e.g.
predict.batch_size = 1
. - model_table_reference indicates the table a prediction job should load the model from.
For example, if we want to save the predicted result into table iris.predict
at column class
using the model stored at sqlflow.my_dnn_model
. We can write the following statement:
SELECT ...
TO PREDICT iris.predict.class
USING sqlflow.my_dnn_model;
A SQLFlow explanation statement consists of a sequence of select, explain, and using clauses.
SELECT select_expr [, select_expr ...]
FROM table_references
[WHERE where_condition]
[LIMIT row_count]
TO EXPLAIN model_table_reference
[WITH
attr_expr [, attr_expr ...]]
[USING explainer];
The select statement syntax is the same as the select statement syntax in the training syntax. SQLFlow uses the column name to guarantee the analysis data has the same order as the training data. For example, if we have used c1
, c2
, c3
and label
column to train a model, the select statement in the analysis job should also retrieve columns that contain the same names.
The explain clause describes the table an analysis job should load the model from, necessary configuration attributes, and the explainer for explanation.
TO EXPLAIN model_table_reference
[WITH
attr_expr [, attr_expr ...]]
USING explainer;
- model_table_reference indicates the table a prediction job should load model from.
- attr_expr indicates the configuration attributes, e.g.
summary.plot_type="bar"
. - explainer indicates the type of the explainer, e.g.
TreeExplainer
.
For example, if we want to explain the model stored at sqlflow_models.my_xgb_regression_model
using the tree explainer and plot the analysis results in sorted order. We can write the following statement:
SELECT *
FROM boston.train
TO EXPLAIN sqlflow_models.my_xgb_regression_model
WITH
summary.sort=True
USING TreeExplainer;
A SQLFlow prediction statement consists of select, evaluate, and into clauses.
SELECT select_expr [, select_expr ...]
FROM table_references
[WHERE where_condition]
[LIMIT row_count]
TO EVALUATE model_table_reference
[WITH
attr_expr [, attr_expr ...]]
INTO evaluate_result_table;
The SELECT statement before TO EVALUATE must generate the same data schema as that used in training. Please be aware that, by the machine learning theory, you are not supposed to use the training dataset for evaluation. If you do that, you are likely to see a very good evaluation result, which indeed, doesn't tell much useful information. Please write a SELECT statement as the prefix that generates different dataset but have the same schema.
The INTO clause names the table for saving evaluation results, which, in this example, is evaluate_result_table
.
The TO EVALUATE
clause specifies the model to evaluate, what metrics will be used for evaluation, and which table will be used to save the result.
TO EVALUATE model_table_reference
[WITH
attr_expr [, attr_expr ...]]
INTO evaluate_result_table;
- model_table_reference indicates that this model will be used to do the evaluation. The result metrics can show the performance of this model when using this model to predict "new" data.
- attr_expr sets attributes when doing evaluation. You can set
validation.metrics
to indicate which metrics will be outputed to the result table, e.g.validation.metrics="Accuracy,AUC"
, you can find more supported metric names for Keras models here and XGBoost models here. - evaluate_result_table is the result table that stores the evaluation results.
SQLFlow supports various TensorFlow pre-made estimators, Keras customized models, and XGBoost models. A full supported parameter list is under active construction, for now, please refer to the tutorial for example usage.