2016-05-23 12:32:02 +00:00
|
|
|
// Copyright © 2016 Abcum Ltd
|
|
|
|
//
|
|
|
|
// Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
// you may not use this file except in compliance with the License.
|
|
|
|
// You may obtain a copy of the License at
|
|
|
|
//
|
|
|
|
// http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
//
|
|
|
|
// Unless required by applicable law or agreed to in writing, software
|
|
|
|
// distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
// See the License for the specific language governing permissions and
|
|
|
|
// limitations under the License.
|
|
|
|
|
|
|
|
package sql
|
|
|
|
|
2016-09-20 23:34:21 +00:00
|
|
|
func (p *parser) parseDefineTableStatement() (stmt *DefineTableStatement, err error) {
|
2016-05-23 12:32:02 +00:00
|
|
|
|
2017-11-16 20:53:13 +00:00
|
|
|
stmt = &DefineTableStatement{RW: true}
|
2016-05-23 12:32:02 +00:00
|
|
|
|
2016-11-04 11:25:53 +00:00
|
|
|
if stmt.KV, stmt.NS, stmt.DB, err = p.o.get(AuthDB); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2016-05-23 12:32:02 +00:00
|
|
|
|
2017-03-02 10:47:10 +00:00
|
|
|
if stmt.What, err = p.parseTables(); err != nil {
|
2016-05-23 12:32:02 +00:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
2016-11-26 13:39:03 +00:00
|
|
|
for {
|
|
|
|
|
2017-11-16 20:53:13 +00:00
|
|
|
tok, _, exi := p.mightBe(DROP, SCHEMAFULL, SCHEMALESS, PERMISSIONS, AS)
|
2016-11-26 13:39:03 +00:00
|
|
|
if !exi {
|
|
|
|
break
|
|
|
|
}
|
|
|
|
|
2017-11-16 20:53:13 +00:00
|
|
|
if p.is(tok, DROP) {
|
|
|
|
stmt.Drop = true
|
|
|
|
}
|
|
|
|
|
2016-11-26 13:39:03 +00:00
|
|
|
if p.is(tok, SCHEMAFULL) {
|
|
|
|
stmt.Full = true
|
|
|
|
}
|
|
|
|
|
|
|
|
if p.is(tok, SCHEMALESS) {
|
|
|
|
stmt.Full = false
|
|
|
|
}
|
|
|
|
|
|
|
|
if p.is(tok, PERMISSIONS) {
|
2017-11-16 20:53:13 +00:00
|
|
|
if stmt.Perms, err = p.parsePerms(); err != nil {
|
2016-11-26 13:39:03 +00:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-11-16 20:53:13 +00:00
|
|
|
if p.is(tok, AS) {
|
|
|
|
|
|
|
|
stmt.Lock = true
|
|
|
|
|
|
|
|
_, _, _ = p.mightBe(LPAREN)
|
|
|
|
|
|
|
|
_, _, err = p.shouldBe(SELECT)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if stmt.Expr, err = p.parseFields(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
_, _, err = p.shouldBe(FROM)
|
|
|
|
if err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if stmt.From, err = p.parseTables(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if stmt.Cond, err = p.parseCond(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
if stmt.Group, err = p.parseGroup(); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
_, _, _ = p.mightBe(RPAREN)
|
|
|
|
|
|
|
|
if err = checkExpression(rolls, stmt.Expr, stmt.Group); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2016-10-14 20:31:45 +00:00
|
|
|
|
2016-05-23 12:32:02 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-09-20 23:34:21 +00:00
|
|
|
func (p *parser) parseRemoveTableStatement() (stmt *RemoveTableStatement, err error) {
|
2016-05-23 12:32:02 +00:00
|
|
|
|
2017-11-16 20:53:13 +00:00
|
|
|
stmt = &RemoveTableStatement{RW: true}
|
2016-05-23 12:32:02 +00:00
|
|
|
|
2016-11-04 11:25:53 +00:00
|
|
|
if stmt.KV, stmt.NS, stmt.DB, err = p.o.get(AuthDB); err != nil {
|
|
|
|
return nil, err
|
|
|
|
}
|
2016-05-23 12:32:02 +00:00
|
|
|
|
2017-03-02 10:47:10 +00:00
|
|
|
if stmt.What, err = p.parseTables(); err != nil {
|
2016-05-23 12:32:02 +00:00
|
|
|
return nil, err
|
|
|
|
}
|
|
|
|
|
|
|
|
return
|
|
|
|
|
|
|
|
}
|