forked from docs/doc-exports
Reviewed-by: Pruthi, Vineet <vineet.pruthi@t-systems.com> Co-authored-by: Su, Xiaomeng <suxiaomeng1@huawei.com> Co-committed-by: Su, Xiaomeng <suxiaomeng1@huawei.com>
247 lines
20 KiB
HTML
247 lines
20 KiB
HTML
<a name="dli_08_15035"></a><a name="dli_08_15035"></a>
|
|
|
|
<h1 class="topictitle1">Result Table</h1>
|
|
<div id="body0000001718627124"><div class="section" id="dli_08_15035__section102271660319"><h4 class="sectiontitle">Function</h4><p id="dli_08_15035__p28331612932">Flink SQL jobs write to the Doris result table.</p>
|
|
</div>
|
|
<div class="section" id="dli_08_15035__section5611103820312"><h4 class="sectiontitle">Prerequisites</h4><ul id="dli_08_15035__ul66761330172912"><li id="dli_08_15035__li13676330102913">An enhanced datasource connection has been created for DLI to connect to Doris, so that jobs can run on the dedicated queue of DLI and you can set the security group rules as required.
|
|
</li><li id="dli_08_15035__li1380793232118"><strong id="dli_08_15035__b477295711920">If MRS Doris is used, IP addresses of all hosts in the MRS cluster have been added to host information of the enhanced datasource connection.</strong><p id="dli_08_15035__p1679341219"></p>
|
|
<p id="dli_08_15035__p1290940152113">For details, see "Modifying Host Information" in <em id="dli_08_15035__i125187181365">Data Lake Insight User Guide</em>.</p>
|
|
</li><li id="dli_08_15035__en-us_topic_0000001549411578_li516015511901"><span id="dli_08_15035__ph1777831600483">Kerberos authentication is disabled for the cluster (the cluster is in normal mode)</span><p id="dli_08_15035__en-us_topic_0000001549411578_p63621633512">After connecting to Doris as user <strong id="dli_08_15035__b4365637161914">admin</strong>, create a role with administrator permissions, and bind the role to the user.</p>
|
|
</li></ul>
|
|
</div>
|
|
<div class="section" id="dli_08_15035__section1465831815212"><h4 class="sectiontitle">Caveats</h4><ul id="dli_08_15035__ul322397111719"><li id="dli_08_15035__li13608118132418">When you create a Flink OpenSource SQL job, set <strong id="dli_08_15035__dli_08_15029_b163001353185217">Flink Version</strong> to <strong id="dli_08_15035__dli_08_15029_b1430115539523">1.15</strong> in the <strong id="dli_08_15035__dli_08_15029_b1030175315523">Running Parameters</strong> tab. Select <strong id="dli_08_15035__dli_08_15029_b430135325212">Save Job Log</strong>, and specify the OBS bucket for saving job logs.</li><li id="dli_08_15035__li980192610493">Storing authentication credentials such as usernames and passwords in code or plaintext poses significant security risks. It is recommended using DEW to manage credentials instead. Storing encrypted credentials in configuration files or environment variables and decrypting them when needed ensures security. For details, see .</li><li id="dli_08_15035__li106441816124218"><span id="dli_08_15035__ph98444732483">Kerberos authentication is disabled for the cluster (the cluster is in normal mode)</span></li><li id="dli_08_15035__li1257525562010">Doris table names are case sensitive.</li><li id="dli_08_15035__li7613141714020">When Doris of CloudTable is used, set the port number in the <strong id="dli_08_15035__b4214142121918">fenodes</strong> field to <strong id="dli_08_15035__b152141342191918">8030</strong>, for example, <em id="dli_08_15035__i15215942101915">xx</em><strong id="dli_08_15035__b621624214198">:8030</strong>. In addition, enable ports <strong id="dli_08_15035__b29851844101919">8030</strong>, <strong id="dli_08_15035__b18986154410198">8040</strong>, and <strong id="dli_08_15035__b9987174411195">9030</strong> in the security group.</li><li id="dli_08_15035__li1024325917145">After HTTPS is enabled, add the following configuration parameters to the <strong id="dli_08_15035__b1050827717488">with</strong> clause for creating a table:<ul id="dli_08_15035__ul19464113016433"><li id="dli_08_15035__li346443094319"><strong id="dli_08_15035__b17846193319435">'doris.enable.https' = 'true'</strong></li><li id="dli_08_15035__li546473044311"><strong id="dli_08_15035__b18851103324310">'doris.ignore.https.ca' = 'true'</strong></li></ul>
|
|
</li><li id="dli_08_15035__li84771594241">On the <strong id="dli_08_15035__b1719956134417">Running Parameters</strong> tab of the Flink job editing page, check <strong id="dli_08_15035__b879053015442">Enable Checkpointing</strong>. Otherwise, data can be written to the Doris result table, and the delay in writing to Doris depends on the value set for <strong id="dli_08_15035__b789383811475">Checkpoint Interval</strong>.</li></ul>
|
|
</div>
|
|
<div class="section" id="dli_08_15035__section661775715318"><h4 class="sectiontitle">Syntax</h4><pre class="screen" id="dli_08_15035__screen1214311454414">create table dorisSource (
|
|
attr_name attr_type
|
|
(',' attr_name attr_type)*
|
|
)
|
|
with (
|
|
'connector' = 'doris',
|
|
'fenodes' = 'FE_IP:PORT,FE_IP:PORT,FE_IP:PORT',
|
|
'table.identifier' = 'database.table',
|
|
'username' = 'dorisUsername',
|
|
'password' = 'dorisPassword'
|
|
);</pre>
|
|
</div>
|
|
<div class="section" id="dli_08_15035__section4712115614410"><h4 class="sectiontitle">Parameter Description</h4><p id="dli_08_15035__p1464110771618"><strong id="dli_08_15035__b437914771914">Shared configuration</strong></p>
|
|
|
|
<div class="tablenoborder"><table cellpadding="4" cellspacing="0" summary="" id="dli_08_15035__table1608573160" frame="border" border="1" rules="all"><thead align="left"><tr id="dli_08_15035__row4641157131610"><th align="left" class="cellrowborder" valign="top" width="25%" id="mcps1.3.5.3.1.5.1.1"><p id="dli_08_15035__p1265919113553">Parameter</p>
|
|
</th>
|
|
<th align="left" class="cellrowborder" valign="top" width="25%" id="mcps1.3.5.3.1.5.1.2"><p id="dli_08_15035__p1265917110552">Default Value</p>
|
|
</th>
|
|
<th align="left" class="cellrowborder" valign="top" width="25%" id="mcps1.3.5.3.1.5.1.3"><p id="dli_08_15035__p5659511155517">Mandatory</p>
|
|
</th>
|
|
<th align="left" class="cellrowborder" valign="top" width="25%" id="mcps1.3.5.3.1.5.1.4"><p id="dli_08_15035__p11659171113559">Parameter Type Description</p>
|
|
</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody><tr id="dli_08_15035__row764167161613"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p7641878169">fenodes</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p664113718160">--</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p46414761617">Yes</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p14641973161">IP address and port number of the Doris FE. Use commas (,) to separate them for multiple instances. To obtain the port number, log in to MRS Manager, choose <strong id="dli_08_15035__b1657318411610">Cluster</strong> > <strong id="dli_08_15035__b11574344615">Services</strong> > <strong id="dli_08_15035__b4574154868">Doris</strong> > <strong id="dli_08_15035__b13574124460">Configurations</strong>, and search for <strong id="dli_08_15035__b15574143612">http</strong>. Search for <strong id="dli_08_15035__b0373256161916">https</strong> instead if HTTPS is enabled.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row10641579165"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p3641147101618">table.identifier</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p36416711611">--</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p1659912491315">Yes</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p16641874161">Doris table name, for example, <strong id="dli_08_15035__b5606658161916">db.tbl</strong>.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row186411672167"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p36411761610">username</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p156414714169">--</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p059854151315">Yes</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p064112715166">User name for accessing Doris.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row126411779163"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p4641475164">password</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p564217781619">--</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p1359854171318">Yes</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p16423714163">Password for accessing Doris.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row132336394599"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p12642117141617">sink.label-prefix</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p964215712169">""</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p1659844131314">Yes</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p1864207131615">Label prefix used for Stream load import. It must be globally unique in two-phase commit (2pc) scenarios to ensure Flink's EOS semantics.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row136428713164"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p176432716163">sink.enable-2pc</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p664312710163">TRUE</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p16443114619128">No</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p197714453238">Whether to enable 2pc for ensuring Exactly-Once semantics. The default value is <strong id="dli_08_15035__b77016454304">true</strong>.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row36424710167"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p13629114105611">sink.check-interval</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p662421295612">10000</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p4443146201215">No</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p2149968276">Interval for checking exceptions during loading.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row19642372162"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p1739492055618">sink.max-retries</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p198621739145514">3</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p8443446111216">No</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p10711103313568">Maximum number of retries when writing records to the database fails.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row5642127101612"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p9928357125614">sink.buffer-size</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p7905131315577">256 * 1024</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p744316467120">No</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p63161341577">Buffer size for caching data during Stream load.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row16423712164"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p17641227145717">sink.buffer-count</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p13860113913556">3</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p1644316467125">No</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p105821448105716">Buffer count for caching data during Stream load.</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row126421731610"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p46438711610">sink.enable-delete</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p1164318715164">TRUE</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p1144254615121">No</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p196431170166">Whether to enable deletion. This option requires batch deletion to be enabled for the Doris table (default in Doris 0.15 or later for Unique model only).</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row106421574168"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.1 "><p id="dli_08_15035__p1464217710161">sink.properties.*</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.2 "><p id="dli_08_15035__p146421575168">--</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.3 "><p id="dli_08_15035__p1144144614123">No</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.5.3.1.5.1.4 "><p id="dli_08_15035__p864311761614">Import parameters for Stream load.</p>
|
|
<p id="dli_08_15035__p10643117171619">For example, <strong id="dli_08_15035__b862615230466">'sink.properties.column_separator' = ','</strong> defines the column separator, and <strong id="dli_08_15035__b370217326469">'sink.properties.escape_delimiters' = 'true'</strong> treats special characters as separators, where <strong id="dli_08_15035__b647065117463">'\x01'</strong> is converted to binary <strong id="dli_08_15035__b98231512474">0x01</strong>.</p>
|
|
<p id="dli_08_15035__p264319721618">JSON format import</p>
|
|
<p id="dli_08_15035__p106434781614">'sink.properties.format' = 'json' 'sink.properties.read_json_by_line' = 'true'</p>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
<div class="section" id="dli_08_15035__section966893013488"><h4 class="sectiontitle">Example</h4><p id="dli_08_15035__p11305132402910">In this example, data is read from the DataGen data source and written to the Doris result table.</p>
|
|
<ol id="dli_08_15035__ol11671552124818"><li id="dli_08_15035__li6127741153217">Create an enhanced datasource connection in the VPC and subnet where Doris locates, and bind the connection to the required Flink elastic resource pool. Add MRS host information for the enhanced datasource connection.</li><li id="dli_08_15035__li1224211412114">Set Doris security groups and add inbound rules to allow access from the Flink queue. Test the queue connectivity based on the Doris address. If the connection passes the test, it is bound to the queue.<p id="dli_08_15035__p26145191117"><a name="dli_08_15035__li1224211412114"></a><a name="li1224211412114"></a></p>
|
|
</li><li id="dli_08_15035__li146711352194820">Create a Doris table by referring to <em id="dli_08_15035__i12235556778">MRS Doris Usage Guide</em>. The creation statement is as follows:<pre class="screen" id="dli_08_15035__screen2053221932510">CREATE TABLE IF NOT EXISTS dorisdemo
|
|
(
|
|
`user_id` varchar(10) NOT NULL,
|
|
`city` varchar(10),
|
|
`age` int,
|
|
`gender` int
|
|
)
|
|
DISTRIBUTED BY HASH(`user_id`) BUCKETS 10
|
|
</pre>
|
|
</li><li id="dli_08_15035__li1266713210143">Create a Flink OpenSource SQL job. Enter the following job script and submit the job. The job script uses DataGen as the data source and writes data to as a Doris result table.<pre class="screen" id="dli_08_15035__screen1368562919258">create table student_datagen_source(
|
|
`user_id` String NOT NULL,
|
|
`city` String,
|
|
`age` int,
|
|
`gender` int
|
|
) with (
|
|
'connector' = 'datagen',
|
|
'rows-per-second' = '1',
|
|
'fields.user_id.kind' = 'random',
|
|
'fields.user_id.length' = '7',
|
|
'fields.city.kind' = 'random',
|
|
'fields.city.length' = '7'
|
|
);
|
|
|
|
|
|
CREATE TABLE dorisDemo (
|
|
`user_id` String NOT NULL,
|
|
`city` String,
|
|
`age` int,
|
|
`gender` int
|
|
) with (
|
|
'connector' = 'doris',
|
|
'fenodes' = 'FE_IP:PORT',
|
|
'table.identifier' = 'demo.dorisdemo',
|
|
'username' = 'dorisUser',
|
|
'password' = 'dorisPassword',
|
|
'sink.label-prefix' = 'demo',
|
|
'sink.enable-2pc' = 'true',
|
|
'sink.buffer-count' = '10'
|
|
);
|
|
|
|
insert into dorisDemo select * from student_datagen_source</pre>
|
|
</li></ol><ol start="5" id="dli_08_15035__ol1752913161143"><li id="dli_08_15035__li4529416121411">Check whether data is successfully written to the Doris result table.
|
|
<div class="tablenoborder"><table cellpadding="4" cellspacing="0" summary="" id="dli_08_15035__table9325172025011" frame="border" border="1" rules="all"><thead align="left"><tr id="dli_08_15035__row15325202055018"><th align="left" class="cellrowborder" valign="top" width="25%" id="mcps1.3.6.4.1.1.1.5.1.1"><p id="dli_08_15035__p73258209504">user_id</p>
|
|
</th>
|
|
<th align="left" class="cellrowborder" valign="top" width="25%" id="mcps1.3.6.4.1.1.1.5.1.2"><p id="dli_08_15035__p1332562010501">city</p>
|
|
</th>
|
|
<th align="left" class="cellrowborder" valign="top" width="25%" id="mcps1.3.6.4.1.1.1.5.1.3"><p id="dli_08_15035__p16325172018507">age</p>
|
|
</th>
|
|
<th align="left" class="cellrowborder" valign="top" width="25%" id="mcps1.3.6.4.1.1.1.5.1.4"><p id="dli_08_15035__p0325122095017">gender</p>
|
|
</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody><tr id="dli_08_15035__row163251820115013"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.1 "><p id="dli_08_15035__p1232562035016">50aff04</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.2 "><p id="dli_08_15035__p11325112075018">93406c5</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.3 "><p id="dli_08_15035__p33251720165016">12</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.4 "><p id="dli_08_15035__p11325132019500">1</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row132513207502"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.1 "><p id="dli_08_15035__p93251020145012">681a230</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.2 "><p id="dli_08_15035__p1932502075013">1f27d06</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.3 "><p id="dli_08_15035__p0325192085019">16</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.4 "><p id="dli_08_15035__p8325320185010">1</p>
|
|
</td>
|
|
</tr>
|
|
<tr id="dli_08_15035__row0325020145013"><td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.1 "><p id="dli_08_15035__p232511207503">006eff4</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.2 "><p id="dli_08_15035__p9326122065016">3521ded</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.3 "><p id="dli_08_15035__p193261320115016">18</p>
|
|
</td>
|
|
<td class="cellrowborder" valign="top" width="25%" headers="mcps1.3.6.4.1.1.1.5.1.4 "><p id="dli_08_15035__p123267201502">0</p>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</li></ol>
|
|
</div>
|
|
</div>
|
|
<div>
|
|
<div class="familylinks">
|
|
<div class="parentlink"><strong>Parent topic:</strong> <a href="dli_08_15032.html">Doris</a></div>
|
|
</div>
|
|
</div>
|
|
|