bool check_column_name(Token_stream& ts) {
Token t = ts.get();
if(t.kind == '(') {
while(t.kind != ')') {
t = ts.get();
if(t.kind == 'a' || t.kind == '0') {
string column_names = "";
while(t.kind != ' ' && t.kind != ')') {
column_names += t.value;
t = ts.get();
}
cout << column_names << endl;
}
}
return true;
}
}
我需要解析这个
(Column_name1 VARCHAR[20], Column_name2 VARCHAR[8], Column_name3 INTEGER);
我需要解析上面的行来调用 Create() 函数来创建一个表。解析该行后,我将能够知道我的列名将是什么,我的表中有多少列以及每列的类型是什么。例如,第一列的名称为“Column_name1”,其类型为“VARCHAR”,它是一个字符串。我的代码能够解析 (column_name1 Column_nam2) 但这不是我想要的。我想解析行 (Column_name1 VARCHAR[20], Column_name2 VARCHAR[8], Column_name3 INTEGER);。