<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    Custom queries in Liferay(custom-sql)

    Prerequisites

    You should know how to create services with Service Builder. Also, you should know a little about SQL: the basic syntax and a notion on how it is used inside programming language code.

    The steps described here were performed over Liferay 6.0.6.

    Service.xml

    One part of service.xml :

    <entity name="Geschaeft" local-service="true" remote-service="false" table="Geschäfte">

        
    <!-- PK fields -->
        
    <column name="ID" db-name="[ID]" type="int" primary="true" />

        
    <!-- Other fields -->    
        
    <column name="Jahr" db-name="[Jahr]" type="Date" />
        
    <column name="Beschaffungsstrategie" db-name="[Beschaffungsstrategie]" type="String" />
        
    <column name="BuchVon" db-name="[Buch von]" type="String" />
        
    <column name="BuchNach" db-name="[Buch nach]" type="String" />
        
    <column name="Transaktionsdatum" db-name="[Transaktionsdatum]" type="Date" />
        
    <column name="Auftragsnummer" db-name="[Auftragsnummer]" type="String" />
        
    <column name="BeschaffungsZeitraumBeginn" db-name="[Besch#Zeitraum Beginn]" type="Date" />
        
    <column name="BeschaffungsZeitraumEnde" db-name="[Besch#Zeitraum Ende]" type="Date" />
        
    <column name="AnkaufVerkauf" db-name="[Ankauf/Verkauf]" type="String" />
        
    <column name="Geschaeftstyp" db-name="[Geschäftstyp]" type="String" />
        
    <column name="Produkt" db-name="[Produkt]" type="String" />
        
    <column name="LaufzeitVon" db-name="[Laufzeit von]" type="Date" />
        
    <column name="LaufzeitBis" db-name="[Laufzeit bis]" type="Date" />
        
    <column name="Sonderprodukt" db-name="[Sonderprodukt]" type="String" />
        
    <column name="KennzeichnungAuftraggeber" db-name="[Kennzeichnung des Auftraggebers]" type="String" />
        
    <column name="Abrechnungsrelevanz" db-name="[Abrechnungsrelevanz]" type="String" />
        
    <column name="FrueherePMSID" db-name="[Frühere PMS-ID oder Nr# Geschäftsimport]" type="String" /> 


        
    <!-- Order -->
        
    <order by="asc">
            
    <order-column name="Jahr" />
        
    </order>
            
    </entity>

     

    Let us beginning

    1.       Create a folder named “custom-sql” in source root.

    2.       Create a file named ” default.xml”, and type the following code. that mean that tell liferay to read others file from here.

    <?xml version="1.0"?>

    <custom-sql>
        
    <sql file="custom-sql/geschaeft.xml" />
        
    <sql file="custom-sql/otherTable.xml" />
        ..
        ..
    </custom-sql>

    3.       Create the .xml file which was added in default.xml.  and type the following code.

    <?xml version="1.0"?>

    <custom-sql>
        
    <sqlid="com.quantum.service.persistence.GeschaeftFinder.getAll">
          
    <![CDATA[
                SELECT
                        *
                FROM
                    Geschäfte
            
    ]]>
        
    </sql>
        
    <sql id="com.quantum.service.persistence.GeschaeftFinder.getList">
            
    <![CDATA[
                SELECT 
    CASE WHEN [Buch von] <> 'Standardbuch' THEN [Buch von] ELSE [Buch nach] END AS Portfolio,
                     [ID],
                     [Auftragsnummer]
                FROM Geschäfte
                WHERE CASE WHEN [Buch von] <> 'Standardbuch' THEN [Buch von] ELSE [Buch nach] END IN ('Spotmarkt','Krefeld A')
                AND [Frühere PMS-ID oder Nr# Geschäftsimport] NOT LIKE 'Q_%'
                AND Produkt <> 'intern_Spot'
                AND Produkt <> 'intern_EEG'
            
    ]]>
        
    </sql>
    </custom-sql>

     

     

    4.       Create a new class named “GeschaeftFinderImpl” in  com.quantum.service.persistence package, and extends BasePersistenceImpl, implements GeschaeftFinder which is not exist  so far. Don’t care about it. Continue type the following code:

    package com.quantum.service.persistence;

    import java.util.Iterator;
    import java.util.List;

    import com.liferay.portal.kernel.dao.orm.QueryUtil;
    import com.liferay.portal.kernel.dao.orm.SQLQuery;
    import com.liferay.portal.kernel.dao.orm.Session;
    import com.liferay.portal.kernel.dao.orm.Type;
    import com.liferay.portal.kernel.exception.SystemException;
    importcom.liferay.portal.service.persistence.impl.BasePersistenceImpl;
    import com.liferay.util.dao.orm.CustomSQLUtil;
    import com.quantum.model.Geschaeft;
    import com.quantum.model.impl.GeschaeftImpl;

    /**
     * 
     * 
    @author noah.xiang
     *
     
    */

    public class GeschaeftFinderImpl extendsBasePersistenceImpl<Geschaeft> implements GeschaeftFinder{
        
    private static String GETLIST = GeschaeftFinder.class.getName() + ".getList";
        
    private static String GETALL = GeschaeftFinder.class.getName() + ".getAll";

        
    public List<Geschaeft> getALL() throws SystemException {

            Session session 
    = null;

            
    try {
                session 
    = openSession();
                System.out.println(
    ">>>>>>>>>>>> "+ GETALL);
                String sql 
    = CustomSQLUtil.get(GETLIST);
                

                SQLQuery q 
    = session.createSQLQuery(sql);

                
    //q.addEntity("Geschäfte", GeschaeftImpl.class);
                q.addScalar("Portfolio", Type.STRING);
                q.addScalar(
    "ID", Type.INTEGER);
                q.addScalar(
    "Auftragsnummer", Type.STRING);

                Iterator
    <Object[]> itr = (Iterator<Object[]>)QueryUtil.iterate(q, getDialect(), -1-1);
                
    while (itr.hasNext()) {
                    Object[] array 
    = itr.next();
                    String portfolio 
    = (String)array[0];
                    
    int userId = (Integer)array[1];
                    String auftragsnummer 
    = (String)array[2];
                    System.out.println(
    ">>>>> "+ userId +"  "+ auftragsnummer+ " "+ portfolio);
                    
                }

                
    //List<Geschaeft> list = q.list();
                
                
    return null;
            }
     catch (Exception e) {
                
    throw new SystemException(e);
            }
     finally {
                closeSession(session);
            }

        }

    }

     

    5.       So far have many errors in your eclipse. But it doesn’t matter. Just ant build-service.xml. liferay will generate relevant code for us.

    6.       Find GeschaeftLocalServiceImpl class in com.quantum.service.impl package.  And create a method named public List<Geschaeft> getAll() throws SystemException. For the method you can rename whatever you want.

    public List<Geschaeft> getAll() throws SystemException{

                return geschaeftFinder.getALL();

          }

    7.       So far, all of configuration is finish. Go to action to call the method, like this:

    List<Geschaeft> geschaeft = GeschaeftLocalServiceUtil.getAll();

    8.       ant build-service.xml again. 

    9.       Wish you success! Think you.

     

     

    直接寫的英文版的,不想再翻譯回來了。都不難理解,一看就能明白。不懂的請留言



    眼鏡蛇

    posted on 2011-10-27 17:44 眼鏡蛇 閱讀(2023) 評論(1)  編輯  收藏 所屬分類: Liferay

    評論

    # re: Custom queries in Liferay(custom-sql) 2013-05-08 13:30 Rasmi

    The entity that I'm creating doesnt have any columns, is that the reason why Finder and FinderUtil are not getting generated for me?  回復(fù)  更多評論   

    <2025年5月>
    27282930123
    45678910
    11121314151617
    18192021222324
    25262728293031
    1234567

    導(dǎo)航

    統(tǒng)計(jì)

    常用鏈接

    留言簿(6)

    隨筆分類

    隨筆檔案

    文章分類

    文章檔案

    搜索

    最新評論

    閱讀排行榜

    評論排行榜

    主站蜘蛛池模板: 中国国语毛片免费观看视频| 国产精品久久亚洲不卡动漫 | 国产亚洲欧美在线观看| 亚洲理论片在线中文字幕| 中文字幕亚洲综合久久| 久久精品亚洲综合| 精品国产综合成人亚洲区| 国产亚洲美日韩AV中文字幕无码成人| 亚洲精品无码激情AV| 亚洲成a人片在线观看国产| 亚洲另类少妇17p| 亚洲一级片免费看| 亚洲人成网站观看在线播放 | 免费看又黄又无码的网站| 日本免费一区二区三区四区五六区 | vvvv99日韩精品亚洲| 亚洲av无码不卡私人影院| 久久久久亚洲?V成人无码| 亚洲日韩中文字幕在线播放| 亚洲精品~无码抽插| 亚洲成在人天堂在线| 亚洲网站在线免费观看| 亚洲人成网站在线观看播放动漫| 亚洲情A成黄在线观看动漫软件 | 亚洲人成片在线观看| 中文字幕无码精品亚洲资源网久久| 亚洲AV一区二区三区四区| 麻豆安全免费网址入口| 中文字幕免费在线视频| 少妇太爽了在线观看免费视频 | 婷婷国产偷v国产偷v亚洲| 西西人体大胆免费视频| 韩国免费A级毛片久久| 91av视频免费在线观看| 中字幕视频在线永久在线观看免费| 成人毛片18女人毛片免费视频未| 免费v片在线观看| 国产成人亚洲综合无码精品 | 久久亚洲高清综合| 亚洲精品中文字幕乱码影院 | 亚洲AV本道一区二区三区四区|