鍍金池/ 教程/ Java/ SQLContainer-使用 FreeformQuery
UI 組件-自定義組件
UI 布局-Panel
UI 組件-Slider 組件
UI 組件-Button
UI 組件-PasswordField
UI 布局-TabSheet 布局
Vaadin Web 應(yīng)用的基本組成部分
UI 組件-Label
UI 組件-Link
UI 布局-GridLayout 布局
安裝開發(fā)環(huán)境
UI 組件-Tree 組件
UI組件-Select 組件
UI 布局-概述
UI 組件-RichTextArea
UI 組件-Table 組件
使用 Item 介面管理一組 Property
使用資源
UI 組件-TextArea
SQLContainer-編輯
SQLContainer-過(guò)濾及排序
UI 組件-TextField
UI 布局-HorizontalSplitPanel 和 VerticalSplitPanel 布局
SQLContainer-引用其它 SQLContainer
UI組件-ProgressIndicator組件
開始編寫 Web 應(yīng)用
UI組件-Form組件
UI 布局-Accordion 布局
SQLContainer-使用 FreeformQuery
SQLContainer 概述
使用主題-創(chuàng)建和應(yīng)用新主題
概述
UI 布局-AbsoluteLayout 布局
UI 組件-Upload 組件
使用主題-概述
UI 布局-FormLayout 布局
MenuBar 組件
UI 布局-VerticalLayout 和 HorizontalLayout 布局
UI 組件-Embedded 組件
UI 組件概述
使用 Container 介面管理一組 Item
UI 組件-LoginForm 組件
數(shù)據(jù)綁定-Property 接口
Vaadin 應(yīng)用程序框架介紹
開始使用 SQLContainer
UI 組件-Checkbox
可視化界面編輯插件
數(shù)據(jù)綁定-概述

SQLContainer-使用 FreeformQuery

在大部分情況下使用 TableQuery 就可以滿足應(yīng)用要求,如果需要使用複雜查詢,比如多表查詢,則可以使用 FreeformQuery。 預(yù)設(shè)情況下 FreeformQuery 為只讀,如果需要支持寫操作,可以自行實(shí)現(xiàn)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)

本例使用多表查詢,查詢語(yǔ)句如下:

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();
    }
    }

http://wiki.jikexueyuan.com/project/vaadin-web-development-tutorial/images/113.png" alt="" />

到目前為止,基本介紹完 SQLContainer 的用法,不過(guò)整體來(lái)說(shuō) SQLContainer 雖然使用簡(jiǎn)單方便,當(dāng)功能有限,對(duì)應(yīng)複雜的資料庫(kù)應(yīng)用還是可以直接使用 JDBC 和 JPA 等。

Tags: Java EE, Vaadin, Web