×
关于

Vaadin Web 开发教程

概述安装开发环境Vaadin 应用程序框架介绍开始编写 Web 应用Vaadin Web 应用的基本组成部分使用资源UI 组件概述UI 组件-LabelUI 組件-LinkUI 組件-TextFieldUI 組件-TextAreaUI 組件-PasswordFieldUI 組件-RichTextAreaUI 組件-ButtonUI 組件-CheckboxUI 组件-Select 组件UI 组件-Table 组件UI 组件-Tree 组件UI 组件-MenuBar 组件UI 组件-Embedded 组件UI 组件-Upload 组件UI 组件-Form 组件UI 组件-ProgressIndicator 组件UI 组件-Slider 组件UI 组件-LoginForm 组件UI 组件-自定义组件UI 布局-概述UI 布局-VerticalLayout 和 HorizontalLayout 布局UI 布局-GridLayout 布局UI 布局-FormLayout 布局UI 布局-PanelUI 布局-HorizontalSplitPanel 和 VerticalSplitPanel 布局UI 布局-TabSheet 布局UI 布局-Accordion 布局UI 布局-AbsoluteLayout 布局可視化界面編輯插件使用主题-概述使用主题-创建和应用新主题数据绑定-概述数据绑定-Property 接口使用 Item 介面管理一組 Property使用 Container 介面管理一組 ItemSQLContainer 概述开始使用 SQLContainerSQLContainer-过滤及排序SQLContainer-编辑SQLContainer-引用其它 SQLContainerSQLContainer-使用 FreeformQuery

SQLContainer-使用 FreeformQuery


在大部分情況下使用 TableQuery 就可以滿足應用要求,如果需要使用複雜查詢,比如多表查詢,則可以使用 FreeformQuery。 預設情況下 FreeformQuery 為只讀,如果需要支持寫操作,可以自行實現FreeformQueryDelegate 介面。

// Read-only queries
public StatementHelper getCountStatement()
public StatementHelper getQueryStatement(int offset, int limit)
public StatementHelper getContainsRowQueryStatement(Object... keys)

// Filtering and sorting
public void setFilters(List<Filter> filters)
public void setFilters(List<Filter> filters,
                       FilteringMode filteringMode)
public void setOrderBy(List<OrderBy> orderBys)

// Write support
public int storeRow(Connection conn, RowItem row)
public boolean removeRow(Connection conn, RowItem row)

本例使用多表查詢,查詢語句如下:

SELECT C.FIRSTNAME , C.LASTNAME , INV.ID,INV.TOTAL 
FROM CUSTOMER C 
INNER JOIN INVOICE INV
ON C.ID=INV.CUSTOMERID;
void openTable(VerticalLayout layout){
    try {
        JDBCConnectionPool pool = new SimpleJDBCConnectionPool(
                "org.hsqldb.jdbc.JDBCDriver",
                "jdbc:hsqldb:file:/hsqldb/data/sample", "SA", "", 2, 5);
        FreeformQuery query = new FreeformQuery(
                "SELECT C.FIRSTNAME , " +
                "C.LASTNAME , INV.ID,INV.TOTAL " +
                "FROM CUSTOMER C " +
                "INNER JOIN INVOICE INV " +
                "ON C.ID=INV.CUSTOMERID;", pool, "ID");
        SQLContainer container = new SQLContainer(query);
        Table table = new Table("All Invoices", container);
        table.setSelectable(true);

        layout.addComponent(table);

    } catch (SQLException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
    }
    }

到目前為止,基本介紹完 SQLContainer 的用法,不過整體來說 SQLContainer 雖然使用簡單方便,當功能有限,對應複雜的資料庫應用還是可以直接使用 JDBC 和 JPA 等。

Tags: Java EE, Vaadin, Web


分类导航

关注微信下载离线手册

bootwiki移动版 bootwiki
(群号:472910771)