📄 createview.java
字号:
/*
* Copyright 2004-2008 H2 Group. Licensed under the H2 License, Version 1.0
* (http://h2database.com/html/license.html).
* Initial Developer: H2 Group
*/
package org.h2.command.ddl;
import java.sql.SQLException;
import org.h2.command.dml.Query;
import org.h2.constant.ErrorCode;
import org.h2.engine.Database;
import org.h2.engine.Session;
import org.h2.message.Message;
import org.h2.schema.Schema;
import org.h2.table.TableView;
/**
* This class represents the statement
* CREATE VIEW
*/
public class CreateView extends SchemaCommand {
private Query select;
private String viewName;
private boolean ifNotExists;
private String selectSQL;
private String[] columnNames;
private String comment;
private boolean recursive;
public CreateView(Session session, Schema schema) {
super(session, schema);
}
public void setViewName(String name) {
viewName = name;
}
public void setRecursive(boolean recursive) {
this.recursive = recursive;
}
public void setSelect(Query select) {
this.select = select;
}
public int update() throws SQLException {
// TODO rights: what rights are required to create a view?
session.commit(true);
Database db = session.getDatabase();
if (getSchema().findTableOrView(session, viewName) != null) {
if (ifNotExists) {
return 0;
}
throw Message.getSQLException(ErrorCode.VIEW_ALREADY_EXISTS_1, viewName);
}
int id = getObjectId(true, true);
String querySQL;
if (select == null) {
querySQL = selectSQL;
} else {
querySQL = select.getSQL();
}
Session s = db.getSystemSession();
TableView view = new TableView(getSchema(), id, viewName, querySQL, null, columnNames, s, recursive);
view.setComment(comment);
db.addSchemaObject(session, view);
return 0;
}
public void setIfNotExists(boolean ifNotExists) {
this.ifNotExists = ifNotExists;
}
public void setSelectSQL(String selectSQL) {
this.selectSQL = selectSQL;
}
public void setColumnNames(String[] cols) {
this.columnNames = cols;
}
public void setComment(String comment) {
this.comment = comment;
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -