J BASE

Download as pdf or txt
Download as pdf or txt
You are on page 1of 629

JBase - User Guide

Release R15.000
June 2015

©2015 Temenos Headquarters SA - all rights reserved.

Warning: This document is protected by copyright law and international treaties. Unauthorised reproduction of this document, or any portion of it, may
result in severe and criminal penalties, and will be prosecuted to the maximum extent possible under law.
Table of Contents
Introduction 16
Purpose of this Guide 16
Intended Audience 16
Overview 17
Dataguard 18
Components 19
Databases 19
Transaction Journaling 19
TRANSACTIONS 22
Transaction Boundaries and Locking 22
Transaction Processing within Transaction Journaling 22
DATABASES 23
Concept 23
Configuration 23
DATABASE CONTROL COMMANDS 25
DB-START 26
Syntax 26
DB-PAUSE 28
Syntax 28
DB-SHUTDOWN 29
Syntax 29
DB-RESUME 30
Syntax 30
DB-REMOVE 31
Syntax 31
DB-STATUS 32
Syntax 32
TJ Configuration 33
jediLoggerConfig 33
jediLoggerAdminLog 33
jediLoggerTransLock 33
Configuring Transaction Journaling 33
Monitoring TJ 44
jlogstatus 44
JLOGSYNC 46
SYNTAX 46
SYNTAX ELEMENTS 46
JLOGMONITOR 48
SYNTAX 48
SYNTAX ELEMENTS 48
JLOGDUP 50
SYNTAX 50
SYNTAX ELEMENTS 50
INPUT_spec/OUTPUT_spec 50
timespec 52
Examples of use 52
Verifying a logging tape 54
Terminating jlogdup 55
Resilient Files 84
Resilience 84

JBase - User Guide - Release R15.000 - Page 2 of 629


Autosizing 84
Internal Hash Table Limits 86
Hashing 86
File Size 86
Writing Data 87
Deleting Data 88
Internal Pointers 88
External Frames 89
External Hashing 90
jrscan 90
Recovery 92
Warmstart Recovery 93
DB-WARMSTART 93
Media/Computer Failure and Recovery 94
Saving and Restoring the System 94
jbackup - jBASE Backup Utility 94
jrestore - jBASE Restore Utility 95
Resilient T24 Configurations 97
Stand-Alone System – application server and database server on one machine 97
Operation of the Hot Standby configuration 101
Scripts/Commands 101
Run Time 110
File Handling 111
Overview 112
CLEAR-FILE 113
COMMAND SYNTAX 113
SYNTAX ELEMENTS 113
COPY 114
COMMAND SYNTAX 114
PROMPT 114
SYNTAX ELEMENTS 114
Options 114
NOTES 114
EXAMPLE 114
CREATE-FILE 116
COMMAND SYNTAX 116
SYNTAX ELEMENTS 116
DELETE 117
COMMAND SYNTAX 117
SYNTAX ELEMENTS 117
EXAMPLE 117
DELETE-FILE 118
COMMAND SYNTAX 118
SYNTAX ELEMENTS 118
NOTES 118
EXAMPLE 118
JBACKUP 119
COMMAND SYNTAX 119
OPTIONS 119
NOTES 119
EXAMPLES 120
JRESTORE 121
COMMAND SYNTAX 121
OPTIONS 121
NOTES 121

JBase - User Guide - Release R15.000 - Page 3 of 629


EXAMPLES 122
JCHMOD 122
COMMAND SYNTAX 122
SYNTAX ELEMENTS 122
NOTES 123
JGREP 124
COMMAND SYNTAX 124
SYNTAX ELEMENTS 124
NOTES 124
EXAMPLE 124
JRCHMOD 125
COMMAND SYNTAX 125
SYNTAX ELEMENTS 125
NOTES 125
JRF 126
COMMAND SYNTAX 126
SYNTAX ELEMENTS 126
NOTES 126
JRSCAN 128
COMMAND SYNTAX 128
SYNTAX ELEMENTS 128
NOTES 128
JSTAT 129
COMMAND SYNTAX 129
SYNTAX ELEMENTS 129
NOTES 130
SEL-RESTORE 132
COMMAND SYNTAX 132
PROMPT 132
SYNTAX ELEMENTS 132
NOTES 132
EXAMPLES 133
DISTRIBUTED FILES 134
PART FILES 135
Creating DISTRIBUTED FILES 136
Attaching and Detaching PART FILES 137
Partioning Algorithm 138
System Partition Algorithm 138
User-defined Partition Algorithm 138
CREATE-DISTRIB 141
Syntax Elements 141
Examples 141
DELETE-DISTRIB 143
Syntax 143
Syntax Elements 143
Notes 143
Example 143
LIST-DISTRIB 144
Syntax 144
Syntax Elements 144
Notes 144
Example 144
VERIFY-DISTRIB 145
Syntax 145

JBase - User Guide - Release R15.000 - Page 4 of 629


Syntax Elements 145
Example 145
Distributed File Considerations 146
Distributed Files Example 147
jBASE Data Provider 149
What is jDP? 150
Overview of available modes 150
Getting Started 151
Upgrading the jDP Environment 152
The ADDON file 153
NAV UTIL 154
What is NAV_UTIL 154
Executing SQL 155
Setting up jDP for each supported mode 155
jBASE Dictionary Configurator 162
jDP and Subvalues 164
jBASE Indexes 165
Overview 166
CREATE-INDEX 167
COMMAND SYNTAX 167
SYNTAX ELEMENTS 167
EXAMPLES 168
DELETE-INDEX 170
COMMAND SYNTAX 170
SYNTAX ELEMENTS 170
EXAMPLES 170
KEY-SELECT/QUERY-INDEX 171
COMMAND SYNTAX 171
SYNTAX ELEMENTS 171
EXAMPLES 171
NOTES 172
LIST-INDEX 173
COMMAND SYNTAX 173
SYNTAX ELEMENTS 173
EXAMPLES 173
NOTES 173
REBUILD-INDEX 175
COMMAND SYNTAX 175
SYNTAX ELEMENTS 175
VERIFY-INDEX 176
COMMAND SYNTAX 176
SYNTAX ELEMENTS 176
NOTES 176
Using JQL Commands 177
SUBROUTINES 178
Related BASIC Statements 180
REGULAR EXPRESSIONS 181
Backup and Restore 182
ACCOUNT-SAVE 182
Appendices 183
Appendix A. Internal operation 183
Appendix B – Sort sequences 183
Appendix C – Universal Co-ordinated Time 185

JBase - User Guide - Release R15.000 - Page 5 of 629


jBASE Internationalisation 186
Introduction 187
Overview 188
The Development Challenges 189
The Development Approaches 190
Internationalization and Localization 191
The Process of Internationalizing 192
The Process of Localizing 193
Code Pages 194
Locales 195
Unicode 196
Unicode Combining/Composite Characters 196
Unicode Expanding and Contracting Characters 196
Unicode Normalization 196
Unicode Universal Character Set and UTF-8 197
Unicode UTF-8 Properties 197
International Components for Unicode (ICU) 198
jBASE, Internationalization and UTF-8 199
jBASE Internationalization Configuration 200
jBASE Code Page Configuration 201
jBASE Locale Configuration 202
jBASE Timezone Configuration 203
jBASE Function Changes for International Mode 204
Character vs. Bytes 204
Character properties 204
Collation properties 205
Conversion properties 205
Character functions 206
Additional Functions 206
Timestamp Functions 206
Byte Count Functions 207
jBASE JQL Changes for International Mode 208
jQL Dictionary Conversions and Correlatives 208
jQL Locale-Based Collation 208
jQL Right Justified Sort 208
Data Conversion 209
EXAMPLE 209
jBASE File Conversion 210
Compiler 210
Conversion Utility 210
Conversion Map 210
Data Import and Export 211
JBASE Error Message Files 212
jBASE Spooling and Printing 213
Spooling 213
Printing 213
Potential Performance Issues 214
Desktop Applications 214
The Future and UTF-8 215
Summary 216
APPENDICES 217
jBASE Environment Variables for Internationalization 217

JBase - User Guide - Release R15.000 - Page 6 of 629


Unicode and ICU Reference Information 217
Locale Definition 217
Configured Code Pages and Aliases 228
UTF and ASCII Code Pages 228
Latin Code Pages 228
Mircosoft Windows Code Pages 229
Japanese, Chinese, Korean Code Pages 230
jBASE ODBC 231
Introduction 232
Assumptions 232
Environment 233
jBASE Locale Configuration 234
Developing Client Applications 235
Resources 237
Enabling TABLEFILE functionality for jODBC 238
jBASE Remote File Service 239
Introduction 239
Assumptions 239
Installation and Configuration 239
Overview 240
Limitations 240
Resources 241
Installation 242
Database Server Configuration 242
Application Server Configuration 242
Example Deployment 244
jRFS and Multiple Application Server (MAS) Architecture 245
jBASE Triggers 247
Overview 248
Subroutine Parameter Description 249
Assignment of Trigger Subroutine Arguments 251
CREATE-TRIGGER 252
COMMAND SYNTAX 252
SYNTAX ELEMENTS 252
NOTES 252
EXAMPLES 252
Environment Variables 253
Setting/Getting Environment Variables 253
jBASE PROGRAMS 253
jBASE Initialization 253
Initial Environment Variables 254
Additional jBASE Environment Variables 255
EXECUTION - Environment Variables 255
DEVELOPMENT - Environment Variables 256
MISCELLANEOUS - Environment Variables 257
TERMINAL - Environment Variables 258
EMBEDDED SQL - Environment Variables 259
EXAMPLE 259
CREATE-FILE - Environment Variables 260
EXAMPLE 260
jRFS – Environment Variables 261
PUTENV - Command 262

JBase - User Guide - Release R15.000 - Page 7 of 629


COMMAND SYNTAX 262
SYNTAX ELEMENTS 262
NOTES 262
EXAMPLE 262
GETENV - Command 263
COMMAND SYNTAX 263
SYNTAX ELEMENTS 263
NOTES 263
EXAMPLE 263
PATH 263
DESCRIPTION 263
VALUES 263
DEFAULT 263
SETTINGS 263
LD_LIBRARY_PATH 265
DESCRIPTION 265
VALUES 265
DEFAULT 265
SETTINGS 265
TERM 265
DESCRIPTION 265
VALUES 265
DEFAULT 265
SETTING 265
TERMINFO 266
DESCRIPTION 266
VALUES 266
DEFAULT 266
SETTING 266
JBCPORTNO 267
DESCRIPTION 267
VALUES 267
DEFAULT 267
SETTING 267
NOTES 267
JBCLOGNAME 268
DESCRIPTION 268
VALUES 268
DEFAULT 268
SETTING 268
NOTES 268
JBCGLOBALDIR 269
DESCRIPTION 269
VALUES 269
DEFAULT 269
SETTING 269
JBCRELEASEDIR 270
DESCRIPTION 270
VALUES 270
SETTING 270
JBCDATADIR 271
DESCRIPTION 271
NOTES 271
VALUES 271
SETTING 271
JBCDEFDICTS 272
DESCRIPTION 272

JBase - User Guide - Release R15.000 - Page 8 of 629


VALUES 272
DEFAULT 272
SETTING 272
JBCEMULATE 273
DESCRIPTION 273
VALUES 273
DEFAULT 273
SETTING 273
JDIAG 274
DESCRIPTION 274
VALUES 274
DEFAULT 274
SETTING 274
JEDIFILEPATH 275
DESCRIPTION 275
VALUES 275
DEFAULT 275
SETTING 275
JEDIFILENAME_MD 276
DESCRIPTION 276
VALUES 276
DEFAULT 276
SETTING 276
JEDIFILENAME_SYSTEM 277
DESCRIPTION 277
VALUES 277
DEFAULT 277
SETTING 277
JEDIENABLEQ2Q 278
DESCRIPTION 278
VALUES 278
DEFAULT 278
SETTING 278
JEDI_DISTRIB_DEFOPEN 279
DESCRIPTION 279
VALUES 279
DEFAULT 279
SETTING 279
JEDI_SECURE_LEVEL 280
DESCRIPTION 280
VALUES 280
DEFAULT 280
SETTING 280
JBC_TCLRESTART 282
DESCRIPTION 282
VALUES 282
DEFAULT 282
SETTING 282
JBC_ENDRESTART 283
DESCRIPTION 283
VALUES 283
DEFAULT 283
SETTING 283
JBCOBJECTLIST 284
DESCRIPTION 284

JBase - User Guide - Release R15.000 - Page 9 of 629


VALUES 284
DEFAULT 284
SETTING 284
JBC_BLOCK_SYSTEM14 285
DESCRIPTION 285
VALUES 285
DEFAULT 285
SETTING 285
JBASEUNIQUE 286
DESCRIPTION 286
VALUES 286
DEFAULT 286
SETTING 286
JBASE_ERRMSG_NON_NUMERIC 287
DESCRIPTION 287
VALUES 287
DEFAULT 287
SETTING 287
JBASE_ERRMSG_TRACE 288
DESCRIPTION 288
VALUES 288
DEFAULT 288
SETTING 288
JBASE_ERRMSG_ZERO_USED 289
DESCRIPTION 289
VALUES 289
DEFAULT 289
SETTING 289
JBASE_WIN_TERM_SVR 290
DESCRIPTION 290
VALUES 290
DEFAULT 290
SETTING 290
JBASE_SVR_SESSION 291
DESCRIPTION 291
VALUES 291
DEFAULT 291
SETTING 291
JBC_INVERT_ALPHA_CHARS 292
DESCRIPTION 292
VALUES 292
DEFAULT 292
Internationalisation 293
JBASE_I18N 293
JBASE_CODEPAGE 293
JBASE_LOCALE 293
JBASE_TIMEZONE 294
DEFAULT 294
Development 295
JBCDEV_BIN 295
JBCDEV_LIB 295
JBCTTYNAME 296
JBCERRFILE 296
JBCSPOOLERDIR 297
JBC_DESPOOLSLEEP 297
JBC_CRREQ 297

JBase - User Guide - Release R15.000 - Page 10 of 629


JBCLISTFILE 298
JBCSCREEN_WIDTH 299
JBCPRINTER_DEPTH 299
JBCPRINTER_WIDTH 300
jBASE Remote File Server (jRFS) 300
Deployment 304
JBoss deployment 306
Deployment 307
JBoss deployment 309
Developers Guide 310
jAgent 312
Connecting to jBASE 314
Closing a connection 317
JDBC API reference 318
JDBC Driver 319
Overview 320
Assumptions 322
Resources 323
jDLS Distributed LockService 324
Overview 325
Distributed Lock Service Deployment 326
Client Distributed Lock Deployment 328
jBASE Distributed Lock Service process flow 330
Lock Mechanisms 331
Distributed Lock Information 333
Utilities 334
Resilience 337
Recovery 338
Query Language 339
Overview 343
jQL Sentences 345
jQL Predefined words and Symbols 346
jQL Sentence Construction 348
A Conversion 350
information 351
AE;expression Format 352
An;expression Format 353
An Format: Embedded Decimals 354
AND Connective Examples 355
Apparent item-id List Example 356
Arithmetic F Code Operators 357
Arithmetic Operators 358
A: Expression Format 359
B Conversion 360
Between Connective 361
BREAK-ON Connective 362
BSELECT 364
C Conversion 365
Calling Subroutines from Dictionary Items 366

JBase - User Guide - Release R15.000 - Page 11 of 629


Changing Case 369
CNV Connective 370
COL.HDG Connective 371
Command Options 372
Concatenation Operator 373
Conversion Processing 374
Converting Characters 375
Converting Numeric Values 377
COUNT 379
D Conversion 380
D1 D2 Conversion 382
Data Conversion 383
Data Definition Records 384
Default Data Definition Records 385
Record Layout 387
Special Field-mark Counts 390
Default Output Specification 392
Explicit Defaults 394
Implicit Defaults 396
Predefined Data Definition Records 398
EDELETE 399
ESEARCH 400
EXPLAIN 401
EXPLAIN Reports 403
jQL Report 405
Explicit Item-id list 407
Extracting Characters 408
F Conversion 410
Field Qualifiers 411
File Modifiers 412
Item Lists 414
FMT Connective 415
Format Codes 416
Format Codes 417
Further Examples of item Lists 418
G Conversion 419
GRAND-TOTAL 420
I-DUMP / S-DUMP 421
I-TYPES 423
ICOMP 424
IF STATEMENT 425
Implicit Item-id list 426
Item-id Selection clause 428
Selection Criteria Clause 430
jBC Statements for use with jQL 431
jQL Basic Subroutines 432
jQL Dictionary Conversions and Correlatives 433
jQL Operands 434
Field Number (FMC) Operand 434
Field Name Operand 436

JBase - User Guide - Release R15.000 - Page 12 of 629


Literal Operand 438
System Parameter Operands 440
Special Operands 442
FIELD NUMBER 444
N (Field Name) Operand 447
Literal Operand 449
Special Operands 451
jQL Output (Reports) 452
jQL Verbs 453
JQLCOMPILE 454
JQLEXECUTE 455
JQLFETCH 456
JQLGETPROPERTY 457
JQLPUTPROPERTY 458
L Conversion 459
Left Ignore examples 460
LIST-LABEL 461
LIST 463
LISTDICT 465
Logical Connectives 466
Logical Operators 467
Logical Operators 468
Macros 469
MC Conversion 470
MD Conversion 472
Miscellaneous Operators 474
MK Conversion 475
Ml / MR Conversion 476
MP Conversion 479
MS Conversion 480
MT Conversion 481
Operators and conversions 482
Order of Operation 483
Output Conversion 484
Output Specification Clause 485
P Conversion 486
Pre processor Conversion 487
Push Operator 488
R Conversion 489
Record Structure 490
REFORMAT 491
Relational Operators 492
Relational Operators 493
Remainder Function 494
Repeat Operators 495
Replacing Characters 496
S Conversion 497
SELECT 498
Single and Double Quotes 499

JBase - User Guide - Release R15.000 - Page 13 of 629


SORT - LABEL 500
Sort Criteria Clause 502
Default sort order 504
Sort Order of Left justified Data 506
Sorting Multivalued Fields 508
SORT 509
SREFORMAT 511
SSELECT 512
Sublist – V Code 514
Substring Function 516
Summary of Operands 518
Synonyms 519
T Conversion 520
T File Conversion 521
The Stack 523
Throwaway Connectives 524
TimeStamp “W{Dx}{Tx}” 525
Total Connectives 526
Types of Item List 527
U Conversion 528
Unicode 529
User Subroutines 531
Using Clause 532
Using Report Qualifier Keywords 533
Value Strings 535
Wild Card Examples 536
Appendix 537
SQL / jQL constants 538
Appendix 542
SQL / jQL constants 543
Associations 547
Assumptions 550
Current limitations 551
Unsupported SQL Features 551
Unsupported SQL Functions 553
SELECT * AND SELECT COUNT(*) 555
Dictionaries 556
Examples of SQL 559
The example files 559
On the jsh 561
In a BASIC Program 564
Limiting multi-values in display 566
Overview 568
SQL Engine 569
SQL Programatic Options 570
SQLSELECT PROGRAM 571
Transaction Journaling 573
Logging Strategy 575
Reduce Log Record Size 579
Selective Journaling 580

JBase - User Guide - Release R15.000 - Page 14 of 629


Selective Restores 581
Failure Conditions and Recovery Remedies 582
Transaction Journaling on a single system 583
Transaction Journaling on a single system with two tape desks 585
Failsafe/Hot Standby 586
Refinement to Hot Standby Configuration 590
Resilient T24 Configurations 591
Cluster System – multiple application servers and a single database server 594
Scripts 597
REMOTE.JOURNAL.STARTUP 601
Transaction Journaling Utilities 602
jlogsync 608
jlogdup 609
jlogmonitor 612
ODBC 613
615
Setting up jBASE ODBC 616
System Requirements 617
618
Installer Package 618
Installing the driver 619
620
Extracting Data from jBASE Server 624
Additional Connection Properties 629

JBase - User Guide - Release R15.000 - Page 15 of 629


Introduction

Purpose of this Guide


This document provides an overview of JBC APIs, file structures, Transaction Journalling, Internalization, distributed locks and other tools
and utilities of jBASE. This manual helps the user to quickly understand the operations of jBASE in a whole with different configurations.

Intended Audience
This User Guide is intended for the use of Internal Temenos users and Clients.

JBase - User Guide - Release R15.000 - Page 16 of 629


Overview

l DataGuard
l File Handling
l jBASE Data Provider
l jBASE Indexes
l jBASE Internationalisation
l jBASE ODBC
l jBASE Remote File Service
l jBASE Triggers
l Environment Variables
l JDBC Driver
l jDLS Distributed LockService
l jQL
l SQL Engine
l Transaction Journalling

l jBASE ODBC Overview and User guide

JBase - User Guide - Release R15.000 - Page 17 of 629


Dataguard

l Overview
l Transactions
l Databases
l Database Control Commands

l DB-START l DB-SHUTDOWN l DB-REMOVE


l DB-PAUSE l DB-RESUME l DB-STATUS

l TJ Configuration
l Monitoring TJ
l jlogsync
l jlogmonitor
l jlogdup
l Resilient Files
l Recovery
l WarEmstart Recovery
l Media/Computer FailurEe and Recovery
l Sample System Configurations
l Resilient T24 Configurations
l Run Time

JBase - User Guide - Release R15.000 - Page 18 of 629


Components

Traditional jBASE systems essentially comprise three parts:  User- and System-related files – “the database”;  an application suite of programs
to manipulate the data in the database  - “the application” and a DBMS system comprising jBASE programs and user-developed programs to
service database requests made by the application.  The database is the only component which requires special attention with regard to resi-
lience; the others can merely be reloaded from an archive image. The database is the only fluid component – it changes from day-to-day and
probably from second-to-second. This document will describe the features of jBASE which exist in order to protect the database from potential
problems which could occur, as well as the methods to use when confronted by each of such circumstances.

Databases
The database is the collection of data which supports any business. This valuable commodity must be protected as much as possible and be
restored to a known, stable, state when the computer facilities fail to perform normally. The database comprises not only application data, but
also configuration data pertaining to:  the users of the computer along with their access and restrictions; and peripherals connected to the com-
puter. The configuration data is not part of the data resilience referred to in this document. Any changes to such data should be archived (nor-
mally during the O/S archiving procedures).

Transaction Journaling
Transaction Journaling provides the capability to prevent permanent data loss following a media or system failure. The Transaction Journal is a
copy of database updates in a chronological order. In the event of such a failure, the Transaction Journal may be replayed, thus restoring the
database to a usable state. Transaction Journaling  preserves the integrity of the jBASE database by ensuring that logically related updates are
applied to the database in their entirety or not at all.

These are the main transaction journaling administration utilities provided within jBASE:

jlogadmin This command is provided to configure and start/stop/suspend transaction journaling.

jlogstatus This command allows the administrator to monitor the activity of transaction journaling.

jlogdup This command enables the recovery or replication of data.

Additional Administration Utilities


jlogsync synchronizes and flushes log files

jlogmonitor monitors the current state of transaction journaling

Selective Journaling
The jBASE journal does not record every update that occurs on the system. It is important to understand what is and is not automatically
recorded in the transaction log.

What is journaled? Unless a file is designated unloggable, everything is updated through the jEDI interface (i.e. use of the jchmod –L filename
command). This includes non-jBASE hash files such as directories.

What is NOT journaled? The opposite of above, in particular:

l Operations using non-jBASE commands such as the ‘rm’ and ‘cp’ commands, the ‘vi’ editor.
l The UNIX spooler files.
l Index definitions.
l Trigger definitions.
l Remote files using jRFS via remote Q-pointers or stub files
l When a SUBROUTINE is cataloged, the resulting shared library is not logged.
l When a PROGRAM is cataloged the resulting binary executable file is not logged.

JBase - User Guide - Release R15.000 - Page 19 of 629


l Internal files used by jBASE such as jPMLWorkFile, jBASEWORK, jutil_ctrl will be set to non-logged only when they are automatically
created by jBASE. If you create any of these files yourself, you should specify that they be not logged (see note on CREATE-FILE
below). You may also choose to not log specific application files.

It is recommended that most application files be enabled for transaction journaling. Exceptions to this may include temporary scratch files and
work files used by an application. Files can be disabled from journaling by specifying LOG=FALSE with the CREATE-FILE command or by
using the -L option with the jchmod command. Journaling on a directory can also be disabled with the jchmod command. When this is done, a
file called .jbase_header is created in the directory to hold the information.

Remote files are disabled for journaling by default. Individual remote files can be enabled for journaling by using QL instead of Q in attribute 1
of the Q pointer, for example;

<1>QL

<2>REMOTEDATA

<3>CUSTOMERS

Adding L to attribute 2 of the file stub

Example

JBC_SOB JediInitREMOTE CUSTOMERS mach1.temenos.com

In general, journaling on specific files should not be disabled for "efficiency" reasons as such measures will backfire when you can least afford it.

Selective Restores
There may be times when a selective restore is preferable to a full restore. This cannot be automated and must be judged on its merits.

For example, assume you accidentally deleted it a file called CUSTOMERS. In this case you would probably want to log users off while it is
restored, while certain other files may not require this measure. The mechanism to restore the CUSTOMERS file would be to selectively restore
the image taken by a jbackup and then restore the updates to the file from the logger journal. For example:

# jrestore –h ‘/JBASEDATA/PROD/CUSTOMERS*’ < /dev/rmt/0


# cd /tmp
# create-file TEMPFILE TYPE=TJLOG set=current terminate=eos
[ 417 ] File TEMPFILE]D created , type = J4
[ 417 ] File TEMPFILE created , type = TJLOG
# SELECT TEMPFILE WITH PATH EQ \/JBASE_ACCOUNTS/PROD/CUSTOMERS]\
21 Records Selected

# jlogdup input set=current output set=database

If required, use the jlogdup rename and renamefile options to restore the data to another file.

Note: In order to preserve the chronological ordering of the records do not use a SSELECT command on the time field. This may not pro-
duce the correct ordering (multiple entries can occur during the same time period – the granularity being one second).

Resilient Files
Resilience is the ability of a file to remain uncorrupted in adverse conditions such as system failure. The implementation of resilient files is
essential for warmstart recovery to guarantee recovery from failure by rolling forward from the transaction journal with or without a system
restore.

If a file is structurally corrupt this will stop any database level updates being applied; preventing the possibility of a roll forward and hence inval-
idate the warmstart recovery. Logical database corruption will be resolved by the roll forward.

A resilient file must have a singularity of update where one disk operation cannot rely on another in a change of file structure. For this reason
new substructures are built within the file before a single disk operation redirects the file to the new structure and the old structure is released.

JBase - User Guide - Release R15.000 - Page 20 of 629


Online Backup and Restore
The Online Backup facility has been developed to enable system managers to perform necessary regular database backups while still allowing
users the ability to perform updates on the database. The three jBASE components used for this feature are jbackup; Transaction Journaling
and the use of transaction boundaries. While jbackup may not necessarily be perceived as the tool of choice for database archiving, it is the only
facility which may be used while the database is online. Using this facility enables the automatic restoration of the database including all
updates up to the point of failure – without operator intervention or scripting. Following the restoration, the database will be left in a con-
sistent state.

The functionality of the restore process, jrestore, has been extended to allow for the automatic roll-forward of logsets after a database restore
has completed. This extension uses the Transaction Journal configuration (JediLoggerConfig) which was active at the time of the last backup
along with the corresponding Transaction Journal Logfiles.

Warmstart
This facility is designed to enable the databases defined by the administrator to be brought back to a stable, working position, following a
power failure. Without this it is not clear whether all transactions have been committed to the database following such events. Databases
which have been shutdown prior to the power outage will not require recovery, so recovery is not attempted on them. Those databases which
were active at the time the computer lost power will be recovered. This recovery will take the form of a database roll-forward of all complete
transactions. A complete transaction is deemed to be one which has entered the commit phase of processing. Those transactions which were
incomplete will not be recovered at all. The databases will be left in a consistent state following recovery. It is the database administrator’s
responsibility to determine which transactions require re-entry.

JBase - User Guide - Release R15.000 - Page 21 of 629


TRANSACTIONS

Database transactions are a group of logically related file updates. These updates are intended to be processed as a whole. In order to maintain
database consistency, all of the updates within a transaction must occur or none of them.

For instance, assume there is a standing instruction where in the bank needs to debit customer A’s account with USD500 and credit customer
B’s account on account of house rent payable by A to B. This has to happen on the 1st day of each month. In the above-mentioned transaction,
two important tasks need to be carried out.

One is a debit to Customer A’s account with $500

Another is a credit to customer B’s account with $500

It is vital that both the above-mentioned tasks happen or none of them to happen. If either of them only happens, it would lead to database
inconsistency.

Transaction Boundaries and Locking


Updates within a transaction block normally require database locks to be taken to prevent inconsistencies arising from different users sim-
ultaneously updating the same record. It is clear that if these locks are held for an extended time, then access to the database may be impaired.
It is vital, then, that locks are only held when about to write to the database and certainly not when waiting for user input.

Transaction Processing within Transaction Journaling


As indicated earlier a transaction is a group of logically related updates to jBASE files. Take the banking example and introduce transaction
boundary markers:

(i) The jBC command - “TRANSTART ….” when executed by the jBC runtime system causes a “TRANSTART” record to be
placed in the transactional cache for this user.

(ii) & (iii) “WRITE” records containing not only the record data, but details about the origin of the updates (see Viewing the
Transaction Journal in a later section. These journal records are cached following the “TRANSTART” record.

(iv) The  jBC command - “TRANSEND …”  causes the process to enter the “COMMIT” phase of execution. Up to this point no
data has been written either to the Transaction Journal or to the database. The following procedure is then followed:

JBase - User Guide - Release R15.000 - Page 22 of 629


DATABASES

Concept
Until recently there has been no way or to manage and control subdivisions of the application – departmental control or to duplicate the applic-
ation/DBMS to support more than one instance of the database – multi-customer hosting. The database grouping is achieved by the used of
the JBASE_ DATABASE environment variable; not specifying this will result in the user being assigned to the “default” database group. This
allows the system administrator to control access to various populations of user/applications, without affecting the other users/applications.

Departmental Control
Users may now be assigned a target grouping or “database” when they access applications. This “database” enables finer control over which
groups of users may access the database. This grouping is likely to be on a departmental or functional basis, i.e. users may be assigned to the
“Sales” or “Accounts” database or even the “Administrators” database. This physical database may thus be physically or logically split by func-
tional areas. Control of each of these areas is by the assigned “database” name. Thus it is possible to restrict access to the database to only,
say, those users who are in the “Administrators” database group etc. The database could be designed such that each functional area contains
files pertinent to each area and that files which are shared between functional groups are stored in a central repository, with access available to
all.

It should be stated that this “database” grouping is not intended to replace file ownership and access permissions which are normally in exist-
ence.

Multi-customer hosting
An application could be replicated such that a provision is made to support multiple customers each running the same application but with
each having their own copy of database files. In this instance the “database” grouping could be by customer, thus allowing control over each dis-
tinct customer database.

Configuration
The default configuration of databases is as follows :

There will always be a “default” database file and a “databases_defined” file defined within the system. In order  for the system to run, the envir-
onment variable “JBCRELEASEDIR” must exist in order to find where jBASE resides. This will be the default entry within the “databases_

JBase - User Guide - Release R15.000 - Page 23 of 629


defined” file.  Each defined database will contain information about where to find Transaction Journaling configuration and administration files.
This will be defaulted to JBCRELEASEDIR location if not specified.

Environment Variables
Two environment command may be used to assign a user or application to a particular database and to use a particular set of Transaction
Journal files:

l set JBASE_DATABASE=”dbname” - will assign this user/application to the specified database.


l set JBCLOGCONFDIR=”path of TJ configuration” - will assign Transaction Journal log files as defined in the  configuration files found
at this location. This command is not mandatory. If not used the default location will be used.

JBase - User Guide - Release R15.000 - Page 24 of 629


DATABASE CONTROL COMMANDS

Com- Options Operation


mand

DB-  -n Database name – “default” if not specified


START

 -t Location of TJ configuration – defaults to $JBCRELASEDIR/config

DB-  -a Administrators are still allowed access to the database


PAUSE

 -n Database name – “default” if not specified

 -r Read type operations are still allowed on the database

 -t Transactions are allowed to complete

DB-  -a All databases


SHUTDO-
WN

 -n Database name – “default” if not specified

 -t Transactions are allowed to complete

DB-  -n Database name – “default” if not specified


RESUME

DB-  -n Database name – “default” if not specified


REMOVE

DB-  -a All databases


STATUS

 -n Database name – “default” if not specified

 -t Display users inside a transaction

 -v Verbose mode

 -w users currently waiting for DB-RESUME

 -V Very verbose mode

JBase - User Guide - Release R15.000 - Page 25 of 629


DB-START

Syntax
DB-START {-nt}

Where:

l -n - Database name


l -t - TJ Logger Config Base

This command is used to start a database. Upon completion, users/applications which have been configured to use this database, may then do
so. Prior to this point the following message will be displayed to the user/application :

jBASE: Database not started

The use of a particular database is trapped very early on in the creation of an application process. If the expectation is that the database should
be available for use, then the system administrator should be contacted for resolution.

The DB-START command not only control access to a particular database, but is used also to define the location of the configuration files for
Transaction Journaling operations. If the “-t” switch is not used, then the default location ($JBCRELEASEDIR or %JBCRELEASEDIR% for
Windows platforms, will be used to record the location of the “config” directory/folder. This information is used by the “Warmstart” facility in
order to provide recovery in case of power failure.

The DB-START command will write two entries into the “databases” directory/folder:

The first file will be named after the Database name as specified by the “-n” switch. If there is not database name specified, then this will default
to the creation of a file called “default”. This file is used to hold the status of the database. This file will contain the following identifier :

JBC__DB

The remainder of the file contains information about the database itself, notably the state of the database.

The second file involved in recovery is the “databases_defined” file within the “databases” directory/folder. If this file does not exist, then it will
be created during the execution of the DB-START command.  Each entry within the “databases_defined” file will take the following form:

database_name            $JBCRELEASEDIR                        TJ config location

or

%JBCRELEASEIR% (Windows)

For example: for Unix/Linux platforms:

default /home/jbase /home/tjlogs


Sales /home/jbase /home/SalesLogs
Accounts /home/jbase /home/AcctsLogs
HR /home/jbase /home/tjlogs

And for Windows platforms:

Default C:\jbase4 C:\jbase4\tjlogs


Sales C:\jbase4 C:\SalesLogs
Accounts C:\jbase4 C:\AcctsLogs
HR C:\jbase4 C:\jbase4\tjlogs

Note: Each field is separated by a space character. The above example shows a sample configuration. The databases “default” and  “HR”
will both use the default configuration for Transaction Journaling, whereas “Sales” and “Accounts” will each have their own set of Trans-
action Journal log files. All databases will use the same set of jBASE executables.

JBase - User Guide - Release R15.000 - Page 26 of 629


JBase - User Guide - Release R15.000 - Page 27 of 629
DB-PAUSE

Syntax
DB-PAUSE {-anrt}

Where:

l -a - Administrators are still allowed access to the database as such must be used with care.
l -n - Database to pause
l -r - Read type operations are still allowed on the database. Write operations including DELETE-FILE, FILELOCK, CLEARFILE,
WRITE and DELETE record will be paused.
l -t - Transactions are allowed to complete.

The DB-PAUSE command is used when the administrator wishes to selectively pause the named database. The pause effected by this com-
mand prohibits all access  to the database from this time, dependent on the options chosen. Processes will wait until this condition is cleared 
from the database , with no application programming required to effect this wait.

Briefly, database transaction is defined so :

l TRANSTART
l READs
l WRITEs
l DELETEs
l TRANSEND

When the TRANSEND instruction is executed, this process is now deemed to be “in a transaction” for database purposes. No database updates
have occurred up to this time, but they are cached. The “–t” option refers to those processes which have entered this state. Once a transaction
has been processed fully this state is exited. The process will now be paused – depending on other options chosen.

Note: A complete description of the life of a transaction will be documented later.

JBase - User Guide - Release R15.000 - Page 28 of 629


DB-SHUTDOWN

Syntax
DB-SHUTDOWN {-ant}

Where:

l a - All Databases


l n - Database name
l t - Transactions are allowed to complete

This command will allow the system administrator to shutdown databases in an orderly manner. This allow for a clean system shutdown,
ensuring database integrity. The effect on processes is the same as for DB-PAUSE.

JBase - User Guide - Release R15.000 - Page 29 of 629


DB-RESUME

Syntax
DB-RESUME {-n}

Where:

l -n - Database name

This command will set the specified database to active – no restrictions on update will be in effect.

JBase - User Guide - Release R15.000 - Page 30 of 629


DB-REMOVE

Syntax
DB-REMOVE {-n}

Where :

-n - Database name

This command will remove the specified database from the databases directory/folder. If the defined database is the “default” database, then
this is ignored, else the database definition is removed from the “databases-defined” file. The “databases-defined” file is used by the
WARMSTART utility when recovering a database following a power failure.

JBase - User Guide - Release R15.000 - Page 31 of 629


DB-STATUS

Syntax
DB-STATUS {-ntvwV}

Where:

l -a - All Databases
l -n - Database name
l -t - Display users inside a transaction.
l -v - Verbose mode.
l -w - Display users currently waiting for DB-RESUME.
l -V - Very verbose mode.

This command allows the system administrator to determine the state of each defined database. The following will show various states of each
of the defined databases (for example).

For example 1

No options declared – default database to display is then “default”

:DB-STATUS

Database 'default' is active , resumed at Tue Oct 03 12:54:16 2006

For example 2

Defined database set to different states – description is self-evident as to the state of each.

Database 'default' is active , resumed at Tue Oct 03 12:54:16 2006

Database 'HR' paused at Tue Oct 03 13:04:08 2006

For READ and WRITE operations

Administrators still have full database access

Transactions will be blocked immediately

Database 'Accounts' paused at Tue Oct 03 13:02:35 2006

For WRITE only operations

Administrators still have full database access

Existing transactions can continue until complete

Database 'Sales' paused at Tue Oct 03 13:02:57 2006

For READ and WRITE operations

Updates are denied also to administrators

Existing transactions can continue until complete

JBase - User Guide - Release R15.000 - Page 32 of 629


TJ Configuration

The jBASE Transaction Journal configuration comprises these essential components:

jediLoggerConfig
This file is the repository for all configuration and operational details concernin Transaction Journaling. The default location of this file is at
$JBCRELEASEDIR (or %JBCRELEASEDIR% for Windows computers). For a system with one active Journal, this will be the location of its
configuration. If other system topologies require separate Journaling facilities (for separate databases?), then the environment variable
JBCLOGCONFDIR is used to identify the location of such configurations.

jediLoggerAdminLog
This file contains logged data regarding the running of Transaction Journaling. The details of this file refer to changes to the Journaling con-
figuration as well as error/warning messages generated bt the Journaling system.

jediLoggerTransLock
This file is used by the Journaling system to act as a lock table during checkpointing. No user information is contained therein.

Configuring Transaction Journaling

jlogadmin
The jlogadmin command allows for the administration of the jBASE Transaction Journal. The jlogadmin command will enabled for interactive
usage when invoked by the super-user/Administrator; execution by other users being restricted to read-only. All administration tasks con-
tained within the jlogadmin utility can also be invoked from the command line, using jlogadmin, with optional parameters.

When the jlogadmin command is executed interactively, navigation to the next field is by using the tab key or cursor-down key and to the pre-
vious field by the cursor-up key. Each field can be modified using the same editor type commands as available in jsh. Changes to a particular
field are effected by the <Enter> key and CTRL-X is used to exit from interactive mode.

Interactive Display
The first execution of jlogadmin will display the following screen:

JBase - User Guide - Release R15.000 - Page 33 of 629


Description of fields

Status:

Specifies the current transaction journal status, which can be On/Active, Off/Inactive or Susp/Suspended. Note: When the status is changed to
Suspended, all transactions which would be updated in the transaction log file will also suspend awaiting a change of status.

Current Switched Log Set:

Specifies the current log set in use. There are four possible log sets – numbered 1 to 4. An entry of 0 indicates that no log set has been chosen
at this time.

Extended records:

Specifies additional information: the application id; the tty name and the login name, will be added in the jBASE transaction journal for each
update.

Time between log file syncs:

Specifies the number of seconds between each synchronization of the log set with the disk. All memory used by the log set is force flushed to
disk. Should the system crash, the maximum amount of possible data loss is limited to the updates which occurred since the last log set syn-
chronization.

Time between log file checkpoints

Specifies the number of minutes between system checkpoints.  After a transaction has completed, this time is checked. If expired, then a sys-
tem checkpoint is performed.

Log notify program:

This specifies the program to execute when the warning threshold of the log set is reached. The log notify program is called every time a mes-
sage is written to jediLoggerAdminLog. The text of the message can be captured by adding arguments to the command line which the notify pro-
gram can examine using SENTENCE(). For example, possibly define the program as:

In addition, when the program is loaded, the following are substituted:

An example of a log notify program, “switchlogs” may be designed to allow automatic switching of logset when the warning threshold is
reached:

The program identified by the “log notify program” is called each time that a message is entered into jediLoggerAdminLog. It is the respons-
ibility of the called program to deal with the reason for the message being entered. The function SENTENCE returns information from JediLog-
gerAdminLog about the latest entry.

NOTE: The message is designated INFORMATION, WARNING or FATAL ERROR. This designation can be used by the log notify program to
decide on a course of action. The messages that can be logged are:

JBase - User Guide - Release R15.000 - Page 34 of 629


Type Message StdOut

INFORMATION Log set changed to s Yes

Log set s truncated Yes

File f for log set s REMOVED Yes

File f for log set n changed to newfilename Yes

n files imported to log set n (see -i option) Yes

Status of logger set to status (current log set s) Yes

Sync count changed from every n1 seconds to every n2 seconds Yes

Log file warning threshold set to p initial percentage thereafter every additional q per- Yes
cent or n seconds

Admin. Log Notify Program now set to program Yes

Admin. Log Notify Program REMOVED Yes

Extended Record Status now set to on|off Yes

Log set switch detected, was set n1, now set n2 No

Kill initiated on jlogdup process id pid : Process id pid from port n Yes

First record read from set n Yes

Termination Statistics: usr x , sys y , elapsed z Yes


r records read from current log set number n : r records, b blocks, rb record bytes , e
errors in file

WARNING Journal Log Files now at p% capacity No

FATAL  ERROR Unable to open logger configuration file filename Yes

Sync demon appears to have died prematurely Yes

Error number errno while reading from file filename No

Error number errno while writing to log file No

Error errno while writing to log journal file filename" Yes

Error errno while writing to log journal Yes

Unable to open logger file filename Yes

Out of memory to log update Yes

Warning threshold:

If the amount of space consumed in the file system, which the active logset resides upon, exceeds the specified threshold, it runs the log notify
program. Individual files in a logset have a capacity of 2GB. If the logsets are not switched, files in a logset can grow to the 2GB limit without
the file system reaching the threshold capacity. If this happens, journaling will cease to function predictably and normal database updates may
fail.

Sync Transactions

An option “SYNC” exists for the TRANSTART command which will force-flush the database and journal following a transaction commit. The
option in jlogadmin allows for this option to be invoked globally. If  “Sync Transactions” is set to “on” then all committed transactions will
cause the force-flush. If set to “off” then committed will not automatically force-flush the database and journal unless the “SYNC” option is
present in individual TRANSTART commands.

JBase - User Guide - Release R15.000 - Page 35 of 629


Encrypt Records

The transaction journal is not normally encrypted. This option will allow the data content of each record to be encrypted on disk. The data con-
tent of each record will be encrypted with an (internally-specified) industry-standard encryption scheme, using an internal key. The record head-
ers remain unencrypted so that all utilities accessing the journal will be unaffected.

File definitions:

As indicated above, the maximum size of an individual file is 2GB. It is clear that if a single file were used for the log file, then this would likely
be insufficient for most realistic application environments. Therefore the administrator is able to set up a log set consisting of a maximum of
sixteen files, thus enabling a maximum log set of 32GB. The configuration will allow for a maximum of four log sets. Usage and switching of the
four log sets will be described in appropriate sections. If the file specified by the administrator does not already exist, then it will be created
automatically.

Command-Line Syntax
In addition to the interactive screen setup facility, there are options which can be added to the jlogadmin command execution. This allows the
administrator to create scripts which can be run either at pre-defined times or intervals; or in response to transaction journal events (usually
error handling events).

The command is invoked by the following:

jlogadmin –{options}
 Where {options} are identified below:

SYNTAX ELEMENTS

Option Description

-a status Set status On/Active, Off/Inactive, or Susp/Suspend

-c Create file in log set if does not exist. ( use with -f )

-d[1-4] Delete logset

-f set,- Change log filename in log set where


fileno,file
Set Logset

fileno File number

File File name

-h Display help

-i[1-4],- Import a log set to override one of the 4 standard log sets. The -o argument is optional. If used it
filename{,fi- suppresses the warning and confirmation message. You can specify up to 16 filenames to define
lename...} the imported log set

-j pwd Password protect journal with “pwd”

-k pid | * | ? Kill jlogdup process ‘pid’ or ‘*’ all or ‘?’ to list.

-l num | next | Switch to log set where


eldest
num log set number 1-4

next next sequential log set

eldest earliest log set

JBase - User Guide - Release R15.000 - Page 36 of 629


-m Set to encrypt all records “ON” or “OFF”

-n program Set threshold notify program.

-o Perform operation without checking if the specified log set is empty. Used with -f and -t.

-p Checkpoint every “nn” minutes

-r Set the sync all transactions to “ON” or “OFF”

-s secs Set synchronization period

-t Truncates log set n. The log set may not be the current switched set. This option ensures that
disk space will be freed and is sometimes preferable to "rm" which may not free the disk space if
any process still has log files open

-w pp, ii, ss Set threshold where

pp initial warning percent

ii every percent after initial percent

ss every second after initial percent

-x status Set extended log record ON or OFF

-C Clear transaction journal administration log file jediLoggerAdminLog

-I Display the statistics if a log set using the embedded information

-V View transaction journal administration log file jediLoggerAdminLog

Defining Logsets
The following diagram illustrates the constituent parts of a Transaction Journal installation

Each logset should, ideally, be defined within a separate filesystem/partition. The definition of the logset can either be the root of such a filesys-
tem/partition or some sub-directory therein. Each logfile within such logsets are special files; the implication of this is that they should not be
created/restored without using the jlogadmin utility. N.B. This will not only create the files where specified but will also enter such con-
figuration in the jediLoggerConfig file.

Example: Creating 2 logsets with 3 logfiles in each

Using the interactive display:

JBase - User Guide - Release R15.000 - Page 37 of 629


e:\logset1\logfile1: No such file or directory

jlogadmin: File 'e:\logset1\logfile1' cannot be opened.

Do you want to create this file (Y/N) ?

Note: Because the logfile does not exist, the operator is asked to create. If e:\logset 1 does not exist, then a message will be displayed:

Following the completion of the creation of this logfile, the operator moves to the next file definition (2) by tabbing to the next field. When all
three files have been created in this way, by entering the cursor key several times, the log set number is changed from a “1” to a “2”. The same
procedure may now be followed to create the logfiles for logset 2.

The following command lines may be used to create both logsets thus:

If the “-c” option is omitted then the files will be created automatically without prompting the operator. The same caveat still exists – if the log-
set directories do not exist then the commands will fail.

A batch file is usually created to perform logfile creation.

Use of logsets and logfiles


Each logfile is designated as having a maximum size of 2Gb on all platforms: with a maximum population of 16 such files per logset, this make
the maximum size of each logset 32Gb. Transaction Journaling relies on a logfile not exceeding its 2Gb limit, otherwise Journaling will be sus-
pended automatically. In order to achieve the 32Gb size per logset the following procedure is followed internally by the Journaling routines:

JBase - User Guide - Release R15.000 - Page 38 of 629


Notes:

l Access to the logger is restricted to this process. Other process will wait until unlocked.
l Writes to a logfile are contained in 4k blocks. If the record (and associated update information) can fit into the current block, then it
is allocated as much space as it needs in that block.
l If the current block is too small then the remainder of the block is allocated; the next logfile is selected and the test for fit is
repeated.
l Once all the requested size of update has been allocated, the configuration file is updated with details of: which logset to update next;
which file in that logset and the offset in that file to write the next data.
l The logger is now unlocked, the next process may now allocate space in the logger.
l The space has been allocated in the logger, this process may now write the updated record data to the assigned space. This allows for
a rapid throughput of logger space allocation, while allowing asynchronous writes to the logger.
l The process can now write to the logger asynchronously, knowing that the allocated space cannot be written to by other processes.
The use of asynchronous writes is vital during writes of large updates. Note that utilities which access the logfiles directly are aware
of this situation and will retry the reads of the logger until a complete record is read.
l The next process requiring writing to the logger may now do so.

Observing the use of the buffers in step (iii), the writes to the logfiles contained in a logset is in a “striping” manner.  The file space initially
used when creating a logfile is approximately 4k. As allocated buffers in a logfile as used, then the logfile grows accordingly. So if one logfile
were to be allocated to a logset, then once the 2Gb limit was reached, then Transaction Journaling would be suspended. Now if (say) 16 log-
files are allocated in a logset and we use the “striping” of each file to contain data in a round-robin basis, it can be seen that if the first logfile
allocated exceeds the 2Gb limit, then each of the other logfiles in the logset would be almost to that limit. So Transaction Journaling would
be suspended after almost 32Gb of journal information has been stored.

Logset Switching
As stated above, there can be up to four logsets defined. The number of logsets which need to be defined is dependent on particular system
operation requirements.

Single Logset

JBase - User Guide - Release R15.000 - Page 39 of 629


Transaction Journaling may be run with a single defined logset. The expected maximum size that the logset will reach must be calculated. This
depends on the following factors: the transaction frequency and the average size of transactional data. If the intended backup regime is daily,
then the logset will be constrained to 32Gb. This is unlikely to be a limiting factor for most installations. The backup strategy is forced to be
off-line; all outstanding transactions must complete prior to the backup being taken. Following this backup, the logset can itself be archived
and then the logset re-initialised back to an empty state.

An example of a command to use to achieve this is (assuming that logset 1 is defined):

This command switches to logset 1 (make current) and then sets Transaction Journaling active.

or alternatively, if journaling already active:

These commands take advantage of the fact that when a logset is re-used, it is automatically truncated to an empty state.

The system is now usable again for multi-user operation.

Note: The “Log notify program” may be used to automate this switching as previously described.

Multiple Logsets

The normal configuration for Transaction Journaling is to use at least two logsets. If the maximum logset usage between backups is greater
than 32Gb (?), then multiple logsets will have to be defined to increase this capacity. This is not the normal case. Multiple logsets are normally
used so that the updates since the penultimate backup are preserved. This has two benefits: if there is a problem with the last backup, the
administrator has the option of recovery to the previous backup, followed by a roll-forward of the transactions since that backup. The oper-
ation is then:

Notes:

l This is done to ensure, positively, that no more updates are added to the Journal
l This logset will be set to an empty state automatically
l This archive would be used if the backup at failed and the previous backup used instead for recovery.

JBase - User Guide - Release R15.000 - Page 40 of 629


The Transaction Journal/Log
Access to the transaction log is via a special file. Use the CREATE-FILE command to create the file stub:

This creates an entry in the current directory

TJ1
JBC__SOB jBASE_TJ_INIT SET: set=current terminate=eos

When a file of type TJLOG is created, it generates a set of dictionary records in the dictionary section of the TJLOG file, which is a normal j4
hash file. The data section of a TJLOG file is handled by a special JEDI driver which accesses the current log set. The log set can be changed by
additional parameters when creating the TJLOG file after the TYPE specification.

Example
CREATE-FILE TJ2 TYPE=TJLOG set=eldest

Transaction Log File Layout

The transaction log files contain the following information

Attribute Name Description

1 SET Log Set

2 FILENO File Number

3 OFFSET File Offset

4 LOGSIZE Total Log Record Size

5 TYPE Log Record Type

6 TIME-UTC UTC Time

6 TIME Update Time

6 DATE Update Date

7 TRANS Trans

8 TYPENUM Log Record Type

9 PID Update Process

10 PORT Update Port

11 ERR Error Description

12 TRANSID Transaction Identifier

21 PATH Full file path name

22 RECKEY Update Record Key

23 JBNAME jBASE Login Name

JBase - User Guide - Release R15.000 - Page 41 of 629


24 OSNAME Platform Login Name

25 TTY Terminal Name

26 APPID Application Identifier

27 SOURCE Source Program Name

28 LINENO Program Line Number

29 REALTIME Program Update Time

30 TRANSTIME Transaction Elapsed Time

31 TRANSCOMP Number of Completed Transactions

32 TRANSABORT Number of Aborted Transactions

1 Default Macro will list TYPE JBNAME PATH TIME DATE

ALL Macro will list all fields

ERRORS Macro will list TYPE JBNAME PATH ERR

Transaction Log File Layout


 The following record types are used in the transaction log (see dictionary item TYPE).

Type Description

EOF End of file

WRITE Record Written

DELETE Record Deleted

CLEARFILE File Cleared

DELETEFILE File Deleted

CREATEFILE File Created

TRANSTART Transaction Started

TRANSEND Transaction Committed

TRANSABORT Transaction Aborted

CHECKPOINT Checkpoint Marker

Selective Restores

The jlogdup command enables selective restores to be performed by preceding the jlogdup command with a select list. The select list can be
generated from the log set by generating a special file type, which uses the current log set as the data file.

JBase - User Guide - Release R15.000 - Page 42 of 629


Example

In this example, all updates to the CUSTOMER file, which have been logged, except for any CLEARFILEs, are re-applied to the CUSTOMER
file.

Note: This type of operation must be used with great care! It is highly possible that the database may be left in an inconsistent state ifs an
individual file is rolled-forward. If transactions contain updates to more than one file (the normal case), then regard must be paid to other
file updates occurring within those transactions in order to maintain database integrity.

JBase - User Guide - Release R15.000 - Page 43 of 629


Monitoring TJ

jlogstatus
The jlogstatus command displays the status of the jBASE Transaction Journal. In its simplest form the jlogstatus, command shows a summary
of the current Transaction Journal activities. Additional command line options are available for output that is more verbose. The jlogstatus
command can also be used to present a rolling status screen, using the ‘-r n’ option, which will update the display every ‘n’ seconds.

SYNTAX
jlogstatus -options

SYNTAX ELEMENTS
Option Description

-a display all available information

-c display current log information

-d display jlogdup process information

-g display general information

-h display help

-l display all Log files information in summary mode

-r nn set display to repeat every nn seconds

-v verbose mode

Example

This will display all information and will refresh every 5 seconds.

JBase - User Guide - Release R15.000 - Page 44 of 629


JBase - User Guide - Release R15.000 - Page 45 of 629
JLOGSYNC

When a jBASE application performs a database update, it writes to the transaction log file (if active). It does this to a memory image and nor-
mally it is up to the platform file system to flush the memory image to disk every so often, by default on most platforms this is usually every
minute.

You can use options in jlogadmin so that the jBASE processes themselves do this file synchronization more often. The default is every 10
seconds. This means in the event of a system failure, you will lose at the most 10 seconds worth of updates.

The use of the jlogsync program means the jlogsync process instead of individual jBASE processes performs file synchronization, thereby alle-
viating the overhead of the synchronization from the update processes. Thus, the jlogsync process is not mandatory. However, in a large install-
ation it may provide beneficial performance gains.

Note: This command is not available for Windows platforms.

SYNTAX
jlogsync -options

SYNTAX ELEMENTS
Option  Description 

-b run in the background (normal operation)

-d display jlogsync demon status

-i initialize and become the jlogsync demon

-k kill the jlogsync demon

-t nn Inactivity timeout period (seconds) for detecting jlogsync being killed

-v verbose mode

-S force synchronization now

Options –i and –b – starting jlogsync

The most common way of starting jlogsync is by using the “-i” and “-b” options. This will stat the process in the background. The command
will be typically be used in a machine startup script, prior to allowing multi-user mode.

jlogsync -i
jlogsync: Started on pid 1640

Option d – displaying status of jlogsync

Standard display is obtained thus:

jlogsync: $Revision: 3.3 $


Program at pid: 1640
Program started: Fri Dec 23 09:33:23 2011
Memory: 81264 bytes used , 13768 bytes jfree

JBase - User Guide - Release R15.000 - Page 46 of 629


CPU Usage: 15.14 usr , 0.00 sys

Option k – kill the jlogsync daemon

The daemon may be killed by the administrator by the use of the ”-k” option. No message is displayed unless the kill fails  in which case “kill”
will be displayed.

Option tnn – set the jlogsync inactivity timeout

When jlogsync is initialized, a default inactivity timeout count of 5 minutes is set up to determine whether the daemon is still working cor-
rectly. If this time does expire and the daemon has not done anything in the meantime, it is deemed at this point that the daemon has died pre-
maturely. The “-tnn” option allows for an inactivity timeout period of “nn” seconds. This value can be any values greater than 60 seconds
(despite the “nn” description).

If the inactivity timeout period is reached then a message is displayed:

Sync demon appear to have died prematurely

Option v – verbose output

When this option is used details of the last sync events are displayed along with details of the inactivity timeout and logset warning values.

jlogsync: $Revision: 3.3 $


Program at pid: 1640
Program started: Fri Dec 23 09:33:23 2011
Memory: 81264 bytes used , 13768 bytes jfree
CPU Usage: 15.14 usr , 0.00 sys
Last forced sync: Fri Dec 23 09:33:38 2011
Last check time: Fri Dec 23 09:33:38 2011
Inactivity timeout: 300 seconds
Warning threshold: 70 initial percent
1 increment percent thereafter
300 increment seconds thereafter

Option S – force a sync. now

This option is used to force-flush the journal.

JBase - User Guide - Release R15.000 - Page 47 of 629


JLOGMONITOR

The jlogmonitor command can be used to monitor potential problems with the jlogdup process. It will report errors when specific trigger
events occur. jlogmonitor can be run in the foreground but will usually be run as a background process (using the standard –Jb option).

SYNTAX
jlogmonitor {-h|?} {-ccmd} {-Cnn} {-Dnn} {-E} {-Inn) {-Snn}

SYNTAX ELEMENTS
Option Description

-ccmd The command cmd is executed when an error occurs.

-Cnn If the file system utilization of the journal log exceeds nn% full then an error message is dis-
played. The error message is repeated for every 1% increase in file system utilization.

-Dnn If the jlogdup process processes no records (or if there is no jlogdup process active), then
after nn minutes of inactivity it displays an error message. It repeats the error message
every nn minutes while the jlogdup process(es) is inactive.

-E If the jlogdup program reports an error, this option causes jlogmonitor to also display an
error. You can view the actual nature of the error by either looking at the screen where the
jlogdup process is active, or by listing the jlogdup error message file (assuming the –
eERRFILE option was used).

-h display help

-Inn The status of the Journaler can be ACTIVE, INACTIVE or SUSPENDED. If the status of
the journaler is either INACTIVE or SUSPENDED (with jlogadmin) for more than nn
minutes, it s=displays an error message. The error message will be repeated every nn
minutes that the journaler is not active

-Snn Use this option to determine if any updates are being applied to the journal logs. If no
updates are applied to the current journal log set for nn minutes it displays an error mes-
sage. It repeats the error message for every nn minutes of system inactivity.

Note: You must specify at least one of the options, -C, -D, -E, -I or -S.

Examples:

l -Cnn

A monitor may be set up which will display a message once the warning threshold (as defined in jlogadmin) has been reached. The mon-
itor will then wait until the percentage full has increased by 1% at which point a new message indicating this is displayed. This will con-
tinue indefinitely (or until aborted).

jlogmonitor -C10

09:43:30  14 DEC 2006 Journal File System capacity exceeds 10% , actual 89%

09:46:30  14 DEC 2006 Journal File System capacity exceeds 10% , actual 90%

l –ccmd

jlogmonitor –c"MESSAGE * %"

JBase - User Guide - Release R15.000 - Page 48 of 629


The command "MESSAGE * %" is executed for every message sent to the screen by jlogdup. The jlogmonitor specially interprets the
use of the % by the program and will be replaced with the error message.

jlogmonitor -C91 -c"jlogadmin -lnext"

l -Dnn

This option allows the operator to monitor any jlogdup processes which may be running. If there is no activity for the specified time,
then an error message is displayed. Note that this command will report inactivity for all running jlogdup processes. It is not possible
to specify one of many jlogdup processes to monitor.

jlogmonitor -D1

10:09:25  14 DEC 2006 No reported activity from the jlogdup programs

10:10:25  14 DEC 2006 No reported activity from the jlogdup programs

10:11:25  14 DEC 2006 No reported activity from the jlogdup programs

l –E

If one or more jlogdup processes are reporting errors, jlogmonitor may be used to display this condition. The process will interrogate
all running jlogdup processes for erros which have been encountered. If any are reporting errors a message similar to the following will
be displayed:

jlogmonitor -E

15:52:52  18 DEC 2006 jlogdup is reporting 2 errors

Further information about any such errors can be found on those screens running the jlogdup processes which are reporting errors.

l -Inn

If journaling is suspended or stopped for any period, jlogmonitor may be used to trap such occasions. The “nn” parameter is in
minutes, so if journaling is stopped/suspended for more than this time a message to that effect will be displayed.

jlogmonitor -I1

16:08:31  18 DEC 2006 The status of the logger is not active

16:09:31  18 DEC 2006 The status of the logger is not active

This will be repeated every “nn” minutes or until aborted.

l –Snn

This option is similar to the “-I” option, but will display a message if no updates have been made to the journal for “nn” minutes.

jlogmonitor -S1

16:13:07  18 DEC 2006 No reported activity being applied to the journal log sets

16:14:07  18 DEC 2006 No reported activity being applied to the journal log sets

The options may be combined on the command line to trap any or all of the possible conditions described above.

So,

jlogmonitor -S1 -I1 may display:

16:14:25  18 DEC 2006 The status of the logger is not active

16:15:25  18 DEC 2006 The status of the logger is not active

16:15:25  18 DEC 2006 No reported activity being applied to the journal log sets

16:16:25  18 DEC 2006 The status of the logger is not active

16:16:25  18 DEC 2006 No reported activity being applied to the journal log sets which indicates the reason for there being no updates
to the logger.

JBase - User Guide - Release R15.000 - Page 49 of 629


JLOGDUP

The jlogdup command provides the capability to duplicate transaction log set data from the jBASE Transaction Journal. The transfer may be in
the simple case an archive of the Transaction Journal to an external device or may be used in a combination of transfers to produce a “hot
standby” machine. The whole or part of a transaction logset may be transferred, either following a jBASE SELECT statement or by specification
in the jlogdup command line. The transfer process(es) may be monitored utilising a comprehensive range of dynamic statistics.

SYNTAX
 jlogdup -Options INPUT input_spec OUTPUT output_spec

An “input specification” consists of a source device for the transfer with optional run-time parameters and   an “output specification” consists
of an output device and associated optional run-time parameters. The “Options” parameters are generally used to display/record information
about the transfer overall.

SYNTAX ELEMENTS
Options

Option Description

-e file error file for database update errors

-f used with the -v or -V option; shows information for the next (future) update; by default

information for past updates is displayed

-h display help

-l file log file to write all status and errors information

-m nn maximum number of errors (default 10000)

-u nn display '*' every nn input records

-v verbose mode, 1 line per record

-x exclusive use of the database, no group locks taken

-V display verbose help screen

-H display verbose help screen

INPUT_spec/OUTPUT_spec
The input/output specification can specify one or more of the following parameters

Parameter Description

blockmax=nnn (S) the maximum size, in blocks, of a serial device

blocksize=nnn the block size to read/write to TTY/SERIAL device or file

device=file%dev (S) the file name for SERIAL device. Can be more than one

encrypt=true(O) output transfer is to be encrypted

JBase - User Guide - Release R15.000 - Page 50 of 629


end=timespec (I) time in log set at which to stop restore/duplication

hostname=host(IOK) host for socket transfers to / from

key=encryptkey the key to use for encryption

noflush=true (O) suppress flush of output at end of transaction. (default false)

notrans=true (O) ignore transaction boundaries. (default false)

port=portnum (IOK) socket port to use for socket transfer

prompt=true prompt when switching serial devices or files

rename=from,to convert path name directories ‘from’ to ‘to’ on restore

renamefile=file (O) use rename file list of format ‘from,to’ to rename files

retry=nn (I) specifies the interval between retries, when 'terminate=wait'

scheme=method encryption method

set=current (IL) begin restore/duplication using the current log set as input

set=database (OD) output is to the database, i.e. Restore mode

set=eldest (IL) begin restore/duplication using the eldest log set

set=n (ILN) begin restore/duplication using log set number n

set=null (O) output is to be discarded

set=serial (S) input/output is to a serial device or file. Requires ‘device=’

set=socket (IOK) input/output is to a socket

set=stdin (IT) the input data comes from the terminal stdin

set=stdout (OT) the output data is directed to the terminal stdout

set=tty (T) the input is from stdin or the output is to stdout

set=logset (OL) the output is directed to the current log set as an update

start=timespec (I) time in log set at which to start restore/duplication

terminate=eof (I) terminate restore/duplication at eof of eldest log set

terminate=eos (I) terminate restore/duplication at end of current log set

terminate=wait (I) switch to elder log sets as required and wait for new updates

terminate=waiteos(I) switch to elder log sets as required and wait for new updates until logset switched, then terminate

timeout=nnn (I) timeout period in seconds for ‘terminate=wait'

verbose=true display to stderr a summary of the specification

The indicators in brackets denote:

Indicator Meaning

D specification valid for type database

I specification valid for type input

JBase - User Guide - Release R15.000 - Page 51 of 629


K specification type for socket

O specification valid for type output

L specification valid for log set

N specification valid for type of null

S specification valid for type serial

T specification valid for type terminal

timespec 
The time specification, used in the ‘start=’ and ‘end=’ specification can be one of the following formats:

Timespec meaning

hh:mm:ss  time of day (todays date assumed)

DD-MMM-YYYY  date (midnight assumed), Any date convention accepted 

hh:mm:ss,DD-MMM-YYYY  both time and date specified either way around 

jbackup_file  time of file created. Use with 'jbackup -sfilename' option 

filename regular file, use the time the file was last modified 

checkpoint use last checkpoint time as start of transfer time 

Examples of use  
In order to expand on the description of each of the many specifications and options, a series of example usages will be used for illustration.

Example 1: Archiving Journal to Off-line Media

Input and Output Specifications

If the Journal, depicted above, contains 4 logsets: logset1-4 and logset2 is the active logset, then a snapshot of this logset may be made to
either a real tape drive e.g. /dev/rmt0 on AIX or a tape image file E:\jrnl_save on Windows, so:

current or 0-4

The current logset refers to that logset which is selected for use at this time within transaction journaling. This logset may be active or inact-
ive. Logset 0 is a special case and means that there is no logset currently being used at this time. It is possible to define up to 4 logsets and the
number 1-4 refer the specific logset.

JBase - User Guide - Release R15.000 - Page 52 of 629


or

It can be seen that the input set, whether specified as current or 2 refer to the same logfile data and that this is the source of the transfer.

eldestLogset

Logsets may have been switched since the last backup, so the updates made to the journal may exist in more than one logset.  Consider that
the data in logset1 contains the oldest data and logset2 contains the more recent, a command such as:

This will take all the data in logset1 and all in logset2 (to this point) and output to the destination as specified by the “output spec”. 

blocksize

The output specification indicates where to put the logfile data. The size of the blocks written to a tape device can be specified using the block-
size parameter, thus: 

blockmax 

In the likelihood that the tape capacity is less than the journal size, another parameter, “blockmax” may be used to specify how many blocks
(as specified by “blocksize”) may be written before the media is required to be changed.

Multiple Devices

When using tape devices it is possible to specify multiple devices so that in the event of media overrun, the jlogdup operations may continue
without intervention

When the end of the tape on /dev/rmt0 is reached (or blockmax is reached), operations will automatically continue on /dev/rmt1, and so on. A
check is made that the media being used is not reused from the same jlogdup operation (by timestamps). If there is a conflict, user intervention
is required.

The following diagram depicts the flow at end of media.

JBase - User Guide - Release R15.000 - Page 53 of 629


If user intervention is required then the user may “R”etry the write “Q”uit the jlogdup operation, or “N”ext device. If  “N”  is entered, then if the
number of devices specified in the command is greater than 1, then the next in sequence in the command is used. If all else fails the user is
asked to “C”ontinue, “Q”uit or “R”ename. The rename option allows a different device to be specified. After this prompt no further checks are
made, automatic checking will be over-ridden.

prompt=true

If no automatic cascading of tapes is desired the use of “prompt=true” on the command line will force operator intervention:

Verifying a logging tape


A tape holding journal data may be verified for readability and for correct formatting for such a tape. An example of this could be :

nullspecification

JBase - User Guide - Release R15.000 - Page 54 of 629


Terminating jlogdup

These definitions will assist in explanation of how jlogdup is terminated.

Taking the earlier example :

This command will terminate when the end of the current logset (i.e. 2), is reached (unless terminated externally). This will only give a partial
snapshot of the journal.

terminate=eos, terminate=eof

These specifications are normally used when more than one logset is defined and more than one logset contains valid logfile data; as above.

The command:

will backup all entries in the journal from the start of logset1 (the eldest) up to the last update in logset1 – no further updates will be saved.
Again this is only part of the information required to recover all of the data.

And the command:

or

will take all updates from the start of the journal and output to the tape all records up to and including the last update on set 2, the current log-
set.

Note: Omitting “terminate=??” will default to “EOF” the end off all logset containing valid data.

terminate=wait

What is more normal is that we want to transfer from the beginning of all logsets, transfer all the logfile data and the wait for new updates, then
transfer them (e.g.) to tape as they arrive. Thus will achieve this.

JBase - User Guide - Release R15.000 - Page 55 of 629


terminate=waiteos

This is a combination of two previous terminations: wait and eos.

This will perform as the previous example, with the exception being that while waiting for new updates, if the logsets are switched then the jlo-
gdup process will terminate. This may be used to trigger some batch operation, ensuring that all updates from that point will reside in another
logset.

timeout

When using “terminate=wait” or “terminate=waiteos” it is possible to set a limit of the amount of time the process will wait for new updates
into the journal. If the “timeout” option is missing the process will wait indefinitely, otherwise it will wait for the number of seconds dedfined
in the “timeout” option.

The jlogdup process will wait for 5 minutes or the switching of the logset before terminating.

retry

The “retry” option is used to attempt to re-read the journal for a complete record and refers to the time delay between re-reads.  A complete
record may exist in the journal when the update to the journal is from a slow device (i.e. tape device) or is a large record, or a combination of
both. The start of the record may have been written but the rest of the write may not yet have completed. This option allows this the operator
to change the default delay time from 5 seconds to another value in seconds. The re-read is attempted 10 times and is normal operation.

The “retry” time allows the operator to override the default wait time of 5 seconds to so other value. Therefore, will wait for 3 seconds between
retries.

verbose=true

This option confirms the input and responds with details about when and how the process will be terminated.

timespec, start= and end= 

JBase - User Guide - Release R15.000 - Page 56 of 629


The timespec options are optional parameters which allow the operator to start and/or end the jlogdup transfer from positions which are not
at the start or end of the logset(s).  The “start=” and “end=” specifications have several formats:

Firstly without time specs.:

Using simple start time specification:

JBase - User Guide - Release R15.000 - Page 57 of 629


Note the difference if record and byte counts.

Using a date specification:

JBase - User Guide - Release R15.000 - Page 58 of 629


Using time and date specification:

JBase - User Guide - Release R15.000 - Page 59 of 629


Using start and end times to show all updates in 1 minute:

JBase - User Guide - Release R15.000 - Page 60 of 629


notrans=true

Start and End times are chosen by the operator. At (probably) any specified time there are likely to be more than one transaction open (i.e.
records are being updated between transaction boundaries). During normal operation, when the destination is “database” , jlogdup will alert the
operator that if a record is to be transferred and that record is part of a transaction, and that the transaction start record has not been detected.
This is not a fatal situation, but alerts the operator to those records so found. These records will not cause the database to be updated with
their contents. These records will cause a message like:

If however a command like :

is issued, then the fact that the updates were part of a transaction is ignored and the database will be updated. This may cause the database to
enter an inconsistent state.

Note: It is advisable that this option is not used without careful analysis of the outcome.

If a backup is now performed with the –sfilename option (create statistics file), and then use this as the start of jlogdup (after adding some
more updates to the journal):

JBase - User Guide - Release R15.000 - Page 61 of 629


If a file is now created (as a marker), and more records added to the journal:

JBase - User Guide - Release R15.000 - Page 62 of 629


Described earlier in the documentation, checkpoint records are written to the journal periodically. A jlogdup transfer can be specifying the last
checkpoint as the starting point within the journal. This will contain all updates since the database was deemed to be in a consistent state:

JBase - User Guide - Release R15.000 - Page 63 of 629


The end of a jlogdup process may also be specified by the last checkpoint within the journal:

JBase - User Guide - Release R15.000 - Page 64 of 629


Example 2: Transfers between computers
This example will be used to illustrate transfers between two computers.

Journal data may be transferred to a different computer by one of two techniques: using “stdin” and “stdout” and “rsh”. Though this method
does work for Unix/Linux-based computers, because of the lack of security it is now not the recommended method of transfer. A “socket” inter-
face exists which allows the operator to manage the transfers more robustly.

stdout

To specify the output destination of a jlogdup transfer, a command like the following may be issued:

The output from this command is omitted as it will contain non-printable characters.

stdin, database

JBase - User Guide - Release R15.000 - Page 65 of 629


This specification will be used for the source end of the transfer, taking input from the pipe and outputting to the destination, in this case dir-
ectly updating the local database.

rsh

To tie these two commands together it is usual to use rsh – remote shell daemon.  All activity is controlled from the local host (Nodej, here)
and will execute a command on the remote host to run a jlogdup process on that computer (Nodek).

This script will set up to run jBASE commands and then run a jlogdup process to update the database on Nodej.

/GLOBALS/JSCRIPTS/logrestore Script

tty

For the specifications “stdin” and “stdout”, the specification “tty” may be used instead.

can be replaced by:

and

can be replaced by:

Sockets

socket,  hostname, port, logset

JBase - User Guide - Release R15.000 - Page 66 of 629


The socket interface between computers Nodej and Nodek allows the operator to set up one or more client-server relationships. On Nodej a
simple jlogdup command may be set up which will take input from the specified set device and output to a socket. This socket refers to a TCP
port on a destination computer (Nodek). On Nodek, again a simple jlogdup command may be set up which will take input from a socket and
output the journal data to the destination device: to the current logset. This time the socket refers to a TCP port on Nodek – a listening
socket.

Note: The receiving jlogdup must be set up before the sending jlogdup; failure to do this will cause the sending jlogdup process to fail with
an error message:

Note: As the output device is “logset”, transaction journaling must be set up on Nodek and active. If there is a “current” logset defined but
not active, then a message similar to this will be displayed:

If logging has not been set up at all, the transfer will stop immediately and a message similar to this is displayed:

This message will be displayed periodically until logging is set active. If logging is subsequently made active then the transfer will complete as
normal.

An example set up for Nodek could be:

JBase - User Guide - Release R15.000 - Page 67 of 629


where:

l socket  is the device specification.


l hostname is the IP address or the DNS name of the host to use for socket transfers – in this case Nodek – this host is waiting for a
connection to be made to it.
l portnum is the TCP port to use for socket transfers. In this example port 4089 is chosen. This can be any unused TCP port (and
therefore must be decided for each system).

Once Nodek has been set up, Nodej can be set up thus:

This will connect to the jlogdup process running on Nodek, transfer all the journal data in the current logset and then terminate. The ter-
mination of the jlogdup process on Nodej will cause the jlogdup process on Nodek also to terminate.

The command :

Will now connect, transfer all the journal data from the current logset and then wait for new updates, transferring the updates as they arrive. 
This process will not terminate and will thus keep the socket open for transfers to Nodek.

This command will listen for a connection, then receive journal updates and output to the current logset. If the jlogdup process on Nodej ter-
minates, then this process will also terminate that connection and will return to listening for a new connection, and so on.

If “terminate=wait” is present on both ends of the socket then this will form a continuous client-server mechanism.

Note:

l If the “timeout” option is used on either end, then the operation will perform as expected, except for one instance. If the receiving end
of the socket (on Nodek) is terminated by the operator, then the sending jlogdup process on Nodej may be sending journal data or be
waiting for new updates.
l If sending data, then the forced closure of the socket will force the termination of the sending jlogdup process and display an error mes-
sage of the form.

JBase - User Guide - Release R15.000 - Page 68 of 629


However, if waiting for new updates, the jlogdup process on Nodej will not be informed of the socket failure until new updates are added to the
journal and the process attempts to transfer them to Nodek, at which point the failure is reported as above.

rename

The rename option is used to change the location of files used within journal updates to other locations.  It is typically used when transferring
data between machine when the directory structure of the two machine is different. As each update is read, if the rename option is effect it will
change the destination location on-the-fly.

The journal may contain a transaction:

JBase - User Guide - Release R15.000 - Page 69 of 629


If the following command were run on Nodek (in our case), you will see that the destination is changed appropriately.

renamefile

JBase - User Guide - Release R15.000 - Page 70 of 629


This option allows for a number of automatic file translations, an that the file only is specified on the command line to enable the translation to
occur.

If a file is defined as C:\move_data and the contents are :

Then using the following command will create the same result as the rename example above.

Note: The rename file may contain many entries, one per line of the form “from,to” to effect many automatic redirections. Note also that
the content of the “from” field must be exactly as it appears in the journal and is case sensitive.

Socket Stream Encryption

Journal transfers via jlogdup are normally on an unencrypted stream, leaving the data unprotected during the session. The operator is able to
specify on the jlogdup command line the form of encryption required for the session.

The first thing to note is that encryption is specified on the sending jlogdup process only; embedded information in the stream will identify that
this stream of data is encrypted, the encryption scheme used and the key to use to encrypt/decrypt the stream. In order that the key (espe-
cially) and the scheme is not sent in clear-text format, the blocks sent between the two jlogdup processes will undergo a further encryption
using an internally-specified encryption scheme and key. Note that the encryption options are only allowed on output specifications..

Using the examples above and extending for encryption usage, the following will illustrate the use of this facility.

where, more generally:

scheme

Is the encryption scheme to use for the transfer of journal entries. This mechanism utilizes OpenSSL high level cryptographic functions. The
valid specifications for encryption are;

l rc2
l blowfish

JBase - User Guide - Release R15.000 - Page 71 of 629


l des
l 3des
l blowfish
l rc2_base64
l des_base64
l 3des_base64
l blowfish_base64

If key is omitted from the command line then a default internal value will be used.

key

Is the string to be used as the encryption key for the transfer of journal entries. If scheme is omitted on the command line, then a default
internal value will be used.

encrypt=true

If either scheme or key are omitted, their values will be internal values. If either key or scheme or both are set then they will override the
default internal values.

Notes:

1. If the logset is encrypted, then this encryption is in addition to any transient encryption during jlogdup transfers.
2. If the logfile is encrypted on the source machine then:
l If the output set is to “logset” then the resulting destination logset will also contain the encrypted records.
l If the output set is to database then the encrypted records are decrypted prior to storage on the database.
l If the output set is anything else then the encrypted records remain encrypted.

Example 3: Report Options


There are various reporting options which may be used with jlogdup, some are displayed in real-time, others record the output to the specified
file location.

-e file

This option will produce an error log containing any update errors during the jlogdup session. The file specified must exist as a hash file.

The use of this option may be illustrated by the following examples:

Starting with an empty logset, set to current and active.

Now create a new hash file thus:

If an attempt to roll the database forward, there will be an error as NEW-FILE already exists. This will be reported to the specified error file.

JBase - User Guide - Release R15.000 - Page 72 of 629


The error_file may now be edited by jed (say), to display the following (edited out blank lines):

JBase - User Guide - Release R15.000 - Page 73 of 629


A new item will be written for each error a new item in the error file.

Note: This option is only valid for “output set=database”.

-f future update

This option is used in conjunction with the “–v” or “–V”

JBase - User Guide - Release R15.000 - Page 74 of 629


option to display the next update to the screen. This may be useful if the updates are very long and some activity is seen after starting the com-
mand. The normal display for “-v” or “-V” is to display the update after completing the update.

-h  help screen

This option is used to display a help screen. It contains an overview of the command and all the reporting options.

–l assign a log status file

This option is used to assign a file to which all status and error information may be stored. This is not the same as the “-e” option in that this
file will record not only the final status of the operation, but also a high-level description of an errors which may have occurred during the ses-
sion.

If the following command is issued:

JBase - User Guide - Release R15.000 - Page 75 of 629


Then “error_file” will contain two records as before.

JBase - User Guide - Release R15.000 - Page 76 of 629


and  the “logger” file will contain the run-time errors and status, thus:

–m nn                  Set the maximum number of errors

JBase - User Guide - Release R15.000 - Page 77 of 629


The “-m” option allow the operator to specify the maximum number of errors before aborting the jlogdup process. This is normall set very high
( the default is 10,000). In this example if we set the maximum count to 1, the process will abort following the first error.

The error file contains:

JBase - User Guide - Release R15.000 - Page 78 of 629


and the “logger” file contains:

-u nn        Display “*” every “nn” records

JBase - User Guide - Release R15.000 - Page 79 of 629


Use of this option provides a periodic display of an asterisk when jlogdup is running. The “-u” option allows the operator to set the number of
records to appear in the journal the display of the next asterisk. Sample output:

Verbose options

Two options exist which allow the operator to view the records being worked on by jlogdup

-v verbose

This option shows the journal update details (“*” separated field showing whever, precisely in the journal the record exists; the type of journal
entry, the file being updated and finally the record being updated

JBase - User Guide - Release R15.000 - Page 80 of 629


-V    very verbose

In addition, the very verbose option also shows the user name; the port number, the time and the date of the update:

JBase - User Guide - Release R15.000 - Page 81 of 629


-x                  exclusive use of database

The speed of database recovery may be improved by the “-x” option. This option must be used with care. No group locks will be taken when
the output set is to database. This is for recovery only, when there should be no processes updating the database.

-H      verbose help screen

This option will display all options for input/output specs.; timespec details plus the output of the “-v” option. 

JBase - User Guide - Release R15.000 - Page 82 of 629


JBase - User Guide - Release R15.000 - Page 83 of 629
Resilient Files

Resilient files have the following characteristics: they are resistant to corruption in adverse conditions and they have the ability to auto-resize
themselves as the population of such files increase

Resilience
For standard  jBASE hashed files, the writing of an item may cause one or many physical disk writes, depending on the size of the item being
written. If the series of writes is interrupted (by say, a power failure), then the structure of the file may be compromised as the item may be par-
tially written to disk.

The resilience (for Resilient files) is provided by running in SECURE mode where any update resolves down to a single disk write, any depend-
ent writes having been flushed to disk beforehand. Fundamentally, the body of the item is written to and then flushed to disk. If a power failure
occurs at this time, the “before image” of the item is still in existence on disk with the integrity of the file being maintained. The intended
update is abandoned (because of the power failure). Upon power being restored to the system, the database may not be in a consistent state if
the failed update was part of a transaction. This does not present a problem as the entire transaction will have been written to the Transaction
Journal prior to attempting any database disk writes of the transactional data. The transaction will thus be replayed in its entirety, thus main-
taining database consistency, (via a roll-forward – this will be described later in the document)

In the normal course of events the final write/ of the item pointer on disk will not be interrupted, the pointer will be switched to the new ver-
sion of the item thus completing the item write.

Autosizing
With the increase in 24 hour operation there has been a corresponding decrease of available time for system maintenance of hashed files. Stand-
ard hashed files become less efficient as the data population exceeds the original creation sizing, resulting in slower retrieval and updates, so an
expanding hashed file requires regular resizing.

Resilient files need no resizing as there is no concept of overflow. When the data within a frame exceeds the available disk space it is split into a
pointer frame pointing to child data frames. The individual items within the frame are rehashed according to the split level and reallocated to
the appropriate child frame. The hashing algorithm base changes according to the split level to avoid common hashing paths.

Where standard hashed files have a linear expansion of search path (the number of data frames read according to population), resilient files have
a logarithmic expansion of the order Modulo, so where an undersized hashed file may require 5 disk reads a resilient file may require 3. A prop-
erly sized hashed file may require only one disk read, but that is assuming regular system maintenance.

The logarithmic search path may imply an exponential file size expansion, but this doesn’t happen in practice as data frames which are not
required, are not allocated.

SYNTAX
CREATE-FILE TYPE=JR [EXTMODS=Modulo] [INTMODS=x[,y[,z]]] [SECURE=YES] [MINSPLIT=m] [HASHMETHOD=h] [SECSIZE=n]
[DEALLOCATE=P|D]

SYNTAX ELEMENTS
Parameter Description

EXTMODS A comma separated list of the modulo of split frames, default 31. When a data frame overfills
it will change to a pointer frame of the order Modulo[level] with a maximum of Modulo[level]
child frames where items are rehashed according to the split level and hashing algorithm.
There are a maximum of 32 modulo and  each must be prime between 3 and 509.

DEALLOCATE The default behaviour is never to deallocate empty frames to the free list. This can be changed
by setting D – deallocate data frames for reuse or P deallocate data and pointer frames. This
can be changed on existing files using jrchmod.

JBase - User Guide - Release R15.000 - Page 84 of 629


HASHMETHOD The internal hash method used in internal and external hashing, default 5 (FNV-1a variant,
recommended).

INTMODS Up to 3 prime numbers defining the internal hash table modulo, default 3, 7, 19. The cumu-
lative product cannot exceed 485, i.e x + x * y + x * y * z.

MINSPLIT Minimum split level of the file. The file will be preallocated to a minimum level of split frames
from the Modulo list. This can have extreme adverse affects on performance and excessive file
size, so its use is not recommended.

SECSIZE Secondary record size, default 2048. Items exceeding this size are stored out of group, i.e. the
item retains its own data frame(s), referenced by a pointer.

SECURE The file is flushed at critical junctures such that any file update will rely only on a single disk
write. This maintains the file structure in the event of system failure.

EXTMODS
Up to 32 comma-separated prime numbers specifying the external modulo for this file. Only one modulo is usually provided, default 31.

DEALLOCATE
When a frame becomes empty through deletion whether to deallocate from the main structure onto the free list. Can be D to deallocate data
frames or P to deallocate data and pointer frames. The default behaviour is not to deallocate any frames.

HASHMETHOD
The hash method as used with all hashed files. The default method of 5 is recommended.

INTMODS
A newly created resilient file consists of a single 4096 byte header containing, amongst other things, an internal hash table up to three levels
deep.

The size and depth of the internal hash table is specified by the INTMODS parameter and by default take the values 3, 7 & 19. The INTMODS
values must be prime and ascending, and the table must fit in the available space in the file header.

MINSPLIT
The MINSPLIT value forces a table to be created with a minimum split level & would normally be used only where the future data population is
known to be large and will remain large throughout the lifetime of the file. In general resilient files control their own sizing and MINSPLIT is
not required.

MINSPLIT can create extremely large files as it is an exponential sizing parameter. Assuming default parameters  (3, 7, 19 & 31) this table show
the resultant filesize:

JBase - User Guide - Release R15.000 - Page 85 of 629


MINSPLIT value Empty file size

0 4096

1 1,638,400

2 50,667,520

3 1,570,570,240

4 48,687,554,560

If the current data profile is not known or the future profile not predictable then the use of MINSPLIT is not recommended.

SECSIZE
As with all hashed files, if an item size exceeds SECSIZE then the record data is given its own linked chain of data frames and only the record
key and a pointer to the data are stored inline. This is known as out of group (OOG) storage. Storing data OOG saves resources when searching
or updating a group.

SECURE
When SECURE=YES is specified updates are flushed to disk where necessary to maintain the structure of the file in the event of a system fail-
ure. This will affect file performance.

Internal Hash Table Limits


Assuming three modulo x, y & z then the total size of the internal hashed table would be:

x+x*y+x*y*z

By default

3 + 3 * 7 + 3 * 7 * 19, or 423             This is the number that cannot exceed 485, above.

And the number of level 0 external frames would be

3 * 7 *19, or 399.

Hashing
Hashing is simply a method of deriving a seemingly random number from the record key and applying a modulo to the result. A given key will
always produce the same hash value for a given hash method.

A good hash method will:

l Produce very different hash values for similar keys


l Produce a wide range of hash values
l Produce a flat distribution of hash values

To hash into a modulo 3 table for key FRED where the hash value is 11, the remainder when divided by 3 is 2 so the key FRED hashes to the
last group (0-2). In reality the hash value is a very large number.

File Size
A newly-created, empty file will only contain 4096 bytes. A populated and subsequently empty file may contain much more as the following
data frames are not released until a resize:

l Overflow frames.
l External level 0 frames.
l Internal data frames.

JBase - User Guide - Release R15.000 - Page 86 of 629


This is the same process as is followed with any hashed file.

The maximum file size is determined by the addressing limits of 64 bits.

Writing Data
When the first item is added to the file it is hashed on the first internal modulo (default 3) a data frame is added to the file to contain the new
item making a minimum file size of 8192.

The internal hash table consists of up to three ascending prime numbers, default 3, 7 & 19, that configure the initial search path for the record
id. The key is hashed on the first modulo (3) which contains one of:

0                The group is empty, nothing has ever been written to it.

< 4096         An internal pointer to the next modulo (7)

>= 4096        A pointer to a data frame.

In the case of an empty file the value will be 0, so for a write a data frame is allocated and the pointer changed to reference the frame – on the
first record this will always reference 4096 as this was end of file at file creation.

When an internally referenced data frame overflows, all items within it are rehashed on the next modulo and reallocated to their respective
newly allocated data frames. The original data frame is released to the free list.

JBase - User Guide - Release R15.000 - Page 87 of 629


Deleting Data
When data is deleted the data frame may become empty in which case it may be released to the free list and its parent pointer zeroed. A ref-
erence count in the parent frame is decremented which may in turn cause the pointer frame to be empty, to be released to the free list.

A frame is not released, even if empty, if:

1. It is  pointed to by the file header (i.e. external level zero or an internal data frame).
2. It is less than the MINSPLIT value for the file.

As records are deleted, a pointer frame may point to a few frames the data within which would fit in the pointer frame if it was changed to a
data frame. No check is made for this eventuality as checking all the parent pointer’s children is too expensive. Instead a pointer frame is only
released when the last pointer is zeroed.

Internal Pointers
Given a set of internal modulo the internal pointer values are known at file creation, i.e. a given pointer can have only one internal value, rather
than zero or a data frame reference. In the diagram below the level 0 pointers can only point to their respective level 1 tables, hence the internal
pointer values are predictable.

JBase - User Guide - Release R15.000 - Page 88 of 629


Similarly all 21 level 1 pointers each have a respective level 2, modulo 19 table.

Once an internal pointer has been set to an internal table position the pointer will never lose this value throughout the lifetime of the file. When
the top level internal pointer (default modulo 19) is allocated a  data frame, this will never change throughout the lifetime of the file. If the data
frame overflows it becomes a pointer frame, but this doesn’t require a change in the internal hash table.

When the internal hash tables are full, no values will ever change, so processes  opening the file do not require a re-read of the file header. This
avoids expensive locking. Sparsely populated files may require much more locking as pointers to data frames are liable to become internal point-
ers.

External Frames
Data or pointer frames referenced at the highest internal pointer level of internal hash table or beyond are referred to as external frames.
Internal data frames (they cannot be pointer frames) are relatively few, by default a maximum of 24 can ever exist. Once a frame is allocated to
the highest level internal reference, it will never be released, even on a CLEAR-FILE.

When an external data frame overflows it is rehashed on the modulo appropriate to the external level, in the same way as internal modulo but
the data frame itself  becomes a pointer frame.

In internal or external hashing, if no item hashes to a pointer then no data frame is allocated.

JBase - User Guide - Release R15.000 - Page 89 of 629


External Hashing
If an external data frame overflows, it will split the records according to the modulo and hashing method for the split level. The hash method
needs to change as if only one external modulo is used then all items that hashed to group n at level m would also hash to group n at level m +
1 causing a further split, etc.

Given the set of parameters at file creation it is always possible to predict the path a given item id will take, what cannot be predicted is the
level within the path (internal and external) at which the item will exist.

jrscan
As the internal structure of Resilient files differs from hashed files so much a new utility, jrscan has been written to complement the func-
tionality that jcheck provides to other hashed files, although without the destructive recovery.

The syntax, from jrscan –h, is:

Usage: jrscan {options} filepath

Options:

l -a - Show header values.


l -b - Bitmap scan - verify frame use.
l -h - Display help.
l -i - Display the internal hash table.
l -k - Display record keys
l -ln - Set split level to n.

JBase - User Guide - Release R15.000 - Page 90 of 629


l -on - Offset n (0xnnnn hex, 0nnnn oct or nnnn dec).
l -v - Verbose output.

-a Provides a comprehensive breakdown of the header values in the file header.

-b Uses a bitmap to map the file structure ensuring all frames are referenced once and once only.

-h Help text.

-i Display the internal hash table. Used for support purposes.

-k Display record keys. Used for support purposes.

-ln Set split level to n. Used for support purposes.

-on Set internal file offset to n. Used for support purposes.

-v Verbose output. Display offsets, keys and block sizes.

JBase - User Guide - Release R15.000 - Page 91 of 629


Recovery

Database recovery can take several forms depending on the nature of the state of the system.

For a simple power failure or an O/S reboot while the database is being updated, the database should be recoverable by a system warmstart pro-
cedure. This warmstart will use Transaction Journal(s) which are being used by the database(s) to roll forward all complete database trans-
actions from the last checkpoint to the point of failure.

For a media failure whereby the database itself has been lost then this data must be restored from the last backup taken. If the Online Backup
facility has been used, then the restore process can restore the system to a consistent state. Providing the Transaction Journal has not been
lost during this media failure (journal is held on other media), then is should be possible to recover the system to a position just prior to the
media failure. Again the system will be recovered to a consistent state.

For disaster recovery situations where there is likely to be some lengthy/permanent disruption to the live site, it may be possible to continue
operations at a site which has been functioning as a hot-standby site.

JBase - User Guide - Release R15.000 - Page 92 of 629


Warmstart Recovery

DB-WARMSTART
This command is restricted to administrative use only and there are no optional parameters.

This command will inspect the “databases-defined” file and determine whether each of the databases defined therein require to be recovered fol-
lowing a power failure.  Any defined database which has a status of “active” will cause a recovery process to begin – all databases which have
been stopped will be in a consistent state. The recovery process takes the form of a roll-forward of the database from the Transaction Journal
logfiles defined for that database. The format of the recovery command is :

jlogdup –V input set=eldest start=CHECKPOINT output set=database

As this command suggests checkpointing must be configured for this to be effective. A checkpoint is defined as a point in time when all trans-
actions have completed in their entirety – no partial transactional updates are pending. When checkpointing is used, the database is deemed to
be in a “consistent” state at the point at which the “checkpoint” record appears in the Transaction Journal. This being the case recovery is only
required from the last checkpoint time. No user intervention is required in determining this time. At the completion of the recovery all trans-
actions which were completed in their entirety will be applied to the database and transactions which are incomplete (i.e. no TRANSEND or
TRANSABORT entry found in the log files for this transaction), will be discarded.

Syntax

DB-WARMSTART

For all computer types, the “WARMSTART” utility should be run with the JBASE_DATABASE set to “warmstart”. It is not possible to predict
which database is active (all may not be including “default”. As the access to jBASE databases is determined very early on in the life of a pro-
cess, the “databases_ defined” file cannot be interrogated to find a usable database. The database “warmstart” also must be started. This will
not be added to the “databases_defined” and as such is a special case. This ensures that recovery is not attempted for this dummy database.
Once the recovery of all required databases has completed, the dummy database entry is deleted. Note: As DB-START is only possible by a sys-
tem administrator, misuse of the dummy database is prevented.

JBase - User Guide - Release R15.000 - Page 93 of 629


Media/Computer Failure and Recovery

This recovery mechanism relies on three components within jBASE: transaction boundaries; Transaction Journaling and jBackup. Firstly, data-
base integrity cannot be guaranteed unless transaction boundaries are utilised. By encapsulating related database updates within transaction
boundaries, jBASE will either perform all of the related updates or none. Transaction boundaries are identified by the TRANSTART,
TRANSEND and TRANSABORT instructions. Transaction Journaling is required in order to provide a chronologically-

Saving and Restoring the System


Regular, usually daily, backups are essential to the good housekeeping of any system. There are two mechanisms for performing backups.

You can use existing UNIX commands, such as ‘tar’ or ‘cpio’ (or Windows Backup), which work well, but should not be run while a jBASE
application is updating files.  ‘Tar’ and ‘cpio’ and Backup  perform a binary dump of the file data, and do not obey any locks, which may have
been set to indicate that an update is in progress. In addition, these saves can be limited because they cannot be restored correctly on a sys-
tem, which has a different architecture to the original system.

The preferred mechanism is to use the jbackup and jrestore jBASE utilities. The jbackup program will back up normal UNIX/Windows data
files and directories as well as jBASE data files, and will respect any locks set by jBASE applications. Bear in mind though that if you choose to
run jbackup concurrently with other active online jBASE applications, your saved files will not be corrupt, but the continuity of any data saved
from an active system cannot be guaranteed. (We shall see later that an Online Backup facility is available which overcomes this caveat.)

jbackup - jBASE Backup Utility


jbackup  provides fast on-line backup facilities, which can be used to check file integrity.

jbackup -Option {Inputlist}

Where inputlist is a file containing a list of files, default stdin

Option Explanation

-bn Set number of write buffers to n

-c Dump control files such as indexes as binary files

-f Device Save to device file, default stdout

-l Link files to be saved as separate UNIX or hash files

-mn Maximum data capacity of media in Mb, default 100 Mb

-pn Set priority, nice value of parent process

-s Save summary of statistics to UNIX/NT file

-v Verbose mode

-L file Save from List file

-B Force blocksize to 128k. Default 16k

-Cn Force blocksize to n bytes, rounded to nearest k

-F Use fixed block device. Use for qic tapes (nt only)

-N Suppress compression if supported by device (NT only)

-S Statfile Save statistics of all saved objects in jBASE, file Statfile. The dictionary for this file is
JBCRELEASEDIR/jbackup] D.

JBase - User Guide - Release R15.000 - Page 94 of 629


-O Override no backup file option, save all

-R Suppress automatic rewind at end of backup

-P Print and scan files only, no save

-V Verbose dot mode, displays a “.” For each file

-A Acc Save from user name home directory (UNIX only)

-W indicates an online backup is to be performed

Examples:

Reads all records, files and directories under the /home directory provided by the find selection and displays each file or directory name as it is
encountered. This option can be used to verify the integrity of the selected files and directories.

Reads all files and directories listed in the UNIX file FILELIST and writes the formatted data blocks to the floppy disk device, displaying each
file or directory name as it is encountered. The jbackup utility will prompt for the next disk if the amount of data produced exceeds the spe-
cified media size of one Mbyte.

Reads all files and directories in home directory of user-id “jBASE” Generates statistics information and outputs blocks to stdout, which is
redirected to /dev/null. The statistics information is then listed using the jbackup dictionary definitions to calculate the file space used.

Reads all records, files and directories under the C:\users\home directory provided by the find selection and displays each file or directory
name as it is encountered. This option can be used to verify the integrity of the selected files and directories. This command should be run with
jshell type sh rather than jsh.

jrestore - jBASE Restore Utility


The jBASE jrestore utility uses two processes together with shared memory to provide an efficient mechanism for restoring records, files and
directories saved by the jbackup utility. One process is used to read data blocks from the restore media and the other creates and writes
records, files and directories. This two process approach keeps data movement to a minimum while making good use of any multiprocessing
capabilities provided by your system.

jrestore provides a powerful selective restore capability. Records, files and directories can be selectively restored by specifying relational expres-
sions with one or more of the available options.

jrestore is capable of resynchronisation so that the restore procedure can begin from any position on the restore media. However, note that
this capability can be limited by a lack of positioning options available with the specific restore device. For example, a streaming cartridge tape
cannot be backspaced.

jrestore will continue to restore from the specified device until the end of volume label is detected. You will then be prompted to mount the
next device or you can select an alternative device if required.

 jrestore command
jrestore <options>

options are:

Option Explanation

-a Restore from current media position.

-bn Set number of input buffers to n, default is 8.

-fdev Restore from dev file, default is stdin.

-c“o n” Restore old directory path (o) as new directory path (n).

-d“dir” Restore directories matching regular expression.

JBase - User Guide - Release R15.000 - Page 95 of 629


-h“file” Restore hash files matching regular expression.

-i“key” Restore record keys matching regular expression. Usually used with the ‘h’ option.

-l“lnk” Restore UNIX link files matching regular expression.

-o“o” Restore other UNIX files matching regular expression, e.g. named pipes.

-u“u” Restore regular UNIX files matching regular expression.

-pn Set priority/nice value of parent process, default is 1.

-q Causes the P option to execute in quiet mode.  Only a summary is displayed.

-v Verbose Mode. Display files and directories before they are restored. Output is dir-
ected to stderr.

-Ttype Restore hash files as specified type.

-B Force buffer block size to 128K, defaults to 16K.

-Cn Force block size to n bytes, rounded to nearest 1024 bytes.

-U Update only, existing files or records are not overwritten.

-O Overwrite existing files and records.

-P Print and scan files only, no restore.

-V Verbose dot mode. Display a ‘.’ for each file.

-W Roll forward the database following the restore using the saved logfile data and con-
figuration

-G Roll forward the database using the logfile data and configuration which are already in
use. This will follow the data restore and roll forward specified by the -W option.

jrestore Examples
Reads formatted files and directories from a streaming cartridge device, displaying each file or directory as it is encountered. This option can be
used to verify that the tape does not contain any parity or formatting errors and so can be restored at a later date.

Reads and restores formatted files and directories from a floppy disk device, displaying each file or directory as it is encountered.

Reads formatted files and directories from stdin, which is being supplied by jbackup, modifies all occurrences of path string /home/old to
/home/new and then restores files and directories using modified path string.

Reads formatted files and directories from UNIX file BACKUP, limits restore to any directories whose path name ends in PAYROLL.

Reads formatted files and directories from UNIX file BACKUP, limits restore to any hash files whose path name ends in CUSTOMERS, and
only restores record keys containing.

JBase - User Guide - Release R15.000 - Page 96 of 629


Resilient T24 Configurations

Each configuration which will be described adheres to those goals as identified in the Temenos Technology and Research White Paper - T24
Resilience High Availability in Failover Scenarios and the proposed new Close of Business Procedures as described in the Functional Spe-
cification Changes to Batch Operation for Global Processing Environments

Stand-Alone System – application server and database server on one machine

This should be the minimum standard configuration utilizing Transaction Journaling. The assumptions made here are that

jBASE will be the database (native) server.

Transaction handling will be achieved by the use of TRANSTART, TRANSEND and TRANSABORT programming commands. Transactions
which are not completed in their entirety will be completely “rolled back” by jBASE, when commanded to so do by the TRANSABORT com-
mand. Upon execution of the TRANSEND command all or none of the constituent database updates will be actioned, ensuring database con-
sistency. Any transactional recovery will be achieved through the use of jBASE facilities.

jBASE transaction journaling will be used to record all database updates.

Transaction Journaling has been configured for example, with two logsets:

l /bnk/bnk.jnl/logset1
l /bnk/bnk.jnl/logset2

where: logset1 and logset2 are links to two mounted filesystems each containing the corresponding transaction log file definitions.

TJ is then activated by a script similar to start_ tj, which activates transaction logging and also the backup of the transaction logs to tape
(/dev/rmt/0 in this case).

The Transaction journal is copied to tape (or other external medium) on a continuous basis by means of the jlogdup facility.

A backup of the database (using the backup_ jbase script) is initiated prior to the execution of Close of Business procedures. Logsets are
“switched” following the successful completion of backups.

When a backup is required, a script, based on “backup_jbase” is run. Actions performed by this script are:

JBase - User Guide - Release R15.000 - Page 97 of 629


Disk-based transaction log file entries are still allowed to be dumped to tape. When there is no Transaction Logging activity, then all out-
standing transactions have either been logged to tape or rolled back. Note: The time allowed for transactions to complete is dependent on
application design. The end of dump activity can be checked by use of the jlogstatus command

The transaction log file duplication process to tape is stopped.

The logging tape is replaced by a new tape for the backup.

The command:

will dump all data to tape below /bnk. As all the transaction log data (bnk.jnl) data has already been dumped to tape prior to the backup, the
exclusion of this directory would seem appropriate, by configuring the data thus:

Directory Description

bnk Main directory, object code etc.

bnk.run Initial logon point

bnk.data Data files

bnk.dict File dictionaries

bnk.help On-line help files

bnk.jnl Transaction Journal

where bnk.jnl is not under the bnk directory structure.

Note: The use of the “-c” option will allow for the dumping of index files to avoid having to rebuild indexes on a restore process.

Note: Alternative backup mechanisms may be employed.

Once the backup has completed and verified, a new tape for tape logging replaces the last backup tape.

The logsets are switched, ready for any database updates.

Transaction logging to disk is re-enabled.

Database updates are enabled.

System Protection and Benefits


The use of Transaction Journaling in this configuration allows for the recovery of transactions up to the point of failure. This configuration
provides assistance to the administrator in identifying those transactions which have not been written to tape prior to system failure. The tape
(set) contains a sequential history of database updates since the last backup.

System Recovery Preparations


The administrator must ensure that a skeleton system save is made available. This skeleton system should contain:

The operating system and configuration (device assignments, user login information, etc).

A licensed copy of jBASE configured as ready-to-run)

This skeleton system must be kept up to date. Any changes to the operating system or jBASE configurations must be reflected in this skeleton
system as a standard procedure; any such changes triggering the production of a new skeleton system.

JBase - User Guide - Release R15.000 - Page 98 of 629


System Recovery after Failure
If the operating system and/or jBASE is deemed corrupt or there has been a catastrophic disk failure, resulting in the loss of a disk, then the
system should be reconstructed as a skeleton system as discussed above. The details of this recovery are out of the scope of this document.

Once the system has been brought to an operational state, the database needs to be brought back to a known state. The last backup set pro-
duced is recovered by the recover_jbase script. This not only restores the jBASE database including saved indexes, but also replays all com-
pleted transactions which have been transferred to tape and initiates transaction logging to tape.

If there has been an application/database error which has resulted in the decision  to perform a complete restore of the system, it is clear that if
the error can be identified to have taken place at a particular time, (whether precisely or approximately), then the whole of the transaction log
should not be replayed. Using the “end=timespec” option of jlogdup will cause the transaction log replay to terminate at the specified time
rather than the end of the logset. (See jlogdup section for valid format of timespec). The recover_jbase script will prompt for a time or assume
EOS (i.e. all the transaction log is to be replayed). As the

Warning: If an “end=timespec” parameter has been specified, then the time chosen may cause transactions which began before this time not to
be completed (i.e. rolled back). Additional database updates pertaining to such transactions and bounded by the corresponding TRANSEND
commands may exist on the transaction log file, but will not be executed.

Close of Business Procedures


This configuration, being a jBASE-only solution will allow for on-line backups to be taken prior to Close of Business procedures.

Cluster System – multiple application servers and a single database server

When clustering T24, two (at least) configurations can be utilised:

Multiple application servers with a JBASE database server


With this configuration, jBASE will be the sole database server. Communication between the application server(s) and the database server will
be by using jRFS within jBASE. This allows multiple application servers to have pointers/stubs as file definitions. These pointers/stubs ref-
erence files which exist on the database server. jRFS mechanisms allow for the updating of the database through jRFS server processes from
requests made on the application servers. The implication of this is that each application server has no direct, individual database storage but
shares access to a central (jBASE) database. As there is only one database server, Transaction Journaling facilities will be available, using the
same mechanisms as the Stand-Alone system above.

JBase - User Guide - Release R15.000 - Page 99 of 629


Multiple application servers with a non-jBASE database server
This configuration uses jBASE as a gateway to another DBMS (such as Oracle or DB2).

jBASE will handle any supported relational database connectivity (such as Oracle/DB2 etc.) through the appropriate jEDI driver. Data mapping
will be achieved through the corresponding RDBMS stub file definitions.  The jBASE/RDBMS stub file definitions can exist on one of various
locations:

On the Application Servers – this could (would) potentially create a locking minefield – how to communicate between the Application Servers
the locked state of the database entities.

On the Database Server (1) – Application Servers communicate over NFS mounts to RDBMS stub files defined on the Database Server. The
downside of this approach is that RDBMS client components (at least) have to exist on each of the Application Servers. Also there is a problem
with managing database locks. This can be achieved by inefficient application-level lock mechanisms whereby the locks are held within a central
filesystem and are accessed by all Applications Servers, utilizing OS locks to manage access to the lock table.

On the Database Server (2) – Application servers communicate using a jRFS driver to jRFS servers on the Database Server. The Database Server
contains the RDBMS stub file mappings to the RDBMS, also residing on the Database server. As jRFS operates in a client-server relationship,
there are no locks taken directly by any process within the Application Servers, but are taken by the jRFS server processes, on their behalf, run-
ning on the Database Server. As all the jRFS server processes run under control (for locking purposes) of a single jBASE server, there is no
issue with locking between these processes. There is also likely to be a cost advantage over Database Server (1) approach, because no RDBMS
components need to exist on the Application Servers.

Transaction management (i.e. the use of TRANSTART, TRANSEND and TRANSABORT programming commands) within the Application Serv-
ers is handled within jBASE as for the Stand-Alone system.

Hot Standby database server

Hot Standby with a jBASE database server

The Hot Standby configuration using jBASE as the database server has the same attributes as previously described in the Cluster Systems with
the exception that all database updates to jBASE are duplicated to a separate server (or remote in the case of disaster recovery). The database
duplication process, achieved by the jlogdup facility, would normally be an operation in addition to dumping the transaction log data to a local
tape device.

JBase - User Guide - Release R15.000 - Page 100 of 629


Operation of the Hot Standby configuration
Transaction handling will be achieved by the use of TRANSTART, TRANSEND and TRANSABORT programming commands.

jBASE transaction journaling will be used to record all database updates.

The Transaction journal is copied to tape (or other external medium) on a continuous basis by means of the jlogdup facility.

A backup of the database (using jbackup) is initiated each night at 12:01 am (for example) to the tape deck /dev/rmt/0 (for example).

Logsets should be switched automatically following the backup.

A jlogdup process will be initiated on the database server which will, in tandem with a corresponding jlogdup server process on the standby
server, transfer all transaction updates from the transaction log on the live cluster to the transaction log on the standby server.

Another jlogdup process on the standby server will take the updates from the previously transferred log files and update the database on the
standby server.

Hot Standby with a non-jBASE database server


If a backend RDBMS is configured then Hot Standby/disaster recovery is handled by the RDBMS; jBASE Transaction Logging is not used as
the recovery mechanisms are handled by the RDBMS.  The RDBMS recovery mechanisms are outside of the scope of this document.

Transaction handling will be achieved by the use of TRANSTART, TRANSEND and TRANSABORT programming commands. The updates con-
tained within a transaction are cached until a TRANSABORT or TRANSEND command is executed for that transaction. No RDBMS activity
takes place when the TRANSABORT command is executed, whereas the TRANSEND can result in many RDBMS interactions before success or
failure is detected. The application code within T24 is unaware of the underlying backend database.

Scripts/Commands
Note 1: For Windows, each of these names should have a file type of “.cmd”

Note 2:  The following are replacements for the variable LD_LIBRARY_PATH depending on platform.

LIBPATH - Pathnames of system libraries (AIX only)

SHLIB_PATH - Pathnames of system libraries (HPUX only)

warmstart
The content of the script/command for a Linux computer is:

JBCRELEASEDIR=/usr/jbc

JBCGLOBALDIR=/usr/jbc

PATH=$PATH:$JBCRELEASEDIR/bin

LD_LIBRARY_PATH=$JBCRELEASEDIR/lib

export JBCRELEASEDIR JBCGLOBALDIR

DB-START -nwarmstart

DB-WARMSTART

DB-REMOVE -nwarmstart

This script should be invoked from the  /etc/rc.d/rc.local script thus :

For Windows computers the content of the batch file “WARMSTART.cmd” is :

l set JBCRELEASEDIR=c:\jbase4.1
l set JBCGLOBALDIR=%JBCDATADIR%
l SET JBCOBJECTLIST=%JBCRELEASEDIR%\lib
l SET JEDIFILEPATH=%HOME%;.

JBase - User Guide - Release R15.000 - Page 101 of 629


l SET PATH=%PATH%;%JBCRELEASEDIR%\bin
l SET JBASE_DATABASE=warmstart
l DB-START -nwarmstart
l DB-WARMSTART
l DB-REMOVE -nwarmstart

This command should be appended to the HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\Run hive

setup_tj
For Unix/Linux:

l #! /bin/ksh
l export JBCRELEASEDIR=/data/reldir/jbcdevelopment
l export JBCGLOBALDIR=/data/reldir/jbcdevelopment
l export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH
l jlogadmin -cf1,1,[logset1 directory]/logfile1
l jlogadmin -cf1,2,[logset1 directory]/logfile2
l jlogadmin -cf2,1,[logset2 directory]/logfile1
l jlogadmin -cf2,2,[logset2 directory]/logfile2
l jlogadmin -cf3,1,[logset3 directory]/logfile3
l jlogadmin -cf3,2,[logset3 directory]/logfile3

For Windows:

l @ECHO OFF
l set JBCRELEASEDIR=c:\jbase4.1
l set JBCGLOBALDIR=c:\jbase4.1
l set PATH=%JBCRELEASEDIR%\bin;%PATH%
l jlogadmin -cf1,1,[logset1 directory]\logfile1
l jlogadmin -cf1,2,[logset1 directory]\logfile2
l jlogadmin -cf2,1,[logset2 directory]\logfile1
l jlogadmin -cf2,2,[logset2 directory]\logfile2
l jlogadmin -cf3,1,[logset3 directory]\logfile3
l jlogadmin -cf3,2,[logset3 directory]\logfile3

For example; jlogadmin –c –f1,1,E:\logset1\logfile1   will create a logfile called logfile1 in directory E:\logset1. Note: The folder logset1 must
exist.

start_tj
For Unix/Linux: 

l #! /bin/ksh
l export JBCRELEASEDIR=/data/ reldir /jbcdevelopment
l export JBCGLOBALDIR=/data/ reldir /jbcdevelopment
l export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH
l jlogadmin -l 1 -a Active

JBase - User Guide - Release R15.000 - Page 102 of 629


l echo `date` > $JBCRELEASEDIR/logs/jlogdup_to_tape_start
l jlogdup input set=current terminate=wait output set=serial device=[Device Spec] &

For Windows:

l @ECHO OFF
l set JBCRELEASEDIR=c:\jbase4.1
l set JBCGLOBALDIR=c:\jbase4.1
l set PATH=%JBCRELEASEDIR%\bin;%PATH%
l jlogadmin -l 1 -a Active
l echo %date% > %JBCRELEASEDIR%\logs%\ jlogdup_to_tape_start
l jlogdup input set=current terminate=wait output set=serial device=[Device Spec]

stop_tj
For Unix/Linux:

l #! /bin/bash
l export JBCRELEASEDIR=/data/reldir/jbcdevelopment
l export JBCGLOBALDIR=/data/reldir/jbcdevelopment
l export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH
l jlogadmin –a Off

For Windows:

l @ECHO OFF
l set JBCRELEASEDIR=c:\jbase4.1
l set JBCGLOBALDIR=c:\jbase4.1
l set PATH=%JBCRELEASEDIR%\bin;%PATH%
l jlogadmin –a Off

start_jlogdup
For Unix/Linux:

l #! /bin/ksh
l export JBCRELEASEDIR=/data/ reldir /jbcdevelopment
l export JBCGLOBALDIR=/data/ reldir /jbcdevelopment
l export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH
l echo `date` > $JBCRELEASEDIR/logs/jlogdup_to_tape_start
l jlogdup input set=current terminate=wait output set=serial device=[Device Spec]&

For Windows:

l @ECHO OFF
l set JBCRELEASEDIR=c:\jbase4.1
l set JBCGLOBALDIR=c:\jbase4.1
l set PATH=%JBCRELEASEDIR%\bin;%PATH%
l date /t > %JBCRELEASEDIR%\config\jlogdup_to_tape_start
l jlogdup input set=current terminate=wait output set=serial device=[Device Spec]&

For example: jlogdup input set=current terminate=wait output set=serial device=c:\temp\logdupop

JBase - User Guide - Release R15.000 - Page 103 of 629


stop_jlogdup
For Unix/Linux:

l #! /bin/ksh
l export JBCRELEASEDIR=/data/ reldir /jbcdevelopment
l export JBCGLOBALDIR=/data/ reldir /jbcdevelopment
l export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH
l jlogadmin -k* > discard

For Windows:

l @ECHO OFF
l set JBCRELEASEDIR=c:\jbase4.1
l set JBCGLOBALDIR=c:\jbase4.1
l set PATH=%JBCRELEASEDIR%\bin;%PATH%
l jlogadmin -k* > discard

backup_jbase
For Unix/Linux:

#! /bin/ksh

export JBCRELEASEDIR=/data/reldir/jbcdevelopment

export JBCGLOBALDIR=/data/reldir/jbcdevelopment

export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH

typeset -u TAPEOUT

typeset -u REPLY

typeset -u BACKUPOK

set TAPEOUT = N

print -n "Are you backing up the logfiles to tape? (Y/N) "

while [ "$TAPEOUT" != Y -a "$TAPEOUT" != N ]

do

read TAPEOUT

done

if [ "$TAPEOUT" != N ]

then

print -n Has all logging to tape finished - press any key when it has

read REPLY

jlogadmin -k* >discard

print Logging to tape terminated

fi

if [ "$TAPEOUT" = Y ]

then

print Please remove the tape for logging and replace with the backup tape

JBase - User Guide - Release R15.000 - Page 104 of 629


set REPLY = N

while [ "$REPLY" != Y ]

do

print -n Enter Y to continue

read REPLY

done

fi

set BACKUPOK = N

while [ "$BACKUPOK" != Y ]

do

print Backup Started `date`

find /data/globus/jbbase13207/mbdemo.data -print | jbackup -v -c -f [Device Spec] -s /tmp/jbstart

print  Waiting for tape to rewind

sleep 5

print Verify Started `date`:

jrestore -f [Device Spec] -P

print Verify Finished `date`

print -n "Backup successful <Y/N>"

read BACKUPOK

done

jlogadmin -l next -a Active

print logsets switched and logging to disk restarted

if [ "$TAPEOUT" = Y ]

then

print Mount a new tape for logging

print Enter any key to resume logging to tape

read INPUT

print `date` > $JBCRELEASEDIR/logs/jlogdup_to_tape_start

jlogdup input set=current terminate=wait output set=serial device=[Device Spec] &

print Logging to tape restarted

fi

For Windows:

@ECHO OFF

set JBCRELEASEDIR=c:\jbase4.1

set JBCGLOBALDIR=c:\jbase4.1

set PATH=%JBCRELEASEDIR%\bin;%PATH%

0001 OPEN "","C:\jbase4.1\config" TO CONFIG_LOGS ELSE STOP 201

0002 CRT "Are you backing up the logfiles to tape? (Y/N)"

JBase - User Guide - Release R15.000 - Page 105 of 629


0003 INPUT tapeout

0004 tapeout = UPCASE(tapeout)

0005 IF tapeout = "Y"  THEN

0006     PRINT "Has all logging to tape finished - press any key when it has":

0007     INPUT reply

0008     EXECUTE "jlogadmin -k*" CAPTURING RESULT

0009     CRT RESULT

0010     CRT "Please remove the tape for logging and replace with the backup tape"

0011     CRT "Enter any key to continue":

0012     INPUT REPLY

0013 END

0014 backupok = "N"

0015 LOOP WHILE backupok # "Y"

0016     EXECUTE  "jfind C:\jdata4.1\bp -print" CAPTURING ALLFILES

0017     DATA ALLFILES

0018     EXECUTE "jbackup -c -f C:\temp\backup_file"

0019     *EXECUTE  "jfind C:\jdata4.1\bp -echo | jbackup -v -c -f [Device Spec] -s C:\tmp\jbstart"

0020     CRT "Waiting for tape to rewind"

0021     SLEEP 5

0022     CRT "echo Verify Started ": TIME() "MTS"

0023     EXECUTE "jrestore -P -f c:\temp\backup_file"

0024     *EXECUTE "jrestore -f [Device Spec] -P"

0025     CRT "Verify Finished at ": TIME() "MTS"

0026    CRT "Was the backup successful <Y/N>"

0027     CLEARDATA

0028     INPUT backupok

0029     backupok = UPCASE(backupok)

0030 REPEAT

0031 EXECUTE "jlogadmin -l next -a Active"

0032 CRT "Logsets switched and logging to disk restarted"

0033 IF tapeout = "Y" THEN

0034     CRT "Mount a new tape for logging"

0035     CRT "Enter any key to resume logging to tape "

0036     INPUT input

0037     STARTTIM =  TIME()

0038     WRITE STARTTIM ON CONFIG_LOGS,"jlogdup_to_tape_start" ON ERROR DEBUG

0039     EXECUTE "jlogdup input set=current terminate=wait output set=serial device=C:\temp\logoutput"

0040     * EXECUTE "jlogdup input set=current terminate=wait output set=serial device=[Device Spec]"

JBase - User Guide - Release R15.000 - Page 106 of 629


0041     CRT "Logging to tape restarted"

0042 END

recover_jbase
For Unix/Linux:

#!/bin/ksh

if [ -z "$1" ]

then

echo "\nWhat is the nature of the recovery :-\n"

PS3="Option :"

select Sel in "Full Restore Required" "Tape Logging Failure"

do break; done

if [ -z "$REPLY" ]

then

exit

fi

else

REPLY=$1

fi

if [ $REPLY = 1 ]

then

echo Put the first backup tape in the tape drive

echo -n Enter any key when ready

read DONE

jrestore -f  [Device Spec] -N

echo -n Is a Transaction Log tape available ?

read REPLY

if  [ $REPLY = "y" ]

then

echo Put the first  log  tape in the tape drive

echo -n Enter any key when ready

read DONE

echo -n "Enter a time to terminate the duplication process (or RETURN for all logs)"

read  ENDTIME

if [-z $ENDTIME ]

then

jlogdup input  set=serial device=[Device Spec] backup terminate=EOS output set=database

else

JBase - User Guide - Release R15.000 - Page 107 of 629


jlogdup input  set=serial device=[Device Spec] end=$ENDTIME output set=database

fi

fi

else

echo Put a new tape in the tape drive

echo -n Enter any key when ready

read DONE

jlogdup input set=current start=$JBCRELEASEDIR/logs/jlogdup_to_tape_start terminate=wait output set=serial device=[Device Spec] &

fi

For Windows:

 IF NOT (SENTENCE(1)) THEN

REPLY = ""

LOOP WHILE REPLY NE "F" AND REPLY NE "T"

CRT "What is the nature of the recovery? F=Full recovery required, T=Tape logging failure"

INPUT REPLY

REPEAT

 END

 IF REPLY = "F" THEN

CRT "Put the first backup tape in the tape drive"

CRT "Enter any key when ready ":

INPUT DONE

EXECUTE "jrestore -f C:\temp\backup_file"

* EXECUTE "jrestore -f [Device Spec]"

CRT "Is a Transaction Log tape available ? ":

INPUT REPLY

CRT "Put the first  log  tape in the tape drive"

CRT "Enter any key when ready ":

INPUT DONE

CRT "Enter a time to terminate the duplication process (or RETURN for all logs) ":

INPUT ENDTIME

IF NOT (ENDTIME) THEN

EXECUTE "jlogdup input  set=serial device=C:\temp\logoutput terminate=EOS output set=database"

*    EXECUTE "jlogdup input  set=serial device=[Device Spec] backup terminate=EOS output set=database"

END ELSE

EXECUTE "jlogdup input  set=serial device=C:\temp\logoutput end=ENDTIME output set=database"

* EXECUTE "jlogdup input  set=serial device=[Device Spec] end=$ENDTIME output set=database"

END

 END ELSE

JBase - User Guide - Release R15.000 - Page 108 of 629


CRT "Put a new tape in the tape drive"

CRT "Enter any key when ready ":

INPUT DONE

IF GETENV("JBCRELEASEDIR", RELDIR) = "" THEN STOP

EXECUTE "jlogdup input set=current start=RELDIR:"config":JBUILD_ DELIM_ CH:jlogdup_ to_ tape_ start terminate=wait output set-
t=serial device=[Device Spec]"

 END

JBase - User Guide - Release R15.000 - Page 109 of 629


Run Time

The jBASE run time provides support for the application during execution time providing support functions such as lock arbitration, update
journaling and spooling facilities. 

JBase - User Guide - Release R15.000 - Page 110 of 629


File Handling

l Overview
l CLEAR-FILE
l COPY
l CREATE-FILE
l DELETE
l DELETE-FILE
l JBACKUP
l JRESTORE
l JGREP
l JRCHMOD
l JRF
l JRSCAN
l JSTAT
l SEL-RESTORE
l DISTRIBUTED FILES
l PART FILES
l Creating DISTRIBUTED FILES
l Attaching and Detaching PART FILES
l Partioning Algorithm
l CREATE-DISTRIB
l DELETE-DISTRIB
l LIST-DISTRIB
l VERIFY-DISTRIB
l Distributed File Considerations
l Distributed Files Example

JBase - User Guide - Release R15.000 - Page 111 of 629


Overview

jBASE can handle data in a variety of forms. Support is built in for access to

Hashed data files (the default)

l Distributed files
l Resilient files
l Directories
l Sequential files

Data held in other forms can be accessed through the use of an appropriate driver. Regardless of where the data is stored, the access mech-
anisms are the same.

JBase - User Guide - Release R15.000 - Page 112 of 629


CLEAR-FILE

The CLEAR-FILE command allows the user to clear all records from the dictionary file or data section files.

COMMAND SYNTAX
CLEAR-FILE {DICT|DATA} filename{,section}

SYNTAX ELEMENTS
filename is the name the file to be cleared. The file type must be one of the supported jBASE file types. If the file type supports separate dic-
tionary and data files, the DICT or DATA keywords may be used to clear either the dictionary file or the data file. DATA is assumed by default.

section is the name of the multiple data section to be cleared.

EXAMPLES
CLEAR-FILE File1

or

CLEAR-FILE DATA File1

Clears the data portion of file File1.

CLEAR-FILE DICT File1

Clears the dictionary portion of file File1 (File1]D).

JBase - User Guide - Release R15.000 - Page 113 of 629


COPY

The COPY command copies specific or selected records from a specified file to the terminal, printer or another file.

COMMAND SYNTAX
COPY {DICT} filename{,section} {recordlist} {(options}

PROMPT
TO: {({DICT} filename{,section}} {targetrecordlist}

SYNTAX ELEMENTS
filename is the name of a valid file. The file type must be one of the supported jBASE file types. The DICT keyword can be used to specify that
the record or records should be copied from or to a dictionary file.

section is the name of the multiple data section, if specified.

recordlist is the list of records (keys) to be copied. If recordlist is omitted, the active SELECT list is used, if present.

Options
A Force ASCII mode. Newline becomes field mark and vice versa.

B Force binary mode. No newline conversion.

D Delete source record after it is copied.

F Output new page between keys. Used with T or P option.

I Suppress or display record keys as records are copied. Emulation dependant.

N Suppress pagination. Used with T or P option.

O Overwrite record in target file, if it already exists.

P Direct record contents to the spooler.

T Direct record contents to the terminal.

S Suppress line numbers, for T or P option.

X Hexadecimal display, for T or P option.

targetrecordlist is a list of record keys to copy the records to - effectively renaming the copied records. Each key in the targetrecordlist is
applied in sequence to the copied records. If targetrecordlist is not specified or contains less keys than there are copied records, the original
record keys will be used.

NOTES
If you enter <RETURN> at the TO: prompt, the records will be copied to the terminal screen or spooler, depending on the options chosen. In
this case, the D(elete) option will have no effect.

EXAMPLE
COPY File1 Record1 (T

Copies Record1 from File1 to the terminal.

JBase - User Guide - Release R15.000 - Page 114 of 629


COPY File1 Record1 (OD

TO:(DICT File2 Record2

Copies Record1 from File1 to dictionary file File2]D overwriting Record2. Once copied, the original Record1 is deleted from File1.

JBase - User Guide - Release R15.000 - Page 115 of 629


CREATE-FILE

The CREATE-FILE command allows the user to create a new file for use within the jBASE system. The command will allow creation of any file
type known to the jEDI libraries - unless the concept of a file is redundant to that target system.

COMMAND SYNTAX
CREATE-FILE {DICT|DATA} filename{,section} {HASHMETHOD=nnn} {TYPE=tname} {PERM=nnn} {LOG=YES|NO} {TRANS=YES|NO}
{BACKUP=YES|NO} {NumBuckets{, BucketMult{, SecSize}}} {NumBuckets{, BucketMult{, SecSize}}}

SYNTAX ELEMENTS
DICT An optional keyword used to specify that the command should create a dictionary file only for
the filename.

DATA An optional keyword used to specify that the command should create a data section file only
for the filename.

filename The name of the file that is to be created.

section The name of a new multiple data section to be created.

HASHMETHOD Used when a hash file is to be created. The numeric parameter nnn specifies the hashing
method to be used when accessing the file. The default method of 2 works very well with all
sorts of key types. However if the record keys will be perfectly uniform numeric keys then
there may be a slight advantage to using method 1 on the file.

TYPE Specifies the type of file to be created. Supported types include

l J3 – files with configurable levels of flushing


l J4 – standard hash files (the default)
l JP – jPLUS files
l UD – Directory files used to access files in the OS

PERM Used to set the permissions of the file in exactly the same manner as the UNIX chmod com-
mand. nnn is an octal number that will be masked by the current umask setting. The default
the value of nnn is 666.

LOG LOG=YES|NO allows the file to be included in or excluded from, the record or transaction log-
ging mechanism, if licensed on your system. The value is set to YES by default.

TRANS TRANS=YES|NO allows the file to be included in or excluded from any transaction bound-
aries that are defined by an executing program. The value is set to YES by default.

BACKUP BACKUP=YES|NO allows the file to be included automatically by the jBASE jbackup utility.
The value is set to YES by default.Options

JBase - User Guide - Release R15.000 - Page 116 of 629


DELETE

The DELETE command deletes specific or selected records from a specified file.

COMMAND SYNTAX
DELETE {DICT} filename{,section} {recordlist}

SYNTAX ELEMENTS
Filename The name of a valid file. The file type must be one of the supported jBASE file types. If the file type
supports separate dictionary and data files

DICT May be used to delete records from the dictionary file.

Section section is the name of the multiple data section if specified

Recordlist The list of record keys to be deleted. If the recordlist is omitted the active SELECT list will be used if
present

EXAMPLE
DELETE File1 Record1

Deletes record Record1 from the file File1.

GET-LIST DeleteList
DELETE File1

Deletes all records from File1 that match the record keys selected by the active select list.

JBase - User Guide - Release R15.000 - Page 117 of 629


DELETE-FILE

The DELETE-FILE command allows the user to delete complete file sets, the dictionary, or the data section of a file.

COMMAND SYNTAX
DELETE-FILE {DICT|DATA} filename{,section}

SYNTAX ELEMENTS
filename Name the file to be deleted. The file type must be one of the supported jBASE file types. If the file type
supports separate dictionary and data files, the DICT or DATA keywords may be used to delete either
the dictionary file or the data file.

section Name of the data section to be deleted. NOTES

NOTES
The command will detect inconsistencies in its use and issue suitable error messages.

Note: Beware of creating a file and then immediately deleting it using the DELETE-FILE command. The DELETE-FILE command will
respect the JEDIFILEPATH variable and if it finds a file of the same name in a directory earlier in the path than the current working dir-
ectory it will delete that file. For this reason it is best to define the JEDIFILEPATH variable as '.' (the current working directory):

EXAMPLE
DELETE-FILE File1

Deletes the complete file set of File1, comprising the dictionary file, default data section and any multiple data sections.

DELETE-FILE File1,Section

Deletes the multiple data file named Section1 from File1.

DELETE-FILE DATA File1

Deletes the default data file named File1.

DELETE-FILE DICT File1

Deletes the dictionary file of File1 (File1]D).

JBase - User Guide - Release R15.000 - Page 118 of 629


JBACKUP

The jbackup utility provides fast on-line backup facilities and can also be used to check file integrity.

COMMAND SYNTAX
jbackup -Option {Inputlist}

Where inputlist is a file containing a list of files, default stdin

OPTIONS
-bn set number of write buffers to n (default is 8, minimum is 1)

-c dump control files such as indexes as binary files

-f Device save to device file, default stdout

-l link files to be saved as separate Unix or hash files

-mn maximum data capacity of media in Mb, default 100 Mb

-pn set priority, nice value of parent process

-s save summary of statistics to Unix file (not available on windows)

-v verbose mode

-L file save from List file

-B force blocksize to 128k. default 16k

-Cn force blocksize to n bytes, rounded to nearest k

-F use fixed block device. Use for QIC tapes (Windows only)

-N suppress compression if supported by device (Windows only)

-S Statfile Save statistics of all saved objects in jBASE file Statfile. The dictionary for this file is JBCRELEASEDIR/jbackup]D.

-O override no backup file option, save all

-R suppress automatic rewind at end of backup

-P print and scan files only, no save

-V verbose dot mode, displays a "." for each file

-A Acc save from user name home directory ( UNIX only )

-E1 will make jbackup pause and give the user an option to quit if it encounters corrupt files

-E2 same as -E1 but will also pause for warnings

NOTES
This command will set the JEDIFILEPATH environment variable to “.” to prevent the backing up of incorrect files.

Use jchmod to change the characteristics of a file. For example,

jchmod -B filename

will cause jbackup to skip 'filename'. Other options of interest are +B, -O and +O.

jbackup creates a file named jbk*PID as a work file when executed. Therefore, jbackup must be run from a directory which has write privileges.
If the file system or directory is not write enabled you will receive the error message ERROR! Cannot open temporary file jbk*PID.tmp, error 2

JBase - User Guide - Release R15.000 - Page 119 of 629


Refer jrestore for more details.

EXAMPLES

Unix
find /home -print | jbackup -P

Reads all records, files and directories under the /home directory provided by the find selection and displays each file or directory name as it is
encountered. This option can be used to verify the integrity of the selected files and directories.

jbackup FILELIST -f /dev/rmt/floppy -m1 -v

Reads all files and directories listed in the UNIX file FILELIST and writes the formatted data blocks to the floppy disk device, displaying each
file or directory name as it is encountered. The jbackup utility will prompt for the next disk if the amount of data produced exceeds the spe-
cified media size of 1 Mbyte.

jbackup -Ajbase -S/usr/jbc/tmp/jbase_stats >/dev/null

LIST /usr/jbc/tmp/jbase_stats USING /usr/jbc/jbackup NAME TOTAL SIZE ID-SUPP

Reads all files and directories in home directory of user-id "jbase". Generates statistics information and outputs blocks to stdout, which is redir-
ected to /dev/null. The statistics information is then listed using the jbackup dictionary definitions to calculate the file space used.

Windows
jfind C:\users\vanessa -print | jbackup -P

Reads all records, files and directories under the C:\users\vanessa directory provided by the jfind selection and displays each file or directory
name as it is encountered. The -P option means that the files are not actually backup (print and scan only). It is useful to verify the integrity of
the selected files and directories. This command should be run with jshelltype sh rather than jsh.

jfind D:\data -print | jbackup -f C:\temp\save20030325 -m10000 -S C:\temp\stats -v

The jfind command outputs the names of all the files and directories under the D:\data directory. This output is passed to the jbackup com-
mand causing it to backup every file that jfind locates. Rather than save to tape, this jbackup command creates a backup file: C:\tem-
p\save20030325. Note that jbackup creates the save2003025 file, but the directory c:\temp must exist before running the command. The -
m10000 option specifies that the maximum amount of data to back up is 10,000MB (or 10GB) rather than the default 100MB. The -S option
causes file statistics to be written to the hashed file stats. This file should exist and be empty prior to commencing the backup. The -v option
causes the name of each file to be displayed as it is backed up. Because of the pipe character used to direct the output of jfind to jbackup, this
command should be run with jshelltype sh rather than jsh.

JBase - User Guide - Release R15.000 - Page 120 of 629


JRESTORE

The jrestore utility provides fast on-line restores from the saves produced by the jbackup utility. The jrestore can be controlled to restore from
any file type on the backup, from single records to multiple directories. The jrestore utility can also be used to verify jbackup saves.

COMMAND SYNTAX
jrestore -Options

OPTIONS
-a restore from current media position

-bn set number of read buffers to n (default is 8, minimum is 1)

-c"old new" restore old directory path as new directory path

-d"DirRE" restore directories matching regular expression

-f Device restore from device file, default stdin

-h"HashRE" restore hash files matching regular expression

-H FileList restore files using only file names from FileList file

-i"ItemRE" restore items matching regular expression

-I ItemList restore items using only item ids from ItemList file

-l"LnkdRE" restore links matching regular expression

-n control info files not restored

-N control info files restored and indexes rebuilt

-o"OfileRE" restore other files matching regular expression

-pn set priority, nice value of parent process

-u"UfileRE" restore normal file matching regular expression

-v verbose mode

-F use fixed block device. Use for QIC tapes

-B force block size to 128k, default 16k

-Cn force block size to n bytes, rounded to nearest k

-P print and scan files only, no restore

-O overwrite existing files and records

-R suppress rewind last reel

-T type restore hash files as specified file type; the original modulo and separation will be retained rather than use the 'resize' parameters.

-U update only does not overwrite existing files or records

-V verbose dot mode, displays a "." for each file

NOTES
When using jrestore ensure that you executing at the standard shell not in jsh otherwise the double quotes and other meta characters will lose
their meaning.

JBase - User Guide - Release R15.000 - Page 121 of 629


Windows Note: When specifying path names the backslash must be escaped with a backslash, otherwise the backslash character is removed.
e.g.

C:\\MyApp\\new

EXAMPLES
jrestore -f /dev/rmt/ctape -P

Reads formatted files and directories from a streaming cartridge device, displaying each file or directory as it is encountered. This option can be
used to verify that the tape does not contain any parity or formatting errors and so can be restored at a later date.

jrestore -f /dev/rmt/floppy -v

Reads and restores formatted files and directories from a floppy disk device, displaying each file or directory as it is encountered.

jbackup -Ajbase | jrestore -c"/home/old /home/new"

Reads formatted files and directories from stdin, which is being supplied by jbackup, modifies all occurrences of path string /home/old to
/home/new and then restores files and directories using modified path string.

jrestore -f BACKUP -d".*PAYROLL$"

Reads formatted files and directories from UNIX file BACKUP, limits restore to any directories whose path name ends in PAYROLL.

jrestore -f BACKUP -h"/CUSTOMERS$" -i".*SMITH.*"

Reads formatted files and directories from UNIX file BACKUP, limits restore to any hash files whose path name ends in CUSTOMERS, and
only restores record ids containing the string SMITH.

JCHMOD
The jchmod command enables you to modify jBASE-specific file attributes such as the resize parameters of a hashed file.

COMMAND SYNTAX
jchmod {+options} {-options} file{ file...}

SYNTAX ELEMENTS
+options

+B Flag the file to be saved by the jbackup utility.

+L Flag the file to be logged to the record or transaction log.

+T Flag updates to be included as part of transaction boundaries.

+R Set the resize parameters. The syntax is the same as for the CREATE-FILE command and includes spaces. The spaces should
{parms} be retained by quoting the string from the shell.

-options

-B Flag the file NOT to be saved by the jbackup utility.

-L Flag the file NOT to be logged to the record or transaction log.

-T Flag updates NOT to be included as part of transaction boundaries.

-R Remove any resize parameters from the file.

-t Tabulate and display statistics of the files. Note this option is exclusive and will cause all other options to be ignored.

file{ file…} A list of all the ‘real’ file names to be processed by the command.

JBase - User Guide - Release R15.000 - Page 122 of 629


NOTES
jchmod will ignore files that are not jBASE supported files, or where options do not apply to certain file types. This allows the command to be
issued against an entire directory without determining which files are valid for the command. A warning message will be issued for any ignored
files.

The ‘real’ file name should be specified to jchmod for dictionary and data sections of a file. The formats DICT file and file,section are not sup-
ported by this command.

JBase - User Guide - Release R15.000 - Page 123 of 629


JGREP

The jgrep utility enables pattern matching of records in one or more jBASE files.

COMMAND SYNTAX
jgrep {options} searchstring file {recordlist...}

SYNTAX ELEMENTS
l searchstring is the string to search for in the file(s). If the string contains spaces, surround it with quotes or use the -I option
described below.
l file is the name of any valid file.
l recordlist is a list of record keys.

Options Explanation

-C Make the search case insensitive. This means that a search string of ‘ABC’ would
match the string ‘abc’.

-I The search string(s) has been omitted from the command line and will be prompted
for before searching the files in the list.

-L List only the record keys that the search string(s) were found in.

-N Do not wait for keyboard input between pages of output.

-P Send all output to current printing queue. (Implies the -N option).

-S Search all subdirectories. If the file specified is a UNIX directory, all the files in the dir-
ectory and its sub-directories will be searched for the searchstring(s).

-r Raw mode. Display record key, line number and occurrences field separated, one line
at a time. Note that this option skips jBC object records located in hash files.

NOTES
Options may be specified after the file or recordlist by preceding the options with a left parenthesis:

jgrep searchstring file recordlist (options

The -S option will cause all records in a hashed file, or all files in a UNIX directory to be searched.

EXAMPLE
jgrep "ABC DE" SALES CUST0001

Searches the record CUST0001 in file SALES for the string ‘ABC DE’.

find . -name "JAC*" -print | xargs jgrep -NS fast

Standard UNIX commands can be used to provide arguments to the jgrep command.

jgrep -ILSN .

Prompts for search strings and then searches the records in all files in the current directory, and all files in any subdirectories. Standard UNIX
commands can be used to provide arguments to the jgrep command. Does not pause at the end of each page of output.

JBase - User Guide - Release R15.000 - Page 124 of 629


JRCHMOD

The jrchmod utility can be used to change the deallocation strategy of a JR file.

COMMAND SYNTAX
jrchmod {options} filename

SYNTAX ELEMENTS
l filename is the JR file to be changed.

Options can be one or more of the following:

Option Explanation

-D Deallocate data frames as they become empty.

-h Help text.

-N Don’t deallocate any frames.

-P Deallocate pointer and data frames as they become empty.

NOTES
The default behaviour of JR files is never to deallocate frames on the assumption they will be reused.

JBase - User Guide - Release R15.000 - Page 125 of 629


JRF

The jrf utility can be used to resize one or more files.

COMMAND SYNTAX
jrf {options} {filename{,section}}

SYNTAX ELEMENTS
l filename is the base name of the file to be resized. The file type must be one of the supported jBASE hash file types.
l section is the name of the data section to be resized.

Options can be one or more of the following:

Option Explanation

-H3 Recreate files as HASH3 (j3) files.

-H4 Recreate files as HASH4 (j4) files.

-H5 Recreate files as jPLUS files

-H6 Recreate files as HASHR (resilient) files

-B Keep original bucket / frame size

-C Change restore specification

-D Allow downsize of file

-E Resize empty files

-F Force a data scan on a resilient file resize

-I Ignore empty files. By default the user will be prompted to resize empty files.

-L Don’t journal the jRF operation

-Mn Override default hash method, set to method n

-R Reporting mode only. The files will not be changed.

-V Verbose mode. Information is printed about each file size as the command progresses.

-V1 Very verbose mode. A jstat is performed on each file and the results printed.

-Sm{,s{,i}} Size to parameters; m – modulo, s – separation, i - ingroupmaxsz

NOTES
Badly sized files can cause severe performance problems. Often, over time internal file sizes become too small for the number of records they
contain.

The jrf utility will resize files listed on the command line, selected via an active SELECT list or all hash files in the current directory. By default
the jrf command will resize all valid hash files in the current directory.

JBase - User Guide - Release R15.000 - Page 126 of 629


Note: This command should only be used on files that are not in use by an application. Although the files cannot be physically corrupted
by jrf, they can be logically corrupted as updates by programs that have already opened the file will be lost.

jrf and Resilient Files


Resilient (JR) files do not by nature require resizing, but when data is freshly imported the order within the internal structure is physically
unordered. A single resize of an unordered JR file to a JR file orders the structure such that a SELECT on the file will be a sequential disk read
from beginning to end, improving performance. This will not affect the speed of direct reads and writes.

JR files will by default take default internal parameters of INTMODS=3,7,19 and EXTMODS=31 and a JR to JR resize will retain whatever para-
meters the original file used. If there is a a particularly unusual hashing pattern jrf can be forced into a ‘sizing’ data scan with the –F option
where various parameters will be tested to attempt to achieve the best data capacity. The – F option would normally only be used on fairly
static files.

JBase - User Guide - Release R15.000 - Page 127 of 629


JRSCAN

The jrscan utility can be used to verify or display the internal structure of Resilient files.

COMMAND SYNTAX
jrscan {options} filename

SYNTAX ELEMENTS
l filename is the base name of the JR file to be scanned..

Options can be one or more of the following:

Option Explanation

-a Show header values.

-b Bitmap scan – verify the internal frame allocation.

-h Display help text.

-i Display the internal hash table.

-ln Assume split level n (diagnostics only).

-m Machine mode display.

-on Offset n (0xnnnn hex, 0nnnn oct or nnnn dec).

-q Quiet mode (no summary)

-S Salvage data to SLVG_ prefixed copy of file (see jcheck –S).

-s Suppress frame count

-t Suppress scan timing

-v Verbose output.

NOTES
This is generally only used for diagnostic purposes.

JBase - User Guide - Release R15.000 - Page 128 of 629


JSTAT

The jstat command analyses a hashed file to provide statistics on the distribution of records and use of the data space.

COMMAND SYNTAX
jstat {options} {filename{,section}}

SYNTAX ELEMENTS
l filename is the base name of the file to be analysed. The file type must be one of the supported jBASE hash file types.
l section is the name of the data section to be analysed.

options are as follows:

Option Explanation

-f Display free space information.

-r Display table entries for each bucket.

-v Displays additional verbose information. When used with the r option displays each record key in the
bucket.

-m Display information in machine readable format.

-dchar Specifies delimiter char to use as a field separator, for machine readable information supplied by the m
option.

The -f option displays additional information relating to the organisation of free space within the file. The information allows a judgement to
made as to how fragmented the file has become.

As records are added to the file, buckets are allocated for secondary space or to extend large groups. As records are deleted, empty buckets are
added to the free space chain associated with the file. When new buckets are required to extend data space for new records, the buckets avail-
able on the free space chain will be used wherever possible. This fills up any ‘holes’ that may have been created in the file. If the file is very
dynamic this process can create fragmentation of the free space and therefore the file. If this becomes excessive, the file can become very large
in relation to the data it contains.

If there are a large number of buckets in the free space chain, in relation to the number of buckets allocated to the file, this may indicate that
the file has become fragmented. Use the jrf utility to remap the file and remove fragmentation.

Two figures regarding freespace are given in the output (see notes). The Total buckets used for free space chain shows how many buckets have
been used within the file to record the free space chain. If this is large, it is a good indication that the file has become fragmented. The Total
unused (freed) buckets shows how many buckets have been created for extra storage space and then given back to the free space chain. If this
is large in relation to the number of buckets in the file, this another indication of file fragmentation.

Bucket Information
The r option displays additional information regarding the efficiency of each bucket in the file. A table will be output showing the number of
bytes allocated, and the number of bytes used, for each group in the file. This can then be used to judge the distribution of the data within file.
You could also extract this information from the output stream using an awk script (or similar) and then perform a statistical analysis of the fig-
ures.

Additional Information
The v or verbose option displays the following additional information:

Restore re-size parameters  Any resize parameters that have been set against the file using the jchmod command.

JBase - User Guide - Release R15.000 - Page 129 of 629


Last Accessed Time and date of the last file access.

Last Modified Latest time and date that the file was modified in any way.

File Size Size of the file in bytes as UNIX sees it.

Inode UNIX inode number for the file.

Device Id UNIX device-id (normally the disc partition).

Backup File Whether the file is backed up by jbackup.

Log File Whether file updates are logged by record or transaction logger.

Trans Rollback Whether file updates should be rolled back if a transaction fails or is aborted.

When the v option is combined with the r option, the key and size of each record in the buckets is also displayed.

Machine Readable Information


The m option displays all the information (excluding -r option) in machine readable format and thus allows resizing and analysing programs to
extract information in a simple way. This option excludes all other options, except the -d option which allows the field delimiter to be changed
to a character other than <TAB> (0x09).

Information from the m option is presented in the following order:

(1) File Type HASH1, HASH2 etc.

(2) #Recs The number of records in the file.

(3) #Rbytes The number of bytes used by the records.

(4) FileLength The length of the UNIX file.

(5) PBuckSz The size of each primary bucket in bytes.

(6) #TBuckets The number of buckets contained in file.

(7) AvgRecSz The average size of each record.

(8) AvgBucketSz The average size of each bucket.

(9) #PBuckets The number of primary buckets.

(10) #SBuckets The number of secondary buckets.

(11) #FBuckets The number of buckets in the free space chain.

(12) FSpace Free space in bytes.

(13) #Ublocks The size of each bucket in UNIX file space blocks.

(14) SBuckSz The size of each secondary bucket in bytes.

NOTES
In its simplest form (jstat filename) the command output will be as follows:

File filename
Type = HASH1 , Hash method = 2 , Created Tue Jul 14 02:58 1992
Buckets = 97 , BucketSize = 512 , SecondaryBucketSize = 512
Record Count = 5 , Record Bytes = 832
Bytes/Record = 166 , Bytes/Bucket = 8

JBase - User Guide - Release R15.000 - Page 130 of 629


Primary file space: Total Buckets = 97 , Total Bytes = 1996
Secondary file space: Total Buckets = 0 , Total Bytes = 0

Most of the fields are self-explanatory, those that are not are explained below:

SecondaryBucketSize is the secondary bucket size of a hashed file as calculated at file creation time by the CREATE-FILE command. It spe-
cifies the record size beyond which space will be allocated outside the hash bucket itself. The hash bucket will instead contain a pointer to the
record.

Primary file space is the primary file space allocation. This shows how the file relates to the originally allocated number of buckets and allows
the effectiveness of the file size to be judged. The total number of buckets should match or be close to the number originally allocated to the
file.

When a record is to be stored in a bucket that does not have enough free space, the bucket is allocated an additional number of primary buck-
ets to accommodate the new record. The number by which the total buckets shown here exceed the original number allocated is the number of
times that this has occurred. If this number is large, you should consider resizing the file. This can be done in two ways:

1. If you have allocated enough buckets to cater for the number of records in the file, increasing the size of each individual bucket should
allow the records to fit into the file better. The new bucket size should be large enough to cater for the average record size shown in
the jstat output.
2. If there are many more records than the number of buckets, you should increase the number of buckets to reflect this. The new num-
ber of buckets should be equal to the number of records divided by the number of average size records that will fit into a single bucket.

If the file is growing in size over time, you should allow for some additional expansion in your calculations. You may find that a combination of
both the above techniques is necessary if the average record size is much greater than the current bucket size and there are many more records
than allocated buckets.

If the records in your file are very large, it is usually more efficient to force all records into secondary file space rather than create a very large
bucket size. In this case, recreate the file with a secondary bucket size of 0.

Secondary file space indicates how much of the file was allocated as pointers to secondary space in the original group. Where possible, this
should only form a small proportion of the file.

In general, the file should be sized slightly larger than its ‘perfect’ size. Unless files are very badly sized, overall performance will only be affected
marginally.

JBase - User Guide - Release R15.000 - Page 131 of 629


SEL-RESTORE

The SEL-RESTORE command restores all or specific records into a jBASE file from an ACCOUNT-SAVE or FILE-SAVE.

COMMAND SYNTAX
SEL-RESTORE targetfilename {recordlist} {(options}

PROMPT
Name of Account on media : sourceaccountname

Name of File on media : sourcefilename

or

Number of File on media : sourcefilenumber

SYNTAX ELEMENTS
sourceaccountname sourceaccountname is the name of the account on the media where the source file
resides.

sourcefilename sourcefilename is the name of the file on the media in which the source records reside.

sourcefilenumber sourcefilenumber is the number of the file on the media in which the source records
reside. Used with the N option.

targetfilename targetfilename is the name of the file to which the records are to be restored.

recordlist recordlist is a list of record keys to be restored.

options are as follows:

Option Explanation

-A Media is already positioned in the section containing the account where the source file is located.

-C Restore all records from the current media position.

-F Display file names as the media is searched for the source file.

-I Display record keys as they are restored.

-N Prompt for source file number.

-O Overwrite records which already exist in the target file.

-S Suppress the ‘records already exist’ messages

NOTES
The command prompts for the name of source account and file held on the media, unless the N option (restore by file number) has been used,
in which case you will be prompted for the number of the source file on the media.

Before execution, any tape device should have been opened with the T-ATT command.

JBase - User Guide - Release R15.000 - Page 132 of 629


EXAMPLES
SEL-RESTORE NEWCODES * (I

Name of Account on media :PAYROLL

Name of File on media :TAXCODES

Restore all records from the file TAXCODES in account PAYROLL into the file NEWCODES. The record key will be displayed as each record is
restored.

SEL-RESTORE NEWCODES SINGLE (N

Number of File on media :22

Restore record SINGLE from file number 22 into the file NEWCODES

JBase - User Guide - Release R15.000 - Page 133 of 629


DISTRIBUTED FILES

A Distributed file  is a collection of existing files used primarily for the purpose of organizing data into functional groups. Each file within the
collection is called a part file. A distributed file can contain up to 254 part files. The method for determining in which part file a record belongs
is called the  partition algorithm.

As a simple example, suppose your database consists of records which span 42 regions and you elect to distribute your data so that each part
file contains all records for a specific region. With distributed files you would be able to process any one of the region part files independently
of the others, or you would be able to process all 42 region part files collectively (i.e. as one database containing the records from all 42
regions).

Distributed files can also be used when the size of a file exceeds the size limit for the operating system (typically 2 gigabytes). This effectively
permits file sizes to reach 254 times the maximum file size your operating system allows.

JBase - User Guide - Release R15.000 - Page 134 of 629


PART FILES

The components of a distributed file collection are called part files.

Part files can have any name and can be any file type except a distributed file.

Part files can exist anywhere on the network, accessible via the JEDIFILEPATH environment variable, Q-pointers or F-pointers.

Each part file is assigned a part number when it is attached to a distributed file. The part number must be a positive integer in the range of 1
through 254 inclusive. This part number is an integral element as it is used by the partition algorithm to determine which part file the record
belongs.

Part numbers do not have to be sequential nor do they have to be continuous. It is quite valid, for example, to have 4 part files numbered 52,
66, 149 and 242.

A part file can belong to more than one distributed file although this imposes two restrictions:

1. The part file must always have the same part number for each distributed file to which it belongs.
2. All distributed files to which a part file belongs must use the same partition logic. In other words, when a record is written to the
common part file, the partition algorithm for each distributed file must resolve the record's location in the same manner. This is only
applicable when the distributed file uses the user-defined partition method.

The number of part files and the partition algorithm can be varied at any time throughout the life of the distributed file. Be aware that if the par-
tition algorithm changes such that records that were normally written to one part file, using the original partition algorithm, might to be writ-
ten to another part file using the new partition algorithm. This could lead to unwanted duplication.

Another problem that can occur is the wrong file is accessed through the distributed file stub (i.e. the file to which the part files are attached to
create the distributed file set; see Creating Distributed Files). Be aware that part files are resolved in the same manner as any other file in
jBASE. For example, suppose two files exist with the same filename where one is resolved via an F-pointer (in $JEDFILENAME_MD) and the
another is resolved via $JEDIFILEPATH, and that the one in $JEDIFILEPATH is our actual part file. What will happen is the actual part file
will never be found because the file pointed to by the F-pointer will be found first, as indicated by the jshow -f command. To alleviate this prob-
lem, it is best to attach the files using a full explicit filepath (see here for further details on attaching/detaching part files).

JBase - User Guide - Release R15.000 - Page 135 of 629


Creating DISTRIBUTED FILES

A distributed file is created using the  CREATE-FILE command with the qualifier TYPE=DISTRIB. This will create two files, a dictionary which
is a Hash4 (currently fixed at mod3) and the distributed file stub. If desired, the dictionary can be resized using the jrf utility. For example, the
following command creates a distributed file called DISTREGION:

l jsh DEMO ~ -->CREATE-FILE DISTREGION TYPE=DISTRIB


l [ 417 ] File DISTREGION]D created , type = J4
l [ 417 ] File DISTREGION created , type = DISTRIB

The file partition table is empty at this point, and the partition algorithm is set to the default system partition method with a delimiter of ‘-‘ 
(that is; all record IDs must be of the form "PartNumber-recordID"). These aspects of the distributed file can be changed with the create-dis-
trib command.

JBase - User Guide - Release R15.000 - Page 136 of 629


Attaching and Detaching PART FILES

Files are attached to a distributed file using the  create-distrib command with the -a option. A file must already exist before it can be attached
to a distributed file.

In the following example an existing file, DISTCUST.SOUTH, is attached to the distributed file DISTCUST as part number 4:

jsh DEMO ~ --> create-distrib -a DISTCUST 4 DISTCUST.SOUTH

Part file 'DISTCUST.SOUTH', Part number 4 added

Note: We can also attach a file using a full explicit filepath as in "create-distrib -a c:\home\myaccount\DISTCUST 4 DISTCUST.SOUTH"

This method of attaching a distributed file is preferred to ensure the proper part file is resolved through the partition algorithm. See Part Files
for further details.

A part file can be detached from a distributed file using the create-distrib command with the -d option. The synonym DELETE-DISTRIB can
also be used for this purpose. For example, to detach the DISTCUST.SOUTH part file:

jsh DEMO ~ --> create-distrib -d DISTCUST 4

Part file 'DISTCUST.SOUTH', Part number 4 deleted

JBase - User Guide - Release R15.000 - Page 137 of 629


Partioning Algorithm

Each distributed file uses a partition algorithm to determine in which part file a record belongs. The partition algorithm is specified by using
the create-distrib command. All part files belonging to a distributed file use the same partition algorithm.

There are two methods for defining the partition algorithm, the system defined method and the user-defined method. The partition algorithm
uses the record ID (or part of the record ID) to distribute the record to the appropriate part file.

System Partition Algorithm


When a distributed file is created it is automatically set to use the system partition algorithm. The create-distrib command is used to set the
partition algorithm. When using the system partition method, jBASE assumes that the record ID will be in the form:

<PartNumber> <Delimiter> <RecordID>

Where:

PartNumber is an integer which determines the part file to which the record is written.

Delimiter can be any character except a system delimiter (AM, VM, SVM). The default delimiter is a dash (-).

RecordID is the actual item-ID of the record. In a ‘hashed’ file type, this determines the group to which the record is written.

The following example sets (or changes) the distributed file DISTREGION to use the system partition algorithm. A dash (-) will be used as the
delimiter between the part number and the record ID:

create-distrib -pSYSTEM,- DISTREGION

User-defined Partition Algorithm


The user-defined method provides the greatest flexibility when the need to determine which part file a record belongs is not based on an integer
value (although it could be used for that purpose as well). The user-defined method is implemented by writing a jBC subroutine which determ-
ines the part number, and then setting the distributed file to use the subroutine as the partition algorithm. As an example, a distributed file
called DISTCUST has 5 part files and the first character of each ID determines which part file the record belongs.

We will use the following jBC subroutine as the partition algorithm:

SUBROUTINE DistCustSub (Reserved, Key, PartNo)

EQU Otherwise TO 1

* Extract the first character from the Key

FirstChar = Key[1,1]

* Now determine the PartNo based on FirstChar

BEGIN CASE

CASE FirstChar = "N"; * North

PartNo = 1

CASE FirstChar = "E"; * East

PartNo = 2

CASE FirstChar = "W"; * West

PartNo = 3

CASE FirstChar = "S"; * South

PartNo = 4

CASE Otherwise ; * Invalid condition; isolate for later review

JBase - User Guide - Release R15.000 - Page 138 of 629


PartNo = 99

END CASE

RETURN

Compile and catalog the subroutine. Ensure that the subroutine is accessible via the JBCOBJECTLIST environment variable.

The subroutine is called each time a record is read from or written to the DISTCUST distributed file. The subroutine must support 3 argu-
ments:

Argument Description

Reservced This parameter is reserved for future enhancements and should not be altered
within the context of the subroutine.

Key This is the record ID. It must be constructed in the application program prior
to READing or WRITEing the record from/to the distributed file. Do not alter
this argument, use it only as a source.

PartNo This must be assigned by the subroutine and must return a valid part number.

You will notice that the part numbers consist of 1, 2, 3, 4 and 99. This illustrates an important feature. It is not a requirement that the part
numbers be sequential or continuous. This could be used to allow additional part files to be added to the distributed file collection without the
necessity of renumbering.

Take special care when writing this subroutine to account for all possibilities. If for any reason the PartNo cannot be determined you will
receive either a READ_ERROR or WRITE_ERROR at the point of failure. Here is one such example where there are 11 part files. The part num-
ber is determined based on the last character of the key, the last character is assumed to be numeric but, if it's not, it will be placed in the 11th
part file:

SUBROUTINE distsub(reserved, key, partno)

lastchar = key[-1,1]

IF NUM(lastchar) THEN

partno = lastchar

IF partno = 0 THEN partno = 10

END ELSE

partno = 11

END

RETURN

Can you spot the error?

The fatal flaw is if the subroutine ever encounters an item-id of 'null'. A null item-id is considered numeric, hence partno will be set to 'null'. A
better way to code this would be:

SUBROUTINE distsub(reserved, key, partno)

lastchar = key[-1,1]

IF lastchar >= 0 AND lastchar <= 9 THEN

partno = lastchar

IF partno = 0 THEN partno = 10

END ELSE

partno = 11

END

JBase - User Guide - Release R15.000 - Page 139 of 629


RETURN

This subroutine takes the 'explicit' approach and does not make assumptions about what form the data will be in.

To set (or change) the distributed file to use the user-defined partition algorithm, use the create-distrib command. For example, to set the
DISTCUST distributed file to use the DistCustSub subroutine:

create-distrib -pUSER,DistCustSub DISTCUST

When compared to the system partition algorithm, the user-defined partition method incurs a small performance penalty when calling the jBC
subroutine. The exact cost of this is highly dependent on how easily the part number is resolved within the subroutine.

JBase - User Guide - Release R15.000 - Page 140 of 629


CREATE-DISTRIB

The CREATE-DISTRIB command is a used to:

1. Maintain the parts of a distributed file


2. Set or change the partition algorithm
3. List or verify the component part files and the partition algorithm

The CREATE-DISTRIB command accepts a variety of options which determines its function as the following table illustrates:

Function Syntax Alternate Syntax

Add a part file CREATE- DISTRIB - a FileName CREATE- DISTRIB FileName


PartNo PartFile PartNo PartFile

Delete a part file CREATE-DISTRIB -d FileName DELETE-DISTRIB Filename


PartNo PartNo

List all part files CREATE-DISTRIB -l FileName LIST-DISTRIB FileName

Verify the existence of the Part Files CREATE-DISTRIB -v FileName VERIFY-DISTRIB FileName

Set (or change) to the System Par- CREATE-DISTRIB -pSYSTEM{,De-


tition Algorithm lim} FileName

Set (or change) to a User-defined Par- CREATE- DISTRIB -


tition Algorithm pUSER,Subroutine FileName

Syntax Elements
Element Description

Filename The name of the distributed file

PartNo An integer from 1 through 254 inclusive which associates the Part file to the Distributed File

PartFile The name of the part file

Delim A single character used to separate the Part Number from the record ID

Subroutine The name of the user defined subroutine

Other options are:

-f      Force Mode

-V     Verbose

Examples
CREATE-DISTRIB -a INVOICES 24 INVOICES.MAR1999

Attaches the file INVOICES.MAR1999 as the 24th part file to the INVOICES distributed file.

CREATE-DISTRIB INVOICES 24 INVOICES.MAR1999

Same as the previous example. Note that the -a is assumed in the absence of any options.

CREATE-DISTRIB -pSYSTEM,| DISTCUST

JBase - User Guide - Release R15.000 - Page 141 of 629


Sets (or changes) the partition method to the SYSTEM partition algorithm for the DISTCUST distributed file. A vertical bar "|" will be used as
the delimiter to separate the part number from the record ID.

CREATE-DISTRIB -pUSER,DistSub DISTCUST

Sets (or changes) the DISTCUST distributed file to use the user-defined subroutine, DistSub, as the partition algorithm.

CREATE-DISTRIB -d MEDICAL.CLAIMS 149

Detaches (disassociates) the 149th part file from the MEDICAL.CLAIMS distributed file.

CREATE-DISTRIB -l CONVENTIONS

Lists the component part files of the CONVENTIONS distributed file. Also lists the partition algorithm.

CREATE-DISTRIB -v CONVENTIONS

Verifies the existence of the component part files belonging to the CONVENTIONS distributed file. Also confirms the partition method. If the
distributed file uses the user-defined partition method this also verifies that the subroutine can be executed.

JBase - User Guide - Release R15.000 - Page 142 of 629


DELETE-DISTRIB

The DELETE-DISTRIB command detaches (de-references) a component part file from a distributed file.

Syntax
DELETE-DISTRIB FileName PartNumber

Syntax Elements
Element Description

FileName The name of the Distributed File

PartNumber An integer from 1 through 254 inclusive which was used to associate the Part File to the Dis-
tributed File

Notes
If the user-defined partition method is used, you should ensure that the subroutine used for the partition algorithm does access the de-ref-
erenced file.

If the system partition method is used, you should ensure that no keys are created which can read from or write to the de-referenced file.

Example
DELETE-DISTRIB INVENTORY 42

Detaches (de-references) the 42nd part file from the distributed file INVENTORY.

JBase - User Guide - Release R15.000 - Page 143 of 629


LIST-DISTRIB

The LIST-DISTRIB command displays all partition information pertaining to a distributed file.

Syntax
LIST-DISTRIB FileName

Syntax Elements
FileName is the name of a Distributed File.

Notes
The VERIFY-DISTRIB command is much more useful as this not only displays the same information as LIST-DISTRIB, it also verifies the exist-
ence of the component part files. If the distributed file uses the user-defined partition method, VERIFY-DISTRIB also verifies that the sub-
routine is executable.

Example
LIST-DISTRIB INVENTORY

JBase - User Guide - Release R15.000 - Page 144 of 629


VERIFY-DISTRIB

The VERIFY-DISTRIB command verifies the existence of the component part files of a distributed file. If the distributed file uses the user-
defined partition method, VERIFY-DISTRIB also verifies that the subroutine is executable.

Syntax
VERIFY-DISTRIB FileName

Syntax Elements
FileName is the name of a Distributed File.

Example
VERIFY-DISTRIB INVENTORY

JBase - User Guide - Release R15.000 - Page 145 of 629


Distributed File Considerations

Although jBASE does not restrict you from directly populating part files, records should always be written through the distributed file stub. Be
aware that if a record is placed in the wrong part file, and that record is subsequently handled through the  partition algorithm, it will be placed
in the part file according to the partition algorithms own relentless logic. This will result in the same record appearing in two part files.

Once part files are populated, changing the logic of the partition algorithm (or changing the partition method), could have disastrous results. If
it is necessary to do this you must pass each record through the new partition algorithm so that it is placed in the proper part file. You must
also remember to delete each record from its original location.

A distributed files is opened in the usual way. For example, the following statement opens a distributed file called DISTCUST:

OPEN "DISTCUST" TO DISTCUST_FILE ELSE ABORT 201,"DISTCUST"

By default, when a distributed file is opened, all component part files are opened at the same time. You can defer the opening of all part files by
setting the JEDI_DISTRIB_DEFOPEN environment variable.

On versions of jBASE prior to 3.3.9, if a record ID resolved to a partition (part file) that did not exist, the process would be trapped to the
jBASE debugger with an "Error 22" error message. This behavior has been changed (see patch number PN3_30268) such that a READ from a
non-existent partition will take the ELSE clause and a WRITE will be trapped with an 'Error 22' unless the WRITE is supplied with the ON
ERROR clause.

If you delete a part file then you must also DELETE-DISTRIB to remove the reference from the distributed file stub. You must also modify any
user-defined partitioning algorithm. This is detailed in the distributed file example.

Distributed files support secondary indexes and triggers at both the distributed file level and the part file level.

JBase - User Guide - Release R15.000 - Page 146 of 629


Distributed Files Example

In this comprehensive example, we create a distributed file called DISTCUST using a user defined partition algorithm and attaching five part
files.

l Create the distributed file stub. This is the file to which all part files will be attached:

jsh DEMO ~ -->CREATE-FILE DISTCUST TYPE=DISTRIB


[ 417 ] File DISTCUST]D created , type = J4
[ 417 ] File DISTCUST created , type = DISTRIB

l Define the partition algorithm. If the distributed file uses the default system partition method, this step would not be necessary unless
you wanted to change the delimiter separating the part number from the record ID. For this example we will use the user-defined
method by assigning the subroutine DistCustSub as the partition algorithm:

jsh DEMO ~ --> create-distrib –pUSER,DistCustSub DISTCUST

l Create the five files to be attached as part files. If the files already exist then this step can be omitted:

jsh DEMO ~ -->CREATE-FILE DISTCUST.NORTH 1 101


[ 417 ] File DISTCUST.NORTH]D created , type = J4
[ 417 ] File DISTCUST.NORTH created , type = J4

jsh DEMO ~ -->CREATE-FILE DISTCUST.EAST 1 101


[ 417 ] File DISTCUST.EAST]D created , type = J4
[ 417 ] File DISTCUST.EAST created , type = J4

jsh DEMO ~ -->CREATE-FILE DISTCUST.WEST 1 101


[ 417 ] File DISTCUST.WEST]D created , type = J4
[ 417 ] File DISTCUST.WEST created , type = J4

jsh DEMO ~ -->CREATE-FILE DISTCUST.SOUTH 1 101


[ 417 ] File DISTCUST.SOUTH]D created , type = J4
[ 417 ] File DISTCUST.SOUTH created , type = J4

jsh DEMO ~ -->CREATE-FILE DISTCUST.ERRORS 1 41


[ 417 ] File DISTCUST.ERRORS]D created , type = J4
[ 417 ] File DISTCUST.ERRORS created , type = J4

Attach the five files to the distributed file:

jsh DEMO ~ -->create-distrib -a DISTCUST 1 DISTCUST.NORTH


Part file 'DISTCUST.NORTH', Part number 1 added

jsh DEMO ~ -->create-distrib -a DISTCUST 2 DISTCUST.EAST


Part file 'DISTCUST.EAST', Part number 2 added

jsh DEMO ~ -->create-distrib -a DISTCUST 3 DISTCUST.WEST


Part file 'DISTCUST.WEST', Part number 3 added

jsh DEMO ~ -->create-distrib -a DISTCUST 4 DISTCUST.SOUTH


Part file 'DISTCUST.SOUTH', Part number 4 added

jsh DEMO ~ -->create-distrib -a DISTCUST 99 DISTCUST.ERRORS


Part file 'DISTCUST.ERRORS', Part number 99 added

l Now, let’s list the part files we have just added.

jsh DEMO ~ -->LIST-DISTRIB DISTCUST -or- create-distrib -l DISTCUST


Partitioning Algorithm is USER Subroutine 'DistCustSub'
Part file 'DISTCUST.NORTH', part number 1
Part file 'DISTCUST.EAST', part number 2
Part file 'DISTCUST.WEST', part number 3
Part file 'DISTCUST.SOUTH', part number 4
Part file 'DISTCUST.ERRORS',part number 99

JBase - User Guide - Release R15.000 - Page 147 of 629


l The distributed file system is now complete. At this point, the DistCustSub subroutine is called each time a record is written to or
read from the DISTCUST file.
l Let’s say, for example, that we find that the DISTCUST.ERRORS part file is no longer needed. The actions we must take to remove this
file from the distributed file are:
l Detach the part file from the distributed file:

DELETE-DISTRIB DISTCUST 99
-or-
create-distrib -d DISTCUST 99

l Modify the user-defined partition subroutine DistCustSub by removing the lines which allocate records to part number 99. Recompile
and catalog.

Optional: Delete the DISTCUST.ERRORS file.


DELETE-FILE DISTCUST.ERRORS

JBase - User Guide - Release R15.000 - Page 148 of 629


jBASE Data Provider

l what is jDP?
l NAV UTIL
l jBASE Dictionary Configurator
l jDP and Subvalues

JBase - User Guide - Release R15.000 - Page 149 of 629


What is jDP?

jDP is the jBASE driver for the attunity connect software, this provides an interface for the attunity software to access jBASE data files.

Using attunity, any products adhering to the ODBC, OLE DB, JDBC or ADO standards  can retrieve data from the jEDI interface (directly from
the jBASE database)

Its key features are as follows:

l Allows connectivity to jBASE files via, ODBC \ ADO \ OLDB \ XML type technologies
l Allows applications (front end) to use SQL (Standard Query Languages) syntax
l Standard jBASE files, (back End) need no modification
l Multi-values, Sub-values are supported, and can be grouped together as associated sets.
l Attunity is available on all supported jBASE platforms except iSeries and zSeries.

Overview of available modes


JDP supports three distinct modes of providing access to files:

l Mode 1 - All visible files mode


l Mode 2 - TableFile mode
l Mode 3 - Catalog mode

Mode 1
This is the default mode and allows access to all the files, a user running the jDP driver can open files that:

Can be opened without specifying a path

i.e. are in the user's MD,HOME Dir or JEDIFILEPATH.

Have filenames that are valid SQL table names and have dictionaries.

This mode is useful for ad hoc queries, or for users using shrink-wrapped client software

Mode 2
This mode restricts the view of database files to only those specified in a ‘TABLEFILE’. (a TABLEFILE is a hash file, which contains an item for
each data file you want to make ‘visible’).

When configured this will override Mode 1 file searches

This method allows access to be restricted to a nominated set of files by using a special TABLEFILE.

Mode 3
A ‘Catalogue’ described simply as a ‘Database’ -a collection of tables that hold data and belong to the database – the database acting as a logical
boundary. Unlike the other two methods of accessing the data through jDP, this method allows a good security and permissions strategy to be
set up on all the individual files in the database, thus allowing various users access to only specified data.

For the catalogue to maintain a list of users, schemas, tables and permissions, a catalogue directory is set up to hold ‘system files’. These sys-
tem files hold all the needed information that to administer the catalogue.

Within a catalogue, it is possible to create ‘Schemas’: described as workspaces where users can place\attach their tables. If no Schemas are
used, the catalogue will use the public schema (this is the default schema). Schemas are used to hold files for individual users (e.g., Bob) or a
logical group of users (e.g. SalesTeam). Each individual schema must have its own working directory where it stores its tables.

When referencing a table in a catalogue, the full explicit reference would be:

JBase - User Guide - Release R15.000 - Page 150 of 629


CatalogName:SchemaName.TableName

Example Catalogue:

Database \ Catalogue name :NutsAndBoltsPlc

Contains four schemas: NutsAndBoltsPlc:Public

NutsAndBoltsPlc:SalesTeam

NutsAndBoltsPlc:AdminStaff

NutsAndBoltsPlc:TheMD

With in the SalesTeam schema you may find the following tables:

NutsAndBoltsPlc:SalesTeam.SalesPersonnel

NutsAndBoltsPlc:SalesTeam.Customers

NutsAndBoltsPlc.SalesTeam.SalesOutstanding

NutsAndBoltsPlc.SalesTeam.SalesMade

Getting Started

What should be installed by default


By default a full and working version of jDP should be installed into

$JBASERELEASEDIR/jdp (UNIX)

%JBASERELEASEDIR%\jdp (WINDOWS)

when you install 4.1.

Within the jdp directory there should be all that is needed to run the jDP demo, however if you have not installed jBASE into its default loc-
ation,

C:\jbase4\4.1     (Windows)

/opt/jbase4/4.1   (UNIX)

there may be some additional scripts to be updated…

What environment variables are needed?


In order for jDP to function correctly you need to ensure that both  jBASE and jDP are configured correctly,  

jDP requires the following :-

On UNIX system
$NAVROOT

It should point to the location where jDP has been installed (default /opt/jbase4/4.1/jdp )

$PATH

Should contain $NAVROOT/bin

$LD_LIBRARY_PATH / $LIBPATH / $SHLIBPATH ( depending on system )

Should contain $NAVROOT/lib, as well as any additional subroutines that are needed by your dictionaries.

On WINDOWS system
%NAVROOT%

JBase - User Guide - Release R15.000 - Page 151 of 629


Should point to the location where jDP has been installed (default C:\jBASE4\4.1\jDP )

%PATH%

Should contain %NAVROOT%\bin

%JBCOBJECTLIST%

Should contain the location of any additional subroutines that are needed by your dictionary’s

How do I start the irpcd demon?


On both UNIX and windows systems if you are having problems starting the irpcd demon there should be a description of the last error in one
of the log files in $NAVROOT/tmp.

Generally most common errors are down to the environment not being set correctly, a good test is to open a “jshell” using the same envir-
onment that you are using for jDP and see if you can list your files.

On Windows systems use “services” in start >> settings >> control panel >> administrative tools >> Services

On UNIX systems you can use the irpcd.ctl script in $NAVROOT/bin

As root in $NAVROOT/bin.

./irpcd.ctl start

Description of scripts & files


On WINDOWS system if you have not installed jBASE to its default location,  or on UNIX systems if you are not using a symbolic link to
/usr/jbc,  you will have to amend to following scripts :-

UNIX
nav_sever.ksh                   Sets up the environment when the server is started

site_nav_login.sh               Gets ran for each client session.

WINDOWS
nav_login.bat Gets ran for each client session.

These scripts are needed to setup the environment for jDP when it first launches a client or server, don’t forget that jDP will need to see the
same sort of things that jBASE does.

For example you may use subroutines from within your dictionaries or using a different MD for jDP users, in both these example’s jDP will fail
if you have not setup your jBASE environment variables in the relevant script.

These scripts can be found in $NAVROOT/bin, and should have a working example that points to the default jBASE/jDP locations.

NOTE: In the $NAVROOT/def directory there should be:

addon.def This file is needed to tell the Attunity driver how to connect to jDP.

license.pak These are the default demo licence supplied by Attunity.

license.txt

Upgrading the jDP Environment


The installation procedure of jDP gives you the option to upgrade all elements of your existing jDP system. If you decline this automatic com-
prehensive upgrade, you can later use the supplied upgrade utility to upgrade selected elements of your existing jDP system.

The upgrade utility transfers existing elements of your jDP configuration into object store, jDPs new internal storage mechanism. This utility
transfers into object store the following elements in your jDP system:

l jDP metadata
l User profile information specified in the jDP security file

JBase - User Guide - Release R15.000 - Page 152 of 629


l Stored query specifications (for both procedures and views)
l The results of all nav_util upgrade operations are written to a log residing in either the default location (\tmp under NAVROOT) or the
directory specified in the CTL_TRACE_DIR parameter in the jDP environment file.

The ADDON file


The ADDON file is used for the following:

l When connecting to a data source using the ODBC driver on a non-Windows platform.
l When using the data connector and user defined data types SDK. For details see jDP Open Data Connectivity and the Developer SDK.

JBase - User Guide - Release R15.000 - Page 153 of 629


NAV UTIL

What is NAV_UTIL
NAV_UTIL is a collection of Attunity utilities. The utilities include troubleshooting utilities and metadata utilities. All of the utilities run from
NAV_UTIL. NAV_UTIL can be used for any thing from creating a datasource, running a SQL query or even checking on the status of any run-
ning demons.

Example of commands
The following are examples of useful commands, for a more detailed description please read the Attunity documentation.

Adding a new datasource


NAV_UTIL UPD_DS DEMO jDP jDP

Generating metadata
NAV_UTIL GEN_ARRAY_TABLES DEMO * (For all tables)

NAV_UTIL UPDATE DEMO * (For all tables)

Or 

NAV_UTIL GEN_ARRAY_TABLES DEMO JCUSTOMERS ( single file )

NAV_UTIL UPDATE DEMO JCUSTOMERS ( single file )

Adding a remote machine to a client


NAV_UTIL EDIT MACHINE

Now put an entry in the remoteMachines section

<remoteMachines name='NAV'>

<remoteMachine name='10_48_3_102' address='10.48.3.102'/>

</remoteMachines>

Next add an entry on the client 

NAV_UTIL UPD_DS DEMO REMOTE jDP 10_48_3_102'

Checking the Status of the Daemon


NAV_UTIL check irpcdstat(daemon [, username, password])

Viewing what datasources are available


NAV_UTIL VIEW MACHINE

Executing a SQL Query


NAV_UTIL EXECUTE command.sql

Where command.sql is a text file containing a valid SQL query

Listing Machines that Have an Active Daemon


NAV_UTIL CHECK NETWORK

JBase - User Guide - Release R15.000 - Page 154 of 629


Executing SQL
You can write and execute SQL in the NavSQL environment, as follows:

On-the-fly: Write a sql statement and end it with a semi-colon. Press Enter to execute the statement.

If the SQL contains data from more than one data source, use a colon (:) to identify the data source (that is, datasource_name:Table_name).

From a file: Enter the full name of a file that contains sql, prefixed by @. Press Enter to execute the sql contained in the file. For example:

NavSQL> @C:\sql\sql-query.sql;

will execute the sql contained in the file sql-query.sql.

MVS platforms: Use single quotes (‘) around the filename.

For example, @’.NAVROOT.TMP.SQL1’.

You can access the NavSQL environment and run a file immediately by entering the following command:

nav_util execute data_source file

where data_source is the name of the data source as defined in the binding file and file is the name of the SQL file.

If you want to run all the queries in the file without the overhead of displaying query information on the screen for each query, enter the fol-
lowing command:

nav_util execute data_source -quiet file

In this case, only queries that fail cause information to be displayed to the screen during the run. A message is displayed after all the queries
have been run, stating the number of queries that succeeded and the number that failed.

From within a transaction: Enter the command begin-transaction (optionally with either read-only or write permission) to start a transaction
where you can commit a number of sql statements together. Use commit to update the data sources with any changes or rollback if you decide
that you do not want to accept the changes.

Setting up jDP for each supported mode


In the introduction to this document we mentioned that jDP can be ran in 3 different modes, the following are typical examples of each mode,

Note: $NAVROOT is the path to where jDP has been installed

$JBCRELEASEDIR is the path to where jBASE has been installed

$JEDIFILEPATH is a search path for jBASE to locate files...

$HOME is the location of you data account,

All of the above should be setup before you start…

Standard datasource
This example shows how to use the standard jBASE environment with jDP, in our sample account we have 3 files

File Dict Record position Description

ORDERS KEY 0 order ID

ITEMID1 foreign key to item details

CUSTID 2 foreign key, customer details

ITEMS ITEMID0 ID of this item

DESC 1 Description of item

CUSTOMER CUSTID 0 Customer ID

JBase - User Guide - Release R15.000 - Page 155 of 629


NAME 1 Name of the customer

ADDR 2 customer's address

CUSTOMERS F Pointer to CUSTOMER

The account is held in the directory

WINDOWS: C:\Sample

UNIX: /home/Sample

It also has its own MD, but this is just to demonstrate that it is actually can be used,  create a file pointer called CUSTOMERS.

l Create the sample tables and dictionaries, and then populate them with some meaningful data.
l Adding a datasource.

You will need to let both the client and server know what type of datasource you are creating, which can be done by using one of the following:

l “Attunity Configuration Manager”, this is a GUI interface installed with the windows version of Attunity, it also allows you to configure
remote servers, (UNIX and WINDOWS)
l “nav_util”
l nav_util is a multi-functional utility supplied by attunity, it allows jDP to setup and maintain datasources, and it can also execute quer-
ies.

To add a datasource via nav_util execute the following from the server.

l nav_util UPD_DS SAMPLE jDP jDP

You can view existing bindings with:-

l nav_util view bindings

For more information please read the Attunity documentation.

l Setting up the environment variables for a client…

When a client connects the attunity driver needs to be able to see where the jBASE account is. This is done by using the following script.

WINDOWS: nav_login.bat

UNIX:                 site_nav_login.sh

WINDOWS
Using jed / notepad edit %NAVROOT%\bin\ nav_login.bat

jed %NAVROOT%\bin\ nav_login.bat

File C:\jbase4\4.1\jDP\bin\ , Record 'nav_login.bat' Insert 17:01:52

Command->

001 @echo off

002 SET PATH="C:\jbase4\4.1\jDP\BIN";%PATH%

003 SET NAVROOT=C:\jbase4\4.1\jDP

-------------------------------- End Of Record --------------------------------

Add the following lines to let jBASE know where things are:

004 SET JEDIFILEPATH=C:\Sample;.

005 SET JEDIFILENAME_MD=c:\Sample\MD

006 SET HOME=c:\Sample

JBase - User Guide - Release R15.000 - Page 156 of 629


UNIX
jed $NAVROOT/bin/site_nav_login.sh

001 #

002 # Modify Attunity 3.2 environment for jBASE 3.x

003 #…

035 # Make sure Attunity can see our demo data files

036 JEDIFILEPATH=/usr/jbc/jdp/demo

037 export JEDIFILEPATH

038

039 #

040 # Any additional site specific changes should follow

041 ######################################################################

Add the following lines to let jBASE know where things are..

036 JEDIFILEPATH=/home/Sample

037 export JEDIFILEPATH

038 JEDIFILENAME_MD=/home/Sample

039 export JEDIFILENAME_MD

040 HOME=/home

041 export HOME

On  the client machines you also need to add a reference to the remote datasource,  this can be done via the GUI or by executing the following
command :

nav_util UPD_DS REMOTE <<datasource>>

EXAMPLE
nav_util UPD_DS REMOTE SAMPLE

Creating a link between the attunity driver and the jBASE files.

If you are using a file that contains multivalues you will need to configure jDP so that the jDP driver treats the multivalued columns as tables,
physically they are still stored as multivalues in the jBASE files, jDP simply creates an internal virtual table that the jDP driver can use.

This is achieved by using the “nav_util” utility,

The general; syntax is as follows…

nav_util  gen_array_table <<datasource>> <<tablename>>

EXAMPLE
nav_util gen_array_table SAMPLE CLIENT

nav_util gen_array_table SAMPLE *

You can list all data sources with the following command :-

nav_util view datasources *

The file viewer will vary depending on whether you are running on windows or UNIX in this example we are not using multi-values so all tables
should be usable via ODBC without any problems.

For further information see your Attunity documentation.

JBase - User Guide - Release R15.000 - Page 157 of 629


TABLEFILE datasource
This example shows how to use a TABLEFILE datasource with jDP,

We can use the files that where created for the previous example:

File Dict Record position Description

ORDERS KEY 0 order ID

ITEMID1 foreign key to item details

CUSTID 2 foreign key, customer details

ITEMS ITEMID0 ID of this item

DESC 1 Description of item

CUSTOMER CUSTID 0 Customer ID

NAME 1 Name of the customer

ADDR 2 customer's address

The account is held in the directory

WINDOWS:  C:\Sample

UNIX: /home/Sample

We also need to create a jBASE H4 file called TABLEFILE, this file will hold reference to the above files. Each entry in a TABLEFILE is very sim-
ilar to having an F Pointer in your “MD”

Create a directory to hold the file,

WINDOWS:  C:\TSample

UNIX: /home/TSample

In the above directory create a jBASE file called TABLEFILE

l Creating a link to the sample tables and dictionaries,

If you are using a UNIX system, <<ACCOUNT>> will be /home/sample, WINDOWS c:\Sample.

jed TABLEFILE TORDERS

001: <<ACCOUNT>>\ORDERS

002: <<ACCOUNT>>\ORDERS]D

jed TABLEFILE TITEMS

001: <<ACCOUNT>>\ITEMS

002: <<ACCOUNT>>\ITEMS]D

jed TABLEFILE TCLIENTS

001: <<ACCOUNT>>\CLIENTS

002: <<ACCOUNT>>\CLIENTS]D

l Adding a datasource.

You will need to let both the client and server know what type of datasource you are creating, this can be done by using on of the fol-
lowing :

“Attunity Configuration Manager”, This is a GUI interface installed with the windows version of Attunity, it also allows you to con-
figure remote servers, (UNIX and WINDOWS )

JBase - User Guide - Release R15.000 - Page 158 of 629


“nav_util”

nav_util is a multi-functional utility supplied by Attunity, it allows jDP to setup and maintain datasources, and it can also execute
queries.

To add a datasource via nav_util execute the following from the server..

nav_util UPD_DS TSAMPLE jDP table file=/home/TSample/TABLEFILE

You can view existing bindings with:-

nav_util view bindings

For more information please read the Attunity documentation.

l Setting up the environment variables for a client…

When a client connects the Attunity driver needs to be able to see where the jBASE account is. This is done by using the following
script.

WINDOWS: nav_login.bat

UNIX:                 site_nav_login.sh

WINDOWS
Using jed / notepad edit %NAVROOT%\bin\ nav_login.bat

jed %NAVROOT%\bin\ nav_login.bat

File C:\jbase4\4.1\jDP\bin\ , Record 'nav_login.bat' Insert 17:01:52

Command->

001 @echo off

002 SET PATH="C:\jbase4\4.1\jDP\BIN";%PATH%

003 SET NAVROOT=C:\jbase4\4.1\jDP

-------------------------------- End Of Record --------------------------------

Add the following lines to let jBASE know where things are..

004 SET JEDIFILEPATH=C:\Sample;.

005 SET JEDIFILENAME_MD=c:\Sample\MD

006 SET HOME=c:\Sample

UNIX
jed $NAVROOT/bin/site_nav_login.sh

001 #

002 # Modify Attunity 3.2 environment for jBASE 4.x

003 #

035 # Make sure Attunity can see our demo data files

036 JEDIFILEPATH=/usr/jbc/jdp/demo

037 export JEDIFILEPATH

038

039 #

040 # Any additional site specific changes should follow

JBase - User Guide - Release R15.000 - Page 159 of 629


041 ######################################################################

Add the following lines to let jBASE know where things are..

036 JEDIFILEPATH=/home/Sample

037 export JEDIFILEPATH

038 JEDIFILENAME_MD=/home/Sample

039 export JEDIFILENAME_MD

040 HOME=/home

041 export HOME

On the client machines you also need to add a reference to the remote datasource, this can be done via the GUI or by executing the following
command : 

nav_util UPD_DS REMOTE <<datasource>>

EXAMPLE
nav_util UPD_DS REMOTE TSAMPLE

l Creating a link between the Attunity driver and the jBASE files.

If you are using a file that contains multivalues you will need to configure jDP so that the jDP driver can treats the multivalued
columns as tables, physically they are still stored as a multivalues in the jBASE files, and jDP simply creates an internal virtual table
that the jDP driver can use.

This is achieved by using the “nav_util” utility,

The general; syntax is as follows…

nav_util gen_array_table <<datasource>> <<tablename>>

EXAMPLE
nav_util gen_array_table TSAMPLE TCLIENT

nav_util gen_array_table TSAMPLE *

You can list all data sources with the following command :-

nav_util view datasources *

The file viewer will vary depending on whether you are running on windows or UNIX in this example we are not using multi-values so all tables
should be usable via jDP without any problems.

For further information see your Attunity documentation.

Catalogue datasource
This example shows how to use a Catalogue datasource with jDP,

To create a catalogue, you must set up a catalogue directory by using the ‘CreateJDPCatalog’ program normally found in the jBASE Bin dir-
ectory. Run the program on the server (the machine that will hold the data), which will prompt the user for three inputs: ‘DSN Name’ (the name
to be entered into the nav.bnd file), ‘Catalogue Directory’ and ‘Public Tables Path’.

DSN Name
This is the datasource name that the program will write into the binding file; the ‘jDP’ software to connect to the catalogue uses this file.

Catalogue Directory
This is the directory that the catalogue can find all its required system tables.

JBase - User Guide - Release R15.000 - Page 160 of 629


Public Tables Path
The directory the catalogue uses to hold the tables for the default schema.

EXAMPLE
jsh ~ -->CreateJDPCatalog

%JBCRELEASEDIR% is currently set to: C:\jbase4\4.1

%NAVROOT% is currently set to: C:\jbase4\4.1\jDP

Attunity version: 3.4.02.00

Enter the Data Source name or <Q>uit: CATSAMPLE

Enter absolute directory pathname in which to locate the Catalog or <Q>uit: c:\cat

Enter absolute directory pathname in which to create tables for the Public schema or <Q>uit:

c:\cat\public

l Creating Catalog and Public directories...


l Loading initial Catalog entries into 'c:\cat'...
l Updating the Schema file...
l Updating Object Store...
l Updating Security...

jDP Catalog created successfully.

jsh ~ -->

After the program has run, you will have to let jDP know about the new datasource.

You can do this via the windows GUI or by typing:

Nav_util UPD_DS CATSAMPLE jDP catalogdir=c:\cat

If a client machine accesses the data (i.e. the server and the client are separate machines) then the client will also need to setup a datasource
entry.

Nav_util UPD_DS CATSAMPLE REMOTE <<remote ip>>

JBase - User Guide - Release R15.000 - Page 161 of 629


jBASE Dictionary Configurator

The jBASE Dictionary Configurator (or jDC) is designed to amend standard jBASE Dictionaries to store extra data needed by jDP in order to
carry out tasks in SQL, which require more information to perform operations such as joins. The jDC also allows configuration of which files
are visible and updateable. By default, all files are read-only through jDP.

The jDC only operates on locally accessible files. To configure server based files, a network share mechnism needs to be set up.

Normal jBASE files contain data in one file in multi-valued format which would normally be spread amongst a number of hierarchical tables in a
relational database. The jDC allows the configuration of a number of logical sub tables to allow SQL constructs to work against jBASE multi-
value data in the normal manner.

To configure the settings for a file, select it and click on the properties button. A dialog should appear similar to this which allows con-
figuration of the visibility / read-only attributes of the file.

These options are as follows;

Description Some tools can be supplied with the string you enter here as a TABLE description.

Visible to Specifies whether the columns are hidden form jDP or not. the default, provided by the driver, is
jDP that the table is visible. Override the default here. You can override the file defaults on an individual
column (dictionary entry).

Allow Specifies whether dictionary elements in this file are updatable by default.
update

Allow SQL If a dictionary element is updateable, this property allows or denies its update using the SQL value
NULL NULL. Note that SQL NULL is not the same as a null string "". It is roughly equivalent to "Unas-
Update signed Var", in the jBC language.

JBase - User Guide - Release R15.000 - Page 162 of 629


SQL read When reading from a column, (dictionary element), you can specify whether to return an empty ele-
returns ment (null string "", or "" in a numeric field for instance), as the special SQL NULL or not. The
NULL driver default shell should only be overridden if you fully understand the concepts of SQL NULL.

Process Dictionary elements that are A or S types, may have conversions/correlatives on both attribute 7
Attribute 7 and attribute 8 of their definition. By default, anything specified on Attribute 7 is ignored. You can
choose to process this attribute by default or not.

File visible By default, the driver advertises all files that it can see. However, you can choose to remove this file
to jDP from the list of advertised TABLES.

Add New Inserts, Deletes and Updates are forbidden by default, for what should be obvious security con-
Items cerns. If you want users to be able to add new rows (items etc), to the file, then specify this here.

Delete Specify whether users are allowed to delete rows (items etc), from this file or not.
Items

JBase - User Guide - Release R15.000 - Page 163 of 629


jDP and Subvalues

jDP can be used to query subvalues provided the system has been setup correctly. In order to use jDP to query sub values, the environment
variable JDP_ AUTO_EXPAND must be set to instruct the query engine to take account of them. In addition all subvalues must be properly
configured using the jDC tool such that there is a controlling multivalue for each subvalue set.

JBase - User Guide - Release R15.000 - Page 164 of 629


jBASE Indexes

l Overview
l CREATE-INDEX
l DELETE-INDEX
l KEY-SELECT / QUERY-INDEX
l LIST-INDEX
l REBUILD-INDEX
l VERIFY-INDEX
l Using JQL Commands
l SUBROUTINES
l Related BASIC Statements
l REGULAR EXPRESSIONS
l Backup and Restore
l Appendices

JBase - User Guide - Release R15.000 - Page 165 of 629


Overview

In order to speed up retrieval of records by attributes rather than by key, jBASE provides the facility to build secondary indexes on these fields.
These indexes are stored as binary trees (see Appendix A for details) which are compiled and stored in a file with the same name as the data file
with “]I” appended onto the end. For example, an index created on JCUSTOMERS will be stored in a file called JCUSTOMERS]I.

Indexes will have a positive effect on SELECTs on the indexed fields themselves but the maintenance of the index will give a slight overhead on
record updates as the index must be maintained. Thus a balance must be sought between improvements in query performance versus the over-
head on other file access.

JBase - User Guide - Release R15.000 - Page 166 of 629


CREATE-INDEX

The CREATE-INDEX command will build a secondary index on an attribute or combination of attributes in the specified file.

COMMAND SYNTAX
create-index -Options filename indexname index-definition

SYNTAX ELEMENTS
Option Description

-a Adjourn the rebuild of the indexes until rebuild-index.

-c Make the index case insensitive

-d Debug of the index code allowed

-k Slow coalesce mode

-lcode Index lookup code

-n Any indexes that produce null strings are ignored

-o Overwrite any existing definition

-s Write out a pseudo source files

-v Verbose display, display on period for each 1000 records rebuilt

-m Suppress multivalue index build use multivalues as single key

-w Permanent write mode

-N Synonymous with -n option. ( compatibility option)

-S Silent operation (compatibility option )

-M Synonymous with -m option. ( compatibility option)

-Vnn Limit multivalue used in index key. e.g. V0 = M option

-X Exclude existing records when building the index

-Zlocale Create index in locale.  Defaults to JBASE_LOCALE if none specified

This command can be used to create a new index definition. By default the index is then rebuilt to include any existing records.

Option -c means the indexes created will be done in a case insensitive fashion. For example "Fred" and "FRED" will be the same index. This is
used automatically in the key-select or query-index command. However if a jQL command such as SORT or SELECT wants to use the index,
then the command must be done in such a way that the jQL command would also be case insensitive (for example, attribute 7 of the DICT item
is MCU and the selection criteria is all upper case).

Option -d means the pseudo-code created to build the index key can be debugged. This assumes that the debugger is enabled for the rest of the
jBC code anyway.

Option –k and –w are advanced tuning options see Appendix A for a description of their use.

Option -l is the lookup code. It is used with key-select and query- index. What happens is that the selection criteria will be converted using an
ICONV call before being used. For example if you create a right justified (numeric) index on say attribute 6 of all items, this could be a date field
in internal format. If you want to look at a range of dates then instead of doing this:

JBase - User Guide - Release R15.000 - Page 167 of 629


jsh-> key-select ORDERS WITH PLACE-DATE > 10638

where 10638 is a date in internal format, then by using the option "-lD" we will perform an ICONV on the selection criteria of format "D" thus
translating the date in external format to internal format, and so your command line would be:

jsh->key-select ORDERS WITH PLACE-DATE > 14-feb-1997

This also applies to selection criteria passed with a jQL command such as LIST or SELECT.

Option -n shows that any index keys that are created as zero length strings will not be entered into the index. This is useful for suppressing
unwanted index keys. It is especially useful when used in conjunction with the CALL statement in the index definition (see Appendix A) so that
if the subroutine decides the index is not interested in being stored, it creates a null index key.

Option -o will overwrite any existing index definition. Without this, if you attempt to re-define an index definition you will get an error. If the -o
option is used to re-define an existing index definition, then all the index data for the definition previously associated with the index will be
deleted.

Option -a means the index data will not be built once the index definition is created. The default action is to build the index, depending upon
the size of your file data, this could be a lengthy operation ! Once the index data is built it then becomes in-sync with the file data and is avail-
able to all the index commands such as key-select and available to jQL commands such as SELECT to improve the performance of them. With
this option you need to execute a rebuild-index command to rebuild the index data.

Option -s causes some pseudo source code to be created. This is used with option -d so that you can debug complex index definitions.

Option -v is the verbose mode. It will display a period character for every 1000 records in the file that are rebuilt.

EXAMPLES
Example: Create an index based on attribute 1 , concatenated with attribute 2.

jsh--> create-index filename indexname by 1 : 2

Example: Create an index on the attribute given in the DICTionary definition NAME and a second attribute number 3 , but in descending order

jsh--> create-index filename indexname by NAME by-dl 3

Example: Create an index on attribute 4 which is normally an internal date. You want to be able to specify dates in external format when doing
selections against it. Additionally if the field is a null string, then don't store any index information.

% CREATE-INDEX -lD -n ORDERS BY-AR 4

Example: Create an index using three attributes.

sh-> create-index FILENAME INDEXNAME BY 1 BY 2 : "*" : 3

In the above definition the index key is built out of three attributes. Should these attributes all have differing numbers of multi-values it makes
it difficult to create an index key that is logically consistent. Therefore in the above example it would fail to create the index definition.

Option -N is synonymous with the -n option on create-index. When used, any index keys that equate to a null string will not be stored.This is a
compatibility option.

Option -S is a compatibility option which provides for silent operation when an index is created.

Option -M or -m option suppresses creating individual index keys for each mutlivalue, in other words all mutlivalues are used to create the
index key.

For example, if an index is generated on a record with an attribute as follows:

PIPE

001 123]456]789

Then by default three index values based on "123" , "456" and "789" will be created. With the -m or (M) option on create-index, we will build a
single index value based on "123]456]789".

Option -Vn. This option provides compatibility and is used to limit the number of multivalues used to generate an index key. Without this
option then ALL multi-values will each generate an index definition. This option restricts it to the first nnn values. A special case of (V0) exists.
In this case where the multi-value count is set to 0, we assume no multi-values are required and so we don"t split the attribute into multi-val-
ues but treat the entire attribute as a single entity -- in effect then (V0) option is identical to the (M) option.

Remember the jBASE syntax already allows an individual value to be used instead. For example

JBase - User Guide - Release R15.000 - Page 168 of 629


CREATE-INDEX FILENAME INDEXNAME BY 4.3

means just use the third multi-value in attribute 4.

Option -X. This option on CREATE-INDEX will set-up the index, but not run the existing file through it - in other words, it doesn"t make any
attempt to index what is already in the file. The file will still me marked as "in-sync". The net result is that you get an index later with only
newly-written or modified records - very nice when you're dealing with huge files and you only want to process what's changed or created since
the index was set-up.

In addition to the above syntax a compatible form of the CREATE-INDEX command can also be used.

CREATE-INDEX FILENAME ITEM

This creates an index called ITEM and the index definition is based on the dictionary item ITEM.

jBASE supports this by converting on-line the syntax to the jBASE syntax and notifying the user of the equivalent converted command (unless
the (S) option is used).

When this happens the dictionary definition is used as follows:

l Attribute 2 tells us what attribute number to extract


l Attribute 7 tells us any lookup code i.e. what to convert any matching string using.
l Attribute 8 tells us any conversions to apply when building the index data
l Attribute 9 tells us if it is a left or right (numeric) sort.

jBASE allows indexes created in this manner to be used with some jQL commands like SELECT or SORT. An index which is not created via a
dictionary item must query the index with KEY-SELECT or QUERY-INDEX.

If a complex definition exists in attribute 8, then the conversion will fail and the user will have to use the jBASE syntax.

This example shows a DICT item in jBASE and how , if you run the create-index command against it, it will be converted to the jBASE syntax
and run.

INDEX1

001 A

002 3

003 Description

004

005

006

007 D2

008 MCU

009 R

010 10

For example

CREATE-INDEX -a filename INDEX1

Notice: Command converted to "CREATE-INDEX -lD2 filename BY-AR OCONV(3,"MCU")"

Index definition "INDEX1" created successfully

Note: You now need to rebuild the index data for file "filename" using rebuild-index.

JBase - User Guide - Release R15.000 - Page 169 of 629


DELETE-INDEX

This command is called to delete one or more index definitions that are associated with a file. All the space taken by the index is released to the
file overflow space (but not necessarily the operating system file free space).

COMMAND SYNTAX
delete-index -Options filename { {indexname {indexname ...}} | *}

SYNTAX ELEMENTS
Option Description

-a Delete ALL indexes in the file

-S Silent option for compatibility

Option -a causes all index definitions to be deleted.  Note: For J4 files this does not physically delete the index file. If you have no further need
for indexes then the filename]I can safely be deleted.

Without option -a you need to specify one or more index name on the command line.

EXAMPLES
Example: Delete ALL the index definitions for file PRODUCTS 

jsh--> DELETE-INDEX -a PRODUCTS

jsh--> DELETE-INDEX PRODUCTS *

Example: Delete the index name "value" in the file PRODUCTS

% delete-index PRODUCTS value

JBase - User Guide - Release R15.000 - Page 170 of 629


KEY-SELECT/QUERY-INDEX

This command allows you to select or count a list of record keys. Note that file updates that cause a change to an index will wait for a query-
index to complete. The first structure of the query-index command allows you to select all record keys sorted by the index definition. For
example, to select all customers sorted by their last name:

jsh-> query-index CUSTOMERS lastname

COMMAND SYNTAX
query-index -Options filename index_name

query-index -Options filename {IF/WITH} iname {Op} "startpos"

query-index -Options filename {IF/WITH} iname {Op} "startpos" {AND} {Op} "endpos"

SYNTAX ELEMENTS
Where Op can be: LT < less than

LE <= less than or equal

GT > greater than

GE >= greater than or equal.

Option Description

-c COUNT the records (default is to select records)

-inn Indexes used restricted to approx nn indexes

-mTYPE Match algorithm – either “REGEXP”, “JQL” or “DEFAULT”

-rnn Record count restricted to approx nn records

The second structure of the query-index command allows you to specify a single conditional parameter. You can make this query less than,
greater than etc. to the parameter. If you don't specify LT,GT,etc. then it defaults to equals.

EXAMPLES
Select all customers whose name begins with "KOOP"

jsh-> QUERY-INDEX CUSTOMERS IF lastname "KOOP"

Note that in this case the double quotes will be ignored , as would single quotes. The IF token is a throwaway token, and is used simply for
clarity. WITH can also be used to the same effect.

Another example is to select all customers whose date of birth is before 25 July 1956

jsh-> QUERY-INDEX CUSTOMERS WITH dob LT 25-JUL-1956

The third structure of the query-index command allows you to specify a range of values. This means the operators must be either GT or GE fol-
lowed by LT or LE. If the operators are not specified the command defaults to GE and LE.

Example: Count all the customers whose last order was placed between 19-DEC-1996 and 23-DEC-1996 inclusively.

jsh--> query-index -c CUSTOMERS IF order.date >= "19-DEC-1996" and <= "23-DEC-1996"

Option -c means a count of record keys is done instead of producing a select list.

Option -m allows the pattern matching algorithm to be changed :

JBase - User Guide - Release R15.000 - Page 171 of 629


When the command is performing its test, it does so using a simple string or numeric test. If you want to make the test more akin to say a jQL
command, then you would use the -mJQL option. For example, if you want to select all customers whose name ends in PATEL, you could do
this:

jsh-> query-index -mJQL CUSTOMERS IF lastname EQ "[PATEL"

Similarly you can use the -mREGEXP to use a pattern matching algorithm called "Regular Expressions". This allows complicated patterns to be
searched for. See the "Regular Expressions" chapter in this document. As an example, the following command will select all products whose
description begins with the letter A is followed by any number of characters before the sequence PIPE is found:

jsh-> query-index -mREGEXP PRODUCTS IF description EQ "^A.*PIPE"

Option -i can be used to restrict the number of indexes used to create the list of record keys. This can be useful to restrict a search to a smaller
subset.

Option -r is similar to -i except it restrict the number of record keys.

NOTES
QUERY-INDEX should only be used to generate select-lists for READNEXT KEY and READPREV KEY statements. It should not be used to
generate select-lists for a subsequent SELECT, the READNEXT statement or for use with other jQL commands, e.g. LIST; the jQL SELECT
command should be used for this purpose.

JBase - User Guide - Release R15.000 - Page 172 of 629


LIST-INDEX

This command is used to display to the screen details of all the current definitions. A format similar to jQL is produced.

COMMAND SYNTAX
list-index -Options filename {Same as jQL options}

SYNTAX ELEMENTS
Option Description

-ffile Use the filename “file” instead of a temporary file

-m Output is in machine readable format

-a Verbose output – all fields will be displayed

Option -f allows you to specify your own file name instead of list-index creating a temporary file. This way you can find out what DICTionary
items are created by list-index, and if you want to you can modify them and pass them on the command line. Using this option therefore allows
you to define your own output format for the command.

Option -m produce "machine readable" displays. In other words the detail is displayed simply as a series of lines, one line per index definition,
with a tab character (CHAR(9)) to delimit the fields. This makes it easily parsed by another program or UNIX script.

Option -a is for verbose mode -- all details will be printed instead of a smaller selection.

EXAMPLES
Example: Display all the index definitions, in full, for file CUSTOMERS, and send the output to the printer.

jsh--> LIST-INDEX -v CUSTOMERS (P

NOTES
Machine readable format broken down as follows;

Tab position Description / INDICES() attribute reference

1 Index name <0>

2 Not used

3 Sort criteria <1>

4 Base FID of index

5 Always 1

6 Index type <2>

7 Creation time <5>

8 Last modified time <6>

9 Index number (zero based)

10 DEBUG flag <7>

11 NULL flag <8>

JBase - User Guide - Release R15.000 - Page 173 of 629


12 CASE flag <9>

13 MULTI-VALUE flag <10>

14 SYNC flag <11>

15 VALUE MAX count <12>

16 – 19 Not used

20 INDEX definition <3>

21 Lookup definition <4>

JBase - User Guide - Release R15.000 - Page 174 of 629


REBUILD-INDEX

This command will rebuild the index definitions. It can be used in the following circumstances:

l Following the corruption of the index file


l Following a file restore using jrestore . This is detailed later.
l Following the creation of an index using create-index -a.

By default create-index will build the index and will not require a rebuild-index command to be performed.

COMMAND SYNTAX
rebuild-index -Options filename { {indexname {indexname ...}} | *}

SYNTAX ELEMENTS
Option Description

-a Rebuilds ALL indexes in the file

-r Rebuild ALL indexes in the specified directory

-v Verbose mode; displays a full stop for every 1000 records

Option -a means you want to rebuild all the indexes defined for the file. This can also be achieved by specifying * as the index name. Otherwise
you must specify on the command line one or more index names to rebuild.

Option -r will rebuild all files in the directory name specified. This is a useful operation after using, for example, jrestore to restore your data-
base and then you can use the option -r to rebuild all files in a certain directory.

JBase - User Guide - Release R15.000 - Page 175 of 629


VERIFY-INDEX

This command will verify the integrity of an index definition, in so far as it looks for internal corruption. It doesn't actually verify that the index
data actually correctly cross references the data file records.

COMMAND SYNTAX
verify-index -Options filename { {indexname {indexname ...}} | *}

SYNTAX ELEMENTS
Option Description

-a Verifies ALL indexes in the file

-l Display leaf information

-o Display overflow frame information

-r Display record information

-v Verbose mode

Option -a means all indexes will be verified and this can also be achieved by using * on the command line for the index name. Without the -a
option (or * as index name) you must specify on the command line one or more indexes to verify.

Option -l means information about each leaf of the index is displayed.

Option -o causes the overflow table information to be displayed.

Option -r causes all the record information to be displayed. This is the index key followed by all the record keys that share the same index
value.

Option -v is the verbose mode and causes extra information to be displayed.

NOTES
CAUTION While this command is active a lock on an entire index is taken. Should an application try to update that index then the application
will wait until the lock is released, which isn't until the verify-index command has completed for that particular index. This means scenarios
such as the one below should be used only with caution as the piping of the output into "more" means the lock will be retained until the dis-
play has completed.

% verify-index -avrl FILENAME | more

JBase - User Guide - Release R15.000 - Page 176 of 629


Using JQL Commands

jBASE supports a limited mechanism whereby jQL commands such as SORT or SELECT can automatically use any valid secondary index to
reduce the search time. This does not involve creating a specific DICTionary item. If for any reason the index cannot be found, or is not up to
date (e.g. awaiting a rebuild-index command) then the jQL command will ignore the secondary index and retrieve the information in the usual
manner.

At present only a single search pattern can be used in a jQL command. As an example a file will have an index built onto attribute 23 , the cus-
tomer last name like this:

jsh->create-index CUSTOMERS lastname BY 23

Let us assume there exists a DICTionary definition called LASTNAME that looks like this:

LASTNAME
001 A
002 23
003 Customer Lastname
004
005
006
007
008
009 T
010 20

Now let us assume we try to select all customers in that file whose last name equals "COOPER]". The jQL statement would look like this:

jsh-> SELECT CUSTOMERS IF LASTNAME EQ "COOPER]"

In this example the index definition is "out of sync", awaiting a rebuild-index command to be performed. Therefore the SELECT would achieve
the result by looking through the entire file. Now let us run the rebuild-index command as:

jsh-> rebuild-index CUSTOMERS lastname

If we now re-execute the SELECT command, then instead of scanning through the entire CUSTOMERS file, it will look through the index defin-
ition "lastname" instead and will therefore execute considerably quicker.

JBase - User Guide - Release R15.000 - Page 177 of 629


SUBROUTINES

It is possible to call a jBC subroutine from an index definition. The subroutine should have five parameters as follows:

Result This is to return the result of the calculation.

Filevar File variable of file for which the update is being processed.

Record Record being updated.

Key Record key of the record being updated.

Field Field, or attribute, already extracted as part of the index definition

As an example, consider the following index creation

jsh-> CREATE-INDEX FILENAME INDEXNAME BY 1 : CALL(2,"INDEX-DEF")

When an update occurs the index key is calculated by taking attribute 1 and concatenating it with the output from a call to a subroutine called
INDEX-DEF. The source code for this may look something like this:

INDEX-DEF
001 SUBROUTINE INDEX-DEF(result , file , record , key , field )
002 IF NUM(field) THEN result = "*1" ELSE result = "*0"
003 result := record<3>
004 RETURN

In the above example the result is created in the first parameter, the "result" variable. This is calculated by taking the string "*1" or "*0" and con-
catenating it with attribute 3 from the record being updated. The choice of "*1" or "*0" depends upon whether the extracted attribute, passed in
the fifth parameter as variable "field" , is numeric or not. The index definition was "CALL(2,"INDEX-DEF")" so this extracted attribute will be
attribute 2.

Any normal jBC code will execute in these subroutines but you should be aware of the following pitfalls.

The code should always create exactly the same result given the same record. This means you should avoid using functionality that creates a
variable value, such as the RND() function, the TIME() or DATE() functions, the users port number and so on. If this occurs then there will be
no way jBASE can delete a changed index value and so the index file will continually grow with invalid data even if the number of records remain
constant.

These subroutines will be called implicitly from other running jBC code which to its knowledge has merely executed a DELETE or WRITE state-
ment. You should therefore avoid any code that changes the nature of the environment such as using the default select list, turning echo on or
off, turning the break key on or off. There are ways around many of these, for example you can turn the echo on and off so long as your code
remembers in all cases to restore it to its original status. Similarly you can do a SELECT so long as it is to a local variable rather than the
default select list.

Depending upon your application, these subroutines may be accessed by users other than the account in which the files exist. Therefore all per-
sons who have access to OPEN and update the file must also have access to be able to CALL your subroutine. This can be done in a number of
ways.

All users who want to update the file may have the environment variable JBCOBJECTLIST set to include the library where these subroutines
were catologed into. For example if the subroutines have been cataloged from account greg then you can set up the JBCOBJECTLIST as fol-
lows so that we look in the users current lib directory and failing that in the lib directory for greg (this from the Korn shell)

export JBCOBJECTLIST=$HOME/lib:~greg/lib

You can CATALOG into a directory that is common to all users anyway. Such as directory is the lib directory where jBASE is installed. In this
example you don't need to set up JBCOBJECTLIST. You do , however, remember to re-catalog all these subroutines when a new version of
jBASE is loaded. You change the output directory for CATALOG with the JBCDEV_LIB environment variable. For example, from the Unix Korn
shell you would do this:

export JBCDEV_LIB=$JBCRELEASEDIR/lib
CATALOG BP INDEX-DEF

JBase - User Guide - Release R15.000 - Page 178 of 629


JBase - User Guide - Release R15.000 - Page 179 of 629
Related BASIC Statements

INDICIES  Returns the index information for the specified file.

OPENINDEX Opens the specified index definition..

READNEXT Move forward through an index.

READPREV Move backward through an index.

SELECT Select an index variable.

SELECTINDEX Creates an array of record keys based on the specified index.

Documentation for these statements can be found in the jBC manual.

JBase - User Guide - Release R15.000 - Page 180 of 629


REGULAR EXPRESSIONS

Regular expressions are the name given to a set of pattern matching characters. The term derived from Unix environment. The regular expres-
sions can be used to great effect using the query-index command to decide what records to select. A full description of regular expressions can
be obtained on Unix systems by entering the command:

% man 8 regexp

For Windows systems only a limited subset of regular expressions are available. The following characters inside a regular expression have spe-
cial meaning:

^ The text must match the start of the record key.

$  The text must match the end of the record key

.* Any number of characters of any value may follow

\x This escapes the character x meaning it just evaluates to x. This is useful if you want to include say the ^ character
as part of your text string rather than a character with special meaning.

For example, on either a Unix or Windows/NT system you could use key-select to find a product description that has the text SLIPPER at the
start of the description. This can be done using the jQL format as you might be familiar with using say the SELECT command or by using reg-
ular expressions. The two methods are therefore:

jsh- > key- select - mJQL PRODUCTS IF description EQ "SLIPPER] "


jsh-> key-select -mREGEXP PRODUCTS if description EQ "^SLIPPER"

As a more complicate regular expression, the following example looks for a product that begins with the string BIG , has the words RED some-
where in the text, and then must end with the words ENGINE:

jsh-> query-index -mREGEXP PRODUCTS "^BIG.*RED.*ENGINE$"

The Unix implementation uses the operating system supplied version of regular expressions and these are far more powerful than the jBASE
supplied version of regular expressions on Windows systems. As already mentioned , use man 5 regexp to find more details. The following
example looks for a product description that begins with the words PIPE , any number of spaces, then one or more numeric characters follow
(including optionally a decimal point), any number of spaces, and finally the characters "mm" , which are case insensitive:

jsh->query-index -mREGEXP PRODUCTS EQ "^PIPE *[0-9\.][0-9\.]*[mM][mM]$"

The above command would find any of the following:

PIPE 5 mm
PIPE15MM
PIPE 33.3 mm

JBase - User Guide - Release R15.000 - Page 181 of 629


Backup and Restore

There are three ways of backing up your database.

ACCOUNT-SAVE
This should only be used to transfer your data to a non-jBASE system. The indexing information will be lost.

tar and cpio


These Unix supplied backup utilities will backup ALL jBASE files and not care if they are hashed files, index files, dictionary items and so on.
These should be used with caution, and only against databases where there is no update activity. The tar and cpio programs will not respect
the locks on a file that jBASE normally uses.

jbackup and jrestore


These are the jBASE supplied backup and restore programs and are the preferred way of backing up your data. They respect all locks and will
keep the tapes free from any soft format errors that would otherwise occur if using tar and cpio on an active database.

By default , when you use jbackup to save a database, any indexing information will be saved as just the index definition, not the actual index
data. Conversely during a restore using jrestore, the index definition will be restored, but not the index data, whether it exists on tape or not.

So the full scenario, by default

l Backup your database:

cd $HOME
find . -print | jbackup -v -f/dev/rmt/0

l Restore your database:

cd $HOME
rm -rf *
jrestore -v -f /dev/rmt/0

l Rebuild indexes.
l The stage (ii) will have restored the database and the index definitions, but not the index data. Now to rebuild the index data for all the
files you have just restored:
rebuild-index -r $HOME

If you have restored files into sub-directories you could use the following Unix command to rebuild the indexes for all files in all sub-directories

cd $HOME
find . -print | xargs rebuild-index

When you backup a database with jbackup, you can use the "-c" option and this will backup the actual index data as well as the data files. The
index data will be dumped as a normal Unix binary file , and so during the restore phase will be restored exactly as-is.

When you restore a database using jrestore, by default it will restore the index information, but will NOT rebuild the index data. This is quite
time-consuming and so by default the jrestore works in the quickest mode. The index will need to be re-built at a later stage using rebuild-
index. In the meantime, any attempts to use query-index or key-select will fail, and the jQL programs such as COUNT and SELECT will not use
the index in order to satisfy the request. During the restore a warning message will be shown against each file that needs re-building. Once the
rebuild-index  has completed, the index will become available again to the jQL programs and query-index.

You can optionally use the -N option to jrestore and this will result in the indexes being built as the data is restored. This will slow down the
restore time, but means the index is immediately available for use without the need to re-build the indexes with rebuild-index.

JBase - User Guide - Release R15.000 - Page 182 of 629


Appendices

Appendix A. Internal operation


The following section describes the internal operation of the indexing system. Understanding of this is not a requirement for simple index cre-
ation or for indexing of small to medium sized files. It explains ‘tuning’ operations that can be carried out to improve indexing performance with
large (>100K records) files.

Within the filename]I file each index is stored as a b-tree. By default each node of the tree relates to one ‘index value’ and contains a list of keys
for the records that contain that value. This is efficient for read operation because, for any requested index value, the required node can rapidly
be found and the record list returned.

For write operations this is however inefficient. If a given value points to a large list of records then to insert a new record the correct place in
the list must be found, the remainder of the list shifted up and the new ‘record key’ inserted. If a file containing a large number of records is
indexed this can be a very slow operation.

To solve this problem ‘write mode’ was introduced. In this mode instead of storing record keys in simple lists each list is also stored as a b-
trees rooted in a node of the existing index value tree. These ‘record b-trees’ are searched by record key instead of index value. The result is that
once the correct index value has been found a new record key can quickly be inserted. However when a read is required the record b-tree must
be coalesced back into a list. This is time consuming. So read performance is reduced.

By default when create-index (or rebuild-index) is invoked the system is switched into write mode. All the records are written into the index,
the system is switched back into ‘read mode’ and the record b-trees are coalesced back into lists ready to be read  Create-index has some
options to fine tune this behaviour:-

Option – k means ‘Slow coalesce’ mode. In this mode the re-coalescing of b-trees is deferred until each index value is read for the first time.
This will give a slightly faster rebuild but at the cost of a delay on the first read of each value.

Option – w means ‘Write only’ mode. In this mode b-trees are never coalesced into lists. This will reduce the performance of read operations
but increase the performance of write operations. If an indexed file is frequently modified, but only occasionally searched, then this mode
should be considered.

Note On IndexFile Size


A certain amount of extra file space is required to support record b-trees. Because of this when in write mode a slightly larger filename]I file is
required than is the case in read mode. When the system switches back into read mode less space is required but, since the size of the file-
name]I file cannot be reduced, it remains the same size. The ‘unused’ space remains available to the indexing system and is re-used as more
entries are added to the file and/or new indexes are created.

Appendix B – Sort sequences


When you create an index definition using the create-index command you must specify a description of how the index key is to be built. This
example below shows a basic index definition such that the index key is created from attribute 4 of the record

create-index CUSTOMERS CUST-NAME BY 4

In the above example CUSTOMERS is the name of the file and CUST-NAME is the name of the index definition. The full details of create-index
have already been described at the earlier part of this document.

This appendix deals with the description of how to build the index key from the record data, which is "BY 4" in the above example. The syntax
of the index definition can be summaries as:

by-expr sort-def {by-expr sort-def {by-expr sort-def }}

Where by-expr is one of BY , BY-AL , BY-DL , BY-AR or BY-DR and sort-def will be described later. Each by-expr causes another sort
sequence in the index key. Consider the following example:

create-index filename indexname BY 3 BY 2

The means the index key will be made up from attribute 3 of the record , a 0xff delimiter, and finally attribute 2 of the record. The index data
will be sorted by attribute 3. Where there are cases when attribute 3 is the same as previous index keys, it will be further sorted by attribute 2.

The keywords by,by-al,by-dl,by-ar and by-dr are all case insensitive.

JBase - User Guide - Release R15.000 - Page 183 of 629


The keyword BY means the sort sequence is ascending left justified.

The keyword BY-AL same as BY and means the sort sequence is ascending left justified.

The keyword BY-DL means the sort sequence is descending left justified.

The keyword BY-AR means the sort sequence is ascending right justified.

The keyword BY-DR means the sort sequence is descending right justified.

When a sort sequence is described as right justified then this takes on the same meaning as it does in jQL commands such as LIST and
SELECT, i.e. it assumes numeric data. Therefore right justified fields will be sorted numerically and left justified fields sorted textually. In the
event that a right justified field contains a null string or non-numeric data, then the sort sequence will be the same as jQL command and have
the following precedence:

l Fields that contain entirely numeric values


l Fields that are an empty zero length string
l Fields that begin with a numeric value and then are followed by non-numeric
l Fields that are one or more bytes and are not numeric.

The "sort-def" definition mentioned earlier is the description of how an individual sort sequence is defined. The "sort-def" can be one or more
extract definitions , each definition being delimited by a colon. Each sort-def definition is concatenated to each other. For example:

by 3 : 4 : 5 by-dr DATE

means the index key is made up as follows:

l attribute 3 from the record concatenated with attribute 4 from the record concatenated with attribute 5 from the record concatenated
with a 0xff delimiter between the sort sequence
l attribute NN from the record, where NN is described the in DICTionary item DATE.

When the index key is added to the index data, the key will be sorted , in ascending left justified sequence, by the first sort sequence , attrib-
utes 3 , 4 and 5. If there are duplicate keys then it is further sorted in descending right justified sequence by attribute NN from the record
where NN is described in the DICTionary item.

Note that when using DICTionary items to describe what attribute number to extract the index definition simply extracts the attribute number
and forgets the DICTionary name. This way the index remains logically consistent even if the DICT record is later amended. The "sort-def" defin-
ition can be more than a simple attribute number. It can be any of the following types.

Numeric This shows to simply extract attribute "Numeric" from the record. If the numeric value is 0 then this means the record key.

Numeric.Numeric This shows to extract a specific multi-value from a specific attribute. For example 4.3 shows to extract multi-value 3
from attribute 4.

OCONV(field , "code") This causes an output conversion to be applied to the defined "field" The conversion to apply is any that can be
applied with the OCONV function in jBC code. The "field" is defined using one of the above mentioned definitions of "Numeric" or "Numer-
ic.Numeric".

CALL(field,"subname") This allows a normal jBC subroutine to be called. The mechanism for doing this is defined later.

"STRING" You can specify a string constant.

As a more complex example, consider the following statement:

jsh-> CREATE-INDEX CUSTOMERS BY 3.1 : "*" : 2.1 BY-AR 4

The above creates an index key with two sort sequences. The first sort sequence is in ascending left justified with multivalue 1 of attribute 3
concatenated with an asterisk and then concatenated with multivalue 1 of attribute 2. The second sort sequence is an ascending right (e.g.
numeric) sequence on the fourth attribute. This index could be, for example, a customers surname , and asterisk and a customers first name. In
the event you have two customers with the same name it will be further sorted by their date of birth.

The second example shows the use of the CALL function:

jsh-> create-index -lD -n CUSTOMERS by-ar CALL(3,"TESTDATE")

In the above example attribute 3 will be extracted from the record and passed to a user-written subroutine call TESTDATE. This subroutine
can amend the index key from what it was passed (e.g. attribute 3) to whatever it likes. We will assume the purpose of this subroutine is to

JBase - User Guide - Release R15.000 - Page 184 of 629


test the attribute passed to it, and if it was a numeric, assume it is a date field and check the date is inside a range. If the date is okay, it passes
back attribute 3 . If not, it passes back a null string.

The use of the -n option means any null index keys will not be stored in the index data. Hence when used in conjunction with the subroutine,
it is a way of using a user-written subroutine to decide what records to put in the index data.

The use of by-ar further shows that all index keys (in this case non- null keys) will be stored in ascending right justified fashion, e.g. as a
numeric sort.

The use of the -lD option shows that when an enquiry is made of the index via query-index , key-select or the jQL commands such as LIST or
SELECT, then the string to search for will first of all be converted using an input conversion of type "D". This is primarily used so that these
commands can use date (or times) in external format (e.g. 23-jul-1970) but will be compared numerically as internal values against the index
data.

Appendix C – Universal Co-ordinated Time


A standard time and date format exists on many operating systems including Unix and Windows. This is called Universal Co-ordinated Time
and is the number of seconds since 00:00:00 January 1st 1970. Confusingly it appears to have been given the acronym UTC (instead of UCT
as you might expect).

Within a jBASE application the normal convention adopted by jBASE , for the purposes of legacy code compatibility, is that times are stored as
seconds past 00:00:00 and dates stored as the number of days since 31st December 1967.

The way to convert from UTC to jBASE time and dates and vice-versa can be demonstrated by the following code segment

*
* Convert a UTC value to a displayable time and date
*
UTC = 866558733
internal.date = INT(UTC/86400)+732
internal.time = MOD(UTC,86400)
CRT "Date = ":OCONV(internal.date,"D")
CRT "Time = ":OCONV(internal.time,"MTS")
*
* Convert internal time and date to UTC
*
UTC2 = (DATE()-732)*86400 + TIME()
CRT "UTC2 = ":UTC2

One important aspect to remember is that the UTC is often in the base time of the operating system without any time zone applied. For
example on Unix systems you set the time and date of your system in UTC but then individual accounts may have different time zones applied.
Thus if you create an index at what appears to be a time of say 10:40:29 then this could actually be a time of 11:40:29 but with a time zone of
minus one hour applied.

JBase - User Guide - Release R15.000 - Page 185 of 629


jBASE Internationalisation

l Introduction
l Overview
l The Development Challenges
l The Development Approaches
l Internationalization and Localization
l The Process of Internationalizing
l The Process of Localizing
l Code Pages
l Locales
l Unicode
l International Components for Unicode (ICU)
l jBASE, Internationalization and UTF-8
l jBASE Internationalization Configuration
l jBASE Code Page Configuration
l jBASE Locale Configuration
l jBASE Timezone Configuration
l jBASE Function Changes for International Mode
l jBASE JQL Changes for International Mode
l jBASE File Conversion
l JBASE Error Message Files
l jBASE Spooling and Printing
l Potential Performance Issues
l The Future and UTF-8
l Summary
l Appendices

JBase - User Guide - Release R15.000 - Page 186 of 629


Introduction

The release of jBASE 4.1 incorporates modifications to the underlying jBASE library functions and components to provide the tools and mech-
anisms whereby global communities can internationalize and localize applications. The internationalization functionality provides applications
with the capability for correct handling of locale dependent collation sequencing, along with processing of unique character properties, code
page data import/export and terminal/printer data input and output. The jBASE library functions when used in International Mode process
internally using character rather than byte orientated values and properties such that applications can be easily coded or converted by minimum
change for the international market.

JBase - User Guide - Release R15.000 - Page 187 of 629


Overview

More applications are crossing international and cultural boundaries, which require localization to provide support for the local language of the
user. Internationalization is the development of software for localized user communities without the need to change the executable code.

Fundamentally, computers deal with numbers. They store letters and other characters by assigning a number for each one. Before the invention
Unicode, there were hundreds of different encoding systems for assigning these numbers. No single encoding could contain enough characters:
for example, the European Union alone requires several different encodings to cover all languages. Even for a single language like English, no
single encoding was adequate for all the letters, punctuation, and technical symbols in common use. 

These encoding systems also conflict with one another. That is, two encodings can use the same number for two different characters, or use dif-
ferent numbers for the same character. Any given computer may need to support many different encodings; yet, whenever passing data between
different encodings or platforms, that data always runs the risk of character corruption from incorrect or incompatible conversion.

Internationalizing allows applications to:

l Provide applications for global markets


l Interface to internationalized processes
l Increase portability
l Reduce development costs

What needs to be internationalized?

l Terminal and File I/O


l Dates / Times
l Numbers / Currency
l Searching / Sorting
l Messages / Properties

How to go about internationalizing an application:

l Separate Executable Code from User Interface


l Handle Numbers, Currency, Dates and Times independently of formatting
l Provide for Text Input and Layout
l Allow for Alphabetical Order of Characters
l Allow for Character Format
l Avoid Cultural Assumptions

JBase - User Guide - Release R15.000 - Page 188 of 629


The Development Challenges

As different countries use different characters to represent words, some basic problems arise in the context of software development when con-
sidering the global market. Here follows some common problems developers need to consider:

l The basic concern is that there are more than 256 characters in the world. Languages such as Cyrillic, Hebrew, Arabic, Chinese, Japan-
ese, Korean, and Thai use characters that are not included in the 256-character ASCII set; but somehow, these characters must be
made available.
l It is impossible to store text from different character sets in the same document/record: if each document has its own character set,
manual intervention for conversion becomes inevitable.
l The introduction of new characters, such as Euro symbols must be accounted for. The Euro is replacing old European currency sym-
bols; documents containing these symbols have now changed.

How can applications interchange data that may include one or more character sets? The solution is to adopt a worldwide usable character set
and use a well-conceived strategy that incorporates that character set to produce software products.

JBase - User Guide - Release R15.000 - Page 189 of 629


The Development Approaches

Companies often develop a first version of a program or system to just deal with English. Later, when it becomes necessary to produce the first
international version, the product is ‘internationalized’ by going through all the lines of code, translating the literal strings.

The process is time consuming and is not a good long-term strategy. Each new version is expensive, as the painstaking process to identify all
the strings, which require translation is repetitive. Because there are multiple versions of the source code, maintenance and support becomes
very expensive. Moreover, there is a high probability that a translator may introduce bugs by mistakenly modifying code.

The fundamental advantage of internationalizing software is that the developer is not limited to the number of different languages or countries
that you can support. If, after developing the internationalized product and you need to provide the software in another language, it is simply a
matter of translating resource files into that language.

By truly internationalizing the product, the software developer is able to:

l Provide applications to global markets;


l Interoperate with external processes;
l Increase systems portability; and
l Reduce development costs.

For applications that will only use the standard ASCII characters, internationalization is not a vital concern. However, for those applications
that need to handle characters outside the ASCII range, internationalization is the best medium- and long-range development solution.

JBase - User Guide - Release R15.000 - Page 190 of 629


Internationalization and Localization

Internationalization is the process of producing a globalized product, in terms of both the design and the code, which is independent of the lan-
guage, script, and culture.

The design of Internationalized products is to support any language, script, culture, and code pages, through the localization process, with min-
imal expense and effort. The localization of an internationalized product is possible without any code change, merely by translating text and per-
haps supplying new graphics.

When internationalizing a software product, the goal is to develop software independently of the countries or languages of its intended users.
The translated software is ready for multiple countries or regions. This completes and reduces the Localization time as the process of inter-
nationalization through eliminating the need to examine the source code in order to translate the displayed user strings; it translates the
resource files containing the display strings.

JBase - User Guide - Release R15.000 - Page 191 of 629


The Process of Internationalizing

The overriding goal of internationalizing programs is to prepare and ensure the code never needs modification; separate files contain the trans-
latable information. This process involves a number of modifications to the code:

l Move all translatable strings into separate files called resource files, and make the code access those strings when needed. These
resource files are completely separate from the main code, and contain nothing but the translatable data.
l Change variable formatting to be language-independent.
l Change sorting, searching, and other types of processing to be language-independent. This means that dates, times, numbers, cur-
rencies, and messages call functions to format according to local language and country requirements.

Concluding the process gives you an internationalized product.

JBase - User Guide - Release R15.000 - Page 192 of 629


The Process of Localizing

Localization is the process of adapting an internationalized offering to a specific language, script, and culture. A localized product is one that is
fully adapted to a country's language and cultural conventions, such as currency, number formats, sorting sequence, and so on.

Localizing an internationalized program involves no changes to the source. Instead, contractors and/or translation agencies modify the files.

The initial cost of producing internationalized code is somewhat higher than localizing to a single market, but the advantage is that you only
pay that cost once. The cost of doing an additional localization, once the code is internationalized, is a fraction of the previous cost, and avoids
the considerable cost of maintenance and source code control for multiple code versions.

JBase - User Guide - Release R15.000 - Page 193 of 629


Code Pages

The term ‘code page’ refers to any of the many different schemas and standards used to represent character sets for various languages. Unicode
has combined the various code pages into the Unicode Standard (which is equivalent to ISO 10646).

Examples of languages and their corresponding code pages:

English:                                      ASCII

French, German: Latin1, Windows1252

Cyrillic:                                      Latin5, Windows1251

Chinese, Japanese, Korean, and Vietnamese:  CJKV, Win950, Win932, Win949, Win1258

JBase - User Guide - Release R15.000 - Page 194 of 629


Locales

From a geographical perspective, a locale is a place. From a software perspective, a locale is a set of information associated with a place. The loc-
ale information includes the name and identifier of the spoken language, sorting and collating requirements, currency usage, numeric display
preferences, and text directionality (left-to-right or right-to-left, horizontal or vertical).

Up to three different parts reference specified locales:

l Language code
l Country Code
l Variant Code

Depending on the locale, you can specify

l Only the language code,


l The language code and country code
l Or the language code, country code and variant.

Each locale specifies a resource bundle of localized text, for example:

l  fr_FR_EURO

The ‘fr’ is the French language code, the ‘FR’ is the country code; the EURO signifies the use of euro currency.

JBase - User Guide - Release R15.000 - Page 195 of 629


Unicode

Unicode is a single-coded character set providing a repertoire for all the languages of the world. Its first version used 16-bit numbers, which
allowed encoding for 65,536 characters; further development allowed a repertoire of more than one million characters, requiring 21 bits. Higher
bits have been declared unusable to ensure interoperability between UTF encoding schemes; UTF16 cannot encode any code points above this
limit. The handling of values above 16 bits is by two 16-bit codes.

l The first Unicode version used 16 bits, which allowed for encoding 65,536 characters.
l Further extended to 32 bits, although restricted to 21 bits to ensure interoperability between UTF encoding schemes.
l Unicode provides a repertoire of more than one million characters.

The 16-bit subset of UCS (Universe Character Set) is known as the Basic Multilingual Plan (BMP) or Plane 0.

Unicode provides a unique number for every character, on every platform, for every program, no matter what the language. Standards such as
XML, Java, ECMAScript (JavaScript), LDAP, CORBA 3.0, WML, etc., requires Unicode and is the official way to implement ISO/IEC 10646;
supported in many operating systems, all modern browsers, and many other products.

Incorporating Unicode into client-server or multi-tiered applications and websites can offer significant cost savings over the use of legacy char-
acter sets. Unicode enables a single software product or a single website to be targeted across multiple platforms, languages and countries
without re-engineering, and allows data to be transported through many different systems without corruption.

Unicode Combining/Composite Characters


Some code points have been assigned to combining characters. A combining character is not a full character by itself; rather, it is an accent or
other diacritical mark added to the previous character. This makes it possible to add an accent or other on any character. This capability is par-
ticularly important for scientific notation in mathematics.

Unicode Expanding and Contracting Characters


Some languages treat certain single characters as two separate characters for collating purposes (expanding), whereas some languages also treat
two characters as a single character when collating (contracting).

Contracting In Spanish sort order, ‘ch’ is considered a single letter. All words that begin with ‘ch’ sort after all other words beginning with ‘c’

Expanding In German, ä is equivalent to ‘ae,’ such that words beginning with ä sort between words starting with ‘ad’ and ‘af’.

Unicode Normalization
Normalization is the removal of ambiguities caused by precomposed and compatibility characters. There are four different forms of nor-
malization.

Form D................................. Split up (decompose) precomposed characters into combining sequences where possible.

Form C................................. Use precomposed instead of combining sequences where possible.

Form NFKD ........................ Like D but avoid use of compatibility characters (e.g., use ‘fi’ instead of U+FB01 LATIN SMALL LIGATURE FI).

Form NFKC......................... Like C but avoid use of compatibility characters.

Below is an example of Precomposed vs. Decomposed characters.

Precomposed     ü = U+00FC

Decomposed ü  = U+0075 + U+0308

Note: that UTF-8 encoding requires the use of precomposed characters wherever possible.

JBase - User Guide - Release R15.000 - Page 196 of 629


Unicode Universal Character Set and UTF-8
The Universal Character Set, UCS assigns each character not only a code number, but also an official name. A U+ precedes a hexadecimal num-
ber representing a Unicode Code Point or (e.g., U+0041 ‘Latin Capital Letter A’).

UTF-8 can represent all possible Unicode code points by byte sequences, which in turn represent different code points. The sequence used for
any given character depends on the Unicode number, which represents that particular character. The Universal Character Set has the following
properties:

l UCS U+0000 to U+007F is identical to US-ASCII (IISO 646 IRV).


l UCS U+0000 to U+00FF are identical to ISO-8859-1 (Latin-1)
l UCS U+E000 to U+F8FF is reserved for private use.

UTF-8 encoding is a Unicode Translation Format of Unicode. Before UTF-8 emerged, users all over the world had to use various language-spe-
cific extensions of ASCII. This made the exchange of files difficult, and application software had to consider small differences between these
encodings. Support for these encodings was usually incomplete and unsatisfactory, because the application developers rarely used all these
encodings themselves.

Unicode UTF-8 Properties


UTF-8 encoding avoids several problems inherent in other encoding systems:

l Files and strings that contain only 7-bit ASCII characters have identical encoding under ASCII and UTF-8.
l ASCII bytes 0x00-0x7F cannot appear as part of any other character.
l Allows easy resynchronization and makes the encoding stateless and guards against the possibility of missing bytes.
l Can encode all possible 231 UCS codes.
l UTF-8 encoded characters may theoretically be up to six bytes long, however 16-bit BMP characters are only up to three bytes long.
l The sorting order of Bigendian UCS-4 byte strings is preserved.
l It never uses the byte 0xFE and 0xFF in the UTF-8 encoding.
l UTF-8 is also much more compact than other encoding options, because characters in the range 0x00-0x7f still only use one byte.
l Use only the shortest possible multi byte sequence that can represent the code point of the character.
l In multi byte sequences, the number of leading one bit in the first byte is identical to the number of bytes in the entire sequence.
l Unicode represents a unique character by a unique 32-bit integer. Hence using UTF-8 encoding avoids problems, which would arise if
using 16 or 32 bit character byte streams, as the normal C string termination byte is a zero, thus byte streams could become pre-
maturely truncated.

JBase - User Guide - Release R15.000 - Page 197 of 629


International Components for Unicode (ICU)

International Components for Unicode (ICU) is IBM’s open source package for cross-platform Unicode library enablement for C/C++ products.
ICU provides functions for formatting numbers, dates, times, currencies according to locale conventions, and similarly, ICU provides code and
data to handle the complexities of native language collation, searching, and other processes. It also provides a mechanism for accessing strings
from resource files, whereby sharing common strings across countries that have the same language.

Perhaps the chief benefit of ICU is that it provides fully portable cross-platform libraries. Since the code is portable to a wide variety of plat-
forms, it is possible to share data formats that drive the code, at runtime, across different platforms.

JBASE has implemented additional functions that interface with the ICU API’s; for example, instead of using normal standard jBASE date con-
versions, it invokes the ICU date conversion procedures, thereby providing fully internationalized date formats.

JBase - User Guide - Release R15.000 - Page 198 of 629


jBASE, Internationalization and UTF-8

The code of jBASE 4.1 releases provides internationalization functionality, sometimes referred to ‘i18n’, (i followed by the 18 characters of nter-
nationalizatio followed by n). This enables applications to take advantage of the internationalization functionality and hence provide for the
global market, i.e. a fully internationalized application.

When configuring application accounts for international mode, all program variables and data records are to be of type UTF-8 handled internally
as UTF-8 encoded byte sequences. The UTF-8 encoding scheme manipulates characters other than those in the standard 7-bit ASCII range
(0x00-0x7f) as two-byte or three-byte sequences, rather than the normal single 8-bit byte.

The number of bytes in the UTF-8 sequence will depend on the original code page. For example, it encodes characters in the range 0x80-0xff,
representing the single byte character set ISO-8859-1, as two bytes. However, it represents characters imported from a Double Byte Character
Sequences (DBCS), such as Kanji characters from the Japanese code page “shift_jis”, as three bytes when encoded as a UTF-8 byte sequence.

When executing in international mode, all terminal input can be configured to be converted from the configured input code page to a UTF-8
byte sequence. Similarly, for terminal output, configure the UTF-8 byte sequences such that it converts the output to one of the output code
pages dependent upon the code page of the terminal device. Normally the input and output code pages would be the same. There is also an obvi-
ous advantage to skipping the conversion step and using UTF-8 direct where possible to communicate with terminal devices as these helps
reduce the conversion overhead from UTF-8 to the configured code page. Several telnet emulators now support a UTF-8 mode for telnet com-
munication.

UTF-8 is an ASCII preserving encoding of the ISO/IEC Unicode Standard 10646. Therefore, all ASCII characters remain the same and still use
a single byte of storage. This provides UTF-8 encoding with an advantage over other forms of Unicode encoding or translation formats. Some
forms would require either a doubling (UTF-16, UCS2) or quadrupling (UTF-32, UCS4) of byte space required to represent the Unicode Code
Point; however with UTF-8 encoding, only the characters over and above the ASCII 7 bit range need to be stored as multi bytes.

JBase - User Guide - Release R15.000 - Page 199 of 629


jBASE Internationalization Configuration

JBASE 4.1 provides internationalization support code page conversion, collation sequences, international dates and times along with number
and currency formatting. The basis of the internationalization configuration is on user id and/or certain jBASE environment variables:

l JBASE_CODEPAGE,
l JBASE_LOCALE,
l JBASE_TIMEZONE.

NOTE: The user id configuration or environment variables have no effect if the account in which it executes the application is not configured for
international mode or the environment variable JBASE_I18N is not set.

Application providers are responsible for the handling of all directionality issues, such as left-to-right, top-to-bottom orientation. The jBASE
library functions such as length (LEN); string comparisons (LT, LE, GT, GE) and collation order statements like (LOCATE/SORT) have all
been modified to operate on a character basis in international mode rather than bytes, along with the currently configured user locale.

JBase - User Guide - Release R15.000 - Page 200 of 629


jBASE Code Page Configuration

Configure the Code pages for the user id using the JBASE_CODEPAGE environment variable. Display a full list of available code pages  using
the “jcodepages” command.

All input and output conversion can be undertaken, however it is more efficient to use UTF-8 for input and output if possible, as no code page
conversion is then necessary, reducing system resource requirements. There are several commercially available telnet clients that can com-
municate using UTF-8, in these cases the telnet client performs the conversion from the configured code page to UTF-8, hence it is important
to ensure that the client is configured correctly such that the input and output code page is the correct one for the keyboard mapping required.

Code page conversion is only applicable when the JBASE_I18N environment variable is set.  If the JBASE_ I18N environment is not set, then
code page conversion will not occur, and all variables will be handled as bytes rather than as characters. As configuration of international mode
is on an account basis the state of international mode can change on execution of a LOGTO.

JBase - User Guide - Release R15.000 - Page 201 of 629


jBASE Locale Configuration

Locales can be configured for the user id via the JBASE_LOCALE environment variable. Display a full list of available locales from the com-
mand line by the “jlocales” command.

Configured locales are only applicable when executing an application in international mode or the JBASE_ I18N environment variable is con-
figured. The locale is based on the underlying OS locale configuration and the configured locale for the user id has no effect.

As configuration of the international mode is on an account basis, the state of international mode can change on execution of a LOGTO. If con-
figuring an account with international mode ‘false’ then the JBASE_I18N environment variable will be unset as the result of the LOGTO.

JBase - User Guide - Release R15.000 - Page 202 of 629


jBASE Timezone Configuration

Timezones can be configured for the user id via the JBASE_TIMEZONE environment variable. Display a full list of available Timezones from
the command line by the “jtimezones” command.

Configured Timezones are only applicable when executing an application in international mode or when the JBASE_I18N environment variable
is configured. If  the JBASE_I18N, environment variable is not set, the timezone is based on the underlying OS timezone configuration and the
configured timezone for the user id has no effect. As configuration, the international mode on an account basis the state of international mode
can change on execution of a LOGTO. If configuring an account with international mode ‘false’ then the JBASE_I18N environment variable will
be unset as the result of the LOGTO.

JBase - User Guide - Release R15.000 - Page 203 of 629


jBASE Function Changes for International Mode

Internally, very few of the jBASE library functions need changing to process data as UTF-8 encoded multi byte sequences rather than single
bytes. It bases resultant values on characters rather than bytes. Some functions change their internal workings depending upon the state of
international mode or JBASE_I18N setting.

Character vs. Bytes


LEN, SUBSTRINGS, X[n,m], INDEX

In international mode, length and sub string extraction works in ‘characters’ not ‘bytes’. Resultant positions are character positions not byte off-
set.

BYTELEN

A new function has been provided to obtain the actual number of bytes rather than characters. For example:

The following source code example contains UTF-8 encoded characters representing the German ‘u’ umlaut (0xC3 0xBC) and the double ‘s’
(0xC3 0x9F).

X = "Füßball";* String as UTF-8 sequence  "F.C3.BC.C3.9Fball"

CRT X

CRT "Character Length of X is ":LEN(X)

CRT "Byte Length of X is ":BYTELEN(X)

CRT "Substring[1,3] of X is ": X[1,3]

If executed in international mode and with the Input/Output Code Page configured to ISO-8859-1 (Latin1) this code will produce the following
output.

Note: The length returned by the LEN function is the number of characters in variable X, whereas the length returned by the BYTELEN
function is always the number of bytes in variable X.

Füßball

Character Length of X is 7

Byte Length of X is 9

Substring[1,3] of X is Füß

Character properties
UPCASE, DOWNCASE, ALPHA, MATCHES, MATCHFIELD

In International mode, functions use the configured locale to convert and/or test character properties.

For example:

The following source code example contains a UTF-8 encoded byte sequence representing the German ‘u’ umlaut (0xC3 0xBC).

 X = "ü"    ;* this string held in source as UTF-8 "C3.BC"

 CRT X: " becomes ": UPCASE(X)

 IF ALPHA(X) THEN CRT X: " is alphabetic "

 IF X MATCHES "1A" THEN CRT X: " is alphabetic "

If executing in international mode and with the Input/Output Code Page configured to ISO-8859-1 and with the locale configured for German
(de_DE) the code produces the following output.

JBase - User Guide - Release R15.000 - Page 204 of 629


ü becomes Ü

ü is alphabetic

ü is alphabetic

The UPCASE function converts the lower case u umlaut to the upper case equivalent. In other words, the UTF-8 byte sequence 0xC3 0xBC
becomes 0xC3 0x9C.

The ALPHA function tests the lower case u umlaut as an alphabetic character according to the configured locale, de_DE.

The MATCHES statement tests the lower case u umlaut against the single alphabetic character according to the configured locale, de_DE

Collation properties
SORT, LOCATE, COMPARE, LE, LT, GE, GT

In international mode, statements use the configured locale to determine sort order. For example:

A sort of the following UTF-8 encoded byte sequences using the SORT function will generate a different sort order depending on the configured
locale.

locale configured for ‘en_US’

cote                              stored as UTF-8 sequence ‘cote’

coté                              stored as UTF-8 sequence ‘cot.C3.A9’

côte                              stored as UTF-8 sequence ‘c.C3.B4te’

côté                              stored as UTF-8 sequence ‘c.C3.B4t.C3.A9’

locale configured for ‘fr_FR’ (reverse accented collation)

cote

côte

coté

côté

Note: that the word côte sorts BEFORE the word coté for the configured locale fr_FR

X = "côte" ;* Source contains UTF-8 sequence "c.C3.B4te"

Y = "coté"                ;* Source contains UTF-8 sequence "cot.C3.A9"

The statement :

IF X LT Y THEN CRT X:" is lower in collation sequence than ":Y

It produces the following output in International mode when executed with the locale configured for French, fr_FR.

côte is lower in collation than coté

Conversion properties
ICONV, OCONV, FMT

The implementation of conversions is by a set of jBASE library functions, which in turn invoke functions in the IBM Public License package,
ICU. This package provides cross-platform open source libraries compliant with Unicode Standard 3.0 and currently supports over 170 locales
independently of the system locales. Several input and output conversions become dependent upon the configured locale.

For example, then following source code example will output a different date format dependent upon the configured locale when executing in
international mode.

CRT OCONV(0,"D2/")

CRT OCONV(0,"D")

This code will produce the following if executed in international mode with a configured German locale of ‘de_DE’.

JBase - User Guide - Release R15.000 - Page 205 of 629


31/12/67

31 DEZ 1967

However, some conversions can be used to ‘force’ an expected format regardless of locale, for instance the DE date format will always produce a
European date format. The DG format is a new Global date format for YYYYMMDD.

CRT OCONV(0,"D2/E") displays            31/12/67

CRT OCONV(0,”DG”) displays            19671231

Character functions
CHAR, SEQ

The CHAR and SEQ functions behaviour differently for international mode.

In international mode the CHAR function now provides for an extended numeric range to support 32 bit Unicode code point values. The CHAR
function will return a UTF-8 encoded byte sequence for the numeric range 128-247 (0x80-0xf7) and the range 256 and beyond, however
numeric values in the system delimiter range 248-255 (0xf8-0xff) will continue to return the normal single byte system delimiters characters.
The resultant characters for numeric values in the ASCII range 0-127 (0x00-0x7f) are unchanged.

In international mode, the SEQ function now accepts UTF-8 encoded byte sequences such that UTF-8 byte sequences representing characters
in the range 0-127 (0x00-0x7f), i.e. single byte characters return the normal ASCII numeric values. UTF-8 encoded byte sequences representing
characters in the range 128-255 (0x80-0xff) will return the ISO-8859-1 equivalent numeric value. System delimiter characters will return
numeric values in the range 248-255 (0xf8-0xff). Other UTF-8 encoded byte sequences will return the equivalent numeric value as specified by
the Unicode code point.

Additional Functions
BYTELEN, LATIN1, LENDP, UTF8

The provision of additional functions helps with programs that need to know the actual real byte length of a variable as well as conversion func-
tions for handling binary values. The conversion function should only be required when dealing with binary data, for example handling data to/-
from tape devices.

The BYTELEN function returns the number of actual bytes used for the string variable. Use this function whether executing in international
mode or not.

The LATIN1 function will convert a string variable from ISO-8859-1 to a UTF-8 encoded byte sequence. Use this function whether executing in
international mode or not.

The LENDP function will return the number of character display positions required in order to display the string variable. Use this function to
determine the display width of characters, for instance the null character has a display width of zero, where as some Japanese Kanji characters
require more than one display position. The LENDP function will change behaviour if used without international mode set true.

The UTF8 function will convert a string variable from UTF-8 encoded byte sequence to the ISO-8859-1 (binary) equivalent. Use this function
whether executing in international mode or not.

Timestamp Functions
TIMESTAMP, TIMDIFF, CHANGETIMESTAMP, MAKETIMESTAMP

LOCALDATE, LOCALTIME

The provision of additional functions assist with date and time internationalisation; these functions enable applications to obtain, convert and
process a ‘timestamp’. These functions are available regardless of current state of international mode.

The TIMESTAMP functions returns a timestamp of Universal Coordinated Time, UTC as decimal seconds.

The TIMEDIFF functions returns the interval between two timestamps.

The CHANGETIMESTAMP function generates a new timestamp by adjusting the supplied timestamp by a dynamic array, which specifies the
adjustment values.

The MAKETIMESTAMP function generates a timestamp using a specified time zone.

The LOCALTIME function generates an internal time value using a supplied timestamp and time zone.

JBase - User Guide - Release R15.000 - Page 206 of 629


The LOCALDATE function generates an internal date value using a supplied timestamp and time zone.

Byte Count Functions


READBLK, WRITEBLK, OSBREAD, OSBWRITE

The prime target of the statements READBLK and WRITEBLK are at device access and hence use a block size or byte count. It is normal for
device formats to use binary values to describe the contents of the data blocks regardless of the underlying structure. As such, these state-
ments continue to work on a byte rather than character basis whether used with international mode set true or not.

If the requirement is to read/write large files, use instead the READSEQ/WRITESEQ commands. In the default configuration the READSEQ
and WRITESEQ statements read/write a line at a time such one a line from the file has been read into a variable, that variable can be used on a
character basis rather than bytes. This assumes that the data in the file is UTF-8 encoded. If the data in the file is not UTF-8 encoded, but ISO-
8859-1 (binary) then convert the data to UTF-8 using the UTF8 function.

Note: If using IOCTL commands to suppress one line at a time mode for the READSEQ or WRITESEQ, operates these statements only in
byte mode, and not character mode

JBase - User Guide - Release R15.000 - Page 207 of 629


jBASE JQL Changes for International Mode

Modification of the jBASE jQL Processor in several areas provides full Internationalization capabilities.

jQL Dictionary Conversions and Correlatives


For dates and times, it applies simple date format functions to use the configured locale to support the standard conversions D and MTS. For-
matting numbers via MR/ML/MD, use locale for Thousands, Decimal Point and Currency notation.

TimeStamp "W{Dx}{Tx}"

In addition, it includes a provided suite of conversions including A, F and I-types for timestamp functionality. This is such that it displays a gen-
erated timestamp for date and/or time in short, long, and full formats. These conversions also support non-Gregorian locales. The meaning of
the components of the conversion is as follows:

W        - Is a new conversion code so not to clash with existing conversions.

D         - Date

T          - Time

x          - Format option: S = Short, M = Medium, L = Long, F = Full

"WDS" or "WTS" SHORT is completely numeric.12/13/52 or 3:30pm

"WDM"              MEDIUM is longer.               Jan 12, 1952

"WDL" or  "WTL" LONG is longer.                   January 12, 1952 or 3:30:32pm

"WDF" or  "WTF" completely specifies FULL.      

jQL Locale-Based Collation


As a part of the internationalization of jBASE, jQL will now use collation tables, when enabled for international mode, that are specific for the
user’s locale.

When international mode is not enabled, the keys are sorted by the binary value of the individual characters as in prior releases.

When international mode is enabled, the keys are first passed to a lookup algorithm that converts the key into a collation key, which is tailored
specifically for the user’s language. Using the collation key, the sort processor is able to produce output in the order expected in the user’s loc-
ale.

jQL Right Justified Sort


The primary purpose of right justified attribute definitions is to produce the correct sort sequence and display properties for numeric values;
use also for mixed alpha and numeric fields to produce a meaningful sort order.

The use of right justified fields with completely non-numeric data does not affect sort order, just the display.

As part of the internationalization of jBASE, jQL uses a new algorithm for right justified fields designed to provide optimal sorting of mixed
alpha and numeric fields as well as numeric fields. The field width specified in the attribute definition no longer affects the behaviour of the
sort.

Pure Numeric keys


It sorts Keys from the largest negative number to the largest positive number.

A single leading minus or plus sign may be present, which ignores leading zeros before a decimal point for sorting purposes. It ignores trailing
zeros after a decimal point for sorting purposes. Nulls will sort either before all numeric keys or as zero, depending on emulation option. If
international mode is true, the defined characters in the Unicode 3.0 specification (section 4.6) to be decimal digits are sorted as numbers.

JBase - User Guide - Release R15.000 - Page 208 of 629


Mixed Alpha Numeric Sorting
The goal here is to produce a meaningful sort order of a field of mixed alpha and numeric data, for example, a field containing a suppliers’ part
number.

In this format and content, the field is unknown and can be expected to contain alpha, alphanumeric, and pure numeric values. Each candidate
key is split into parts, alternating between numeric and non-numeric parts. Sign characters are only valid as the first character of the key, else-
where they are treated as non-numeric. If the part is numeric then it processes that part in the same manner as a pure numeric key above. If
international mode is true, it passes non-numeric parts through the collation algorithm to produce collation key parts. If international mode is
false, it sorts the non-numeric parts left to right.

Data Conversion
When executing programs in international mode, it processes all variable contents as UTF-8 encoded sequences. As such all data must be held
as UTF-8 encoded byte sequences. This means that data imported into an Account configured to operate in international mode must be con-
verted from the data’s current code page to UTF-8. Normally if ALL the data are 8 bit bytes in the range 0x00-0x7f (ASCII) then no conversion
is necessary as these values are effectively already UTF-8 encoded. However values outside of the 0x00-0x7f range must be converted into
UTF-8 proper such that there can be no ambiguity between character set code page values.

For instance, the character represented by the hex value 0xE0 in the Latin2 code page, (ISO-8859-2), is described as "LATIN SMALL LETTER
R WITH ACUTE". However the same hex value in the Latin1 code page, (ISO-8859-1), is used to represent the character "LATIN SMALL
LETTER A WITH GRAVE".

To avoid this clash of code pages the Unicode specification provides unique hex value representations for both of these characters within the
specifications 32-bit value sequence.

EXAMPLE
l Unicode value 0x00E0 used to represent LATIN SMALL LETTER A WITH GRAVE
l Unicode value 0x0155 used to represent LATIN SMALL LETTER R WITH ACUTE

Note : UTF-8 is an encoding of 32 bit Unicode values, which also has ‘special’ properties (as described earlier), which Unix and Windows
platforms can use effectively.

Another good reason for complete conversion from the original code page to UTF-8 is that doing so also removes the requirement for ‘on the
fly’ conversions when reading/writing to files, as this would add massive and unnecessary overhead to ALL application processing, whereas the
conversion from original code page to UTF-8 is a ‘one off’ cost.

JBase - User Guide - Release R15.000 - Page 209 of 629


jBASE File Conversion

The first requirement before configuring an account and application for international mode is to convert the file data from the original code page
into UTF-8 encoded byte sequences.

Compiler
You must convert all source files containing characters in the range 0x80 thru 0x255 such that these characters are represented in UTF-8
before compiling.

Conversion Utility
A conversion tool ‘jutf8’ has been provided to help with the file conversion. The first would be to restore the data in the normal way using a
restore process working in binary mode. Once the files have been restored, use the following utility with the imported data files to convert the
data. The syntax of the conversion utility is as follows:

jutf8 {-options} {filename {,...} }

Where options can be:

c The code page to use for conversion, default latin1

d Process directories

f Force mode, skip prompt for confirmation

-m MapFilePath Use specified map file for conversion

-s Skip sample testing for file already converted

-u Convert from UTF-8 to code page, i.e., reverse conversion

-v Verbose mode

The conversion utility, by default, will attempt to confirm that the data is not already converted into UTF-8. Directories are skipped by default
unless the –d option is explicitly specified.

Note: The conversion of file contents containing binary data such as compiled programs may render the compiled object no longer usable.
It is recommended that the files be cleared of program object files before use of the utility on source files.

Conversion Map
Use the MapFilePath option to specify a file that describes the mapping of certain characters, e.g., system delimiters, from and to the required
hex value.

The map file describes how characters in the original file should be ‘mapped’ from their current hex value to the required hex value BEFORE con-
version to UTF-8 proper. The example below maps any characters in the range 0x01-0x08 into what would normally be system delimiters
before conversion to UTF-8. Therefore, character 0x04 is mapped to 0xFC and then converted to the two-byte UTF-8 encoded sequence 0xC4
0xBC, which does not clash with the system delimiter and which in turn represents the 32-bit Unicode value of 0x00FC.

MyMapFile

#From              To

0x01                0xFF

0x02                0xFE

JBase - User Guide - Release R15.000 - Page 210 of 629


0x03                0xFD

0x04                0xFC

0x05                0xFB

0x06                0xFA

0x07                0xF9

0x08                0xF8

Note: If the map file is specified along with the ‘u’ option then it reverses mapping from/to.

Data Import and Export


The jBASE Directory and SEQ drivers have been modified to provide for an additional IOCTL command, which provides for data conversion
from a specified code page to UTF-8 when reading from the native operating system file. This command can also be used when writing to the
native file such that the data is converted from UTF-8 to the configured code page. This IOCTL has been specifically developed for Import
and/or Export of data to external applications and is not recommended for usage as part of an application for ‘on the fly’ conversion. You can
also use this IOCTL with the READSEQ and WRITESEQ statements.

Below is an example of using the IOCTL to convert data in a UNIX directory file from ‘shift_jis’, Japanese, to UTF-8 while reading the record
from the native file. The record is then written out (without conversion) to a jBASE Hash File. This IOCTL command will also return the pre-
viously configured Code Page for the File Descriptor. Note: hash files do not support this additional IOCTL command.

* Convert directory record from CodePage shift-jis to UTF-8 and place into Hash file

INCLUDE JBC.h

OPEN 'MYDIRECTORY.' TO FILE ELSE STOP

OPEN 'MYHASHFILE' TO HASHFILE ELSE STOP

* Setup Code Page for IOCTL command

CodePage ="shift-jis"

IF IOCTL(FILE,JIOCTL_COMMAND_SETCODEPAGE,CodePage) ELSE

CRT "Code page problem" ; STOP

END

IF CodePage NE "" THEN CRT "Previously configured Code Page : ":CodePage

* Read and convert record from code page shift-jis to UTF-8

READ Record FROM FILE,"MyCodePage" THEN

CRT "No Chars ":LEN(Record), "No Bytes ":BYTELEN(Record)

WRITE Record ON HASHFILE,"MyUTF8"

END

JBase - User Guide - Release R15.000 - Page 211 of 629


JBASE Error Message Files

When executing in international mode, error messages files use the configured locale such that it generates de-nationalized error message files
used in place of the default error message file.

The detection of the correct error message file for the locale works on the basis that if the error message for the full locale specification, i.e., it
cannot open LanguageCode_CountryCode_ Variant, and the process defaults to use the LanguageCode_ContryCode. If this still fails, it only
uses LanguageCode until ultimately it uses no part of the locale to detect the error message file.

For instance, if configuring a user for the locale ‘fr_FR_EURO’ then any error messages for processing are initially searched for in the "jbcmes-
sages_fr_FR_EURO" file.

If this file cannot be opened, the process will attempt to open "jbcmessages_fr_FR". Similarly, if this file is not available, the process will then
attempt to open "jbcmessages_fr". If the open still fails, it uses the default error message file "jbcmessages".

JBase - User Guide - Release R15.000 - Page 212 of 629


jBASE Spooling and Printing

Spooling
The jBASE spooler files will hold the created spooler jobs as UTF-8 encoded byte sequences only if generated by a program executing in inter-
national mode. i.e, as per the Account definition. Else, it creates spooler jobs in the normal Latin1 (ISO-8859-1) code page as previously.

Printing
You can configure a new parameter, CODEPAGE, in the FORM TYPE configuration file in the jBASE release sub directory ‘config’, (see jsp-
form_deflt), to specify a code page to use for conversion when despooling the print job. The syntax of the parameter is as follows:

CODEPAGE codepage      

Where “codepage” is the name of the code page to use, such that the print job is converted from the internal format of UTF-8 encoded byte
sequences to the required code page for the printer device. For example:

CODEPAGE shift-jis

This code page parameter will convert the UTF-8 byte sequence in the print job to shift-jis for Japanese.

Note : the internal format MUST always be UTF-8 if using CODEPAGE parameters; otherwise, fatal conversion errors can occur. If the
CODEPAGE parameter is not specified, output will be not be converted, hence if the spool job was generated by a process executing in
international mode, then output will be in UTF-8, otherwise if the job was generated by a process executing in normal mode, output will
be in ISO-8859-1 (latin1).

Whenever possible, printers should be configured to support UTF-8, so that code page conversion is not necessary, thereby further reducing
unnecessary conversion overheads on the system.

JBase - User Guide - Release R15.000 - Page 213 of 629


Potential Performance Issues

By operating in international mode, it is inevitable that certain functions will suffer in terms of application performance:

l LEN: must now scan variables counting characters, not simply return the number of bytes
l LOCATE: must use the locale for the sort order
l SORT/COMPARE: must use the locale for the sort/compare order
l MATCHES/MATCHFIELD: must determine if characters are numeric, alpha, etc via locale
l ICONV/OCONV: date, time and currency conversions all use the locale
l ALPHA, ISPRINT: properties must be based on the locale
l INPUT/PRINT: code page conversion to and from UTF-8

Normally, the LEN function returns the current byte length of the array, which is always kept up-to-date as the array increases or decreases in
size. In international mode, the LEN function must return the number of characters rather than the number of bytes in the array. As a result,
the array must be traversed in order to count the characters, causing a decrease in performance.

LOCATE usually compares strings directly, without regard for locale. In international mode, however, the locale is used during comparison.
The same holds true for MATCHES, MATCHFIELD, SORT, COMPARE and property tests, since variables must first be converted to Unicode.

If international mode is enabled, conversion between code pages is required for Terminal I/O; however, this is a relatively slow operation.
Whenever possible, it is ideal to use terminal emulators etc., which are capable of sending and receiving UTF-8, such that no code page con-
version is necessary, thereby reducing the CPU overhead of conversion.

As all strings must be converted to UTF-8 encoding before compile time, and all read/write data is all presumed to be UTF-8 encoded, there
should be no overhead to other functions, except as mentioned above or when functions are working on a character basis, e.g., substring extrac-
tion.

If an account is not configured for international mode, the overhead is a simple bit test in a few functions.

Desktop Applications
Desktop applications vary in their Unicode support, and as a result, have limited internalization support:

l Limited Interfaces in Win98/ME


l VB 6 (Unicode is only supported on NT/Win2000)
l Microsoft Office 32 bit supports Unicode.
l 32-bit COM only supports Unicode.
l OLE DB, ODBC, ADO, RDO all COM components
l Java handles everything as Unicode

JBase - User Guide - Release R15.000 - Page 214 of 629


The Future and UTF-8

The industry is converging on UTF-8 and Unicode for all internationalization. Microsoft NT is built on a base of Unicode; AIX, Sun, HP/UX all
offer Unicode support. All the new web standards, such as HTML, XML, etc., support Unicode. The latest versions of Netscape Navigator and
Internet Explorer both support Unicode.  UNIX support for Unicode for directory names is provided via UTF-8.

Because of these difficulties, the major Unix distributors and developers foresee Unicode eventually replacing older legacy encodings, primarily
in the UTF-8 form.

UTF-8 will more than likely be used exclusively in:

l Text files (source code, HTML files, email messages, etc.)


l File names
l Standard input and standard output, pipes
l Environment variables
l Cut and paste selection buffers
l Telnet, modem, and serial port connections to terminal emulators; and
l Any other places where byte sequences used to be interpreted in ASCII.
l For example, terminal emulators such as xterm or the Linux console driver transform every keystroke into the corresponding UTF-8
sequence and send it to the stdin of the foreground process.

JBase - User Guide - Release R15.000 - Page 215 of 629


Summary

If it is certain that an application will only ever use ASCII characters, internationalization may be not necessary.  However, with UTF-8 all
ASCII characters stay the same.  On the other hand, if providing an application to any additional markets is a possibility, you should carefully
consider internationalization as a development process. 

It is best to consider internationalization impacts early in the development of software products preferably before it is fully developed as sig-
nificant application changes will be necessary, particularly if the product will be made available to the Asian market. Far more than simply trans-
lating literal strings, internationalization is a process that either can positively affect the quality and cost of development. 

It is true that internationalization can lessen the performance of some important functions in the finished software product. However, if provid-
ing your application to a global marketplace it is an important business priority, tremendous carefully considering and understanding the pro-
cess of internationalization will make gains in the development lifecycle and improved product quality.

JBase - User Guide - Release R15.000 - Page 216 of 629


APPENDICES

jBASE Environment Variables for Internationalization


Users can be configured for internationalization by setting the following environment variables.

JBASE_I18N

When the JBASE_I18N environment variable is set, the application is expecting to execute in International mode.

Note: That the value of this environment variable can be modified by a LOGTO command. The value of the JBASE_I18N variable will then
be set according to the true or false value for the account.

JBASE_CODEPAGE

You can only set the JBASE_CODEPAGE environment variable to a valid code page available with the ICU package. Use the jcodepages com-
mand for a list of currently available code pages. Conversion for input and output will only take place if configuring the account for international
mode or the JBASE_I18N variable is set.

JBASE_LOCALE

You can only set the JBASE_LOCALE environment variable to a valid locale available with the ICU package. Use the jlocales command for a
list of currently available locales. Only use the configured locale if the account is configured for international mode or the JBASE_I18N variable
is set.

JBASE_TIMEZONE

You can only set the JBASE_TIMEZONE environment variable to a valid time zone available with the ICU package. Use the jtimezones com-
mand for a list of currently available time zones. Only use the configured time zone if the account is configured for international mode or the
JBASE_I18N variable is set.

For example, the following environment variable configuration would configure a user for the French and the country locale specific for France
and the code page set for latin1, iso-8859-1.

JBASE_I18N=1

JBASE_CODEPAGE=iso-8859-1

JBASE_LOCALE=fr_FR

Unicode and ICU Reference Information


The following website contain useful information about the Unicode Standard and the IBM Open Source software package that has been imple-
mented with the jBASE 4.1 release.

http://www.unicode.org

http://oss.software.ibm.com/icu

Locale Definition
A Locale represents a specific geographical, political, or cultural region.

An operation that requires a Locale to perform its task is called locale-sensitive and uses the Locale to tailor information for the user. For
example, displaying a date is a locale-sensitive operation: format the date according to the customs/conventions of the user's native country,
region, or culture. 

The first argument to the constructors is a valid ISO Language Code. These codes are the lower-case two-letter codes as defined by ISO-
639.

http://www.ics.uci.edu/pub/ietf/http...ted/iso639.txt

JBase - User Guide - Release R15.000 - Page 217 of 629


The second argument to the constructors is a valid ISO Country Code. These codes are the upper-case two-letter codes as defined by ISO-
3166. 

http://www.chemie.fu-berlin.de/diver.../ISO_3166.html

The third constructor requires a third argument: the Variant. Use the Variant codes to further define the locale, e.g., European countries now
using the Euro use the variant code EURO.

Configured Locales
LanguageCode_CountryCode_Variant  (Available with ICU )

af af_ZA  ar ar_AE ar_BH ar_DZ

ar_EG ar_IQ ar_JO ar_KW ar_LB

ar_LY ar_MA ar_OM ar_QA ar_SA

ar_SD ar_SY ar_TN ar_YE

be be_BY bg bg_BG

ca ca_ES ca_ES_EURO cs cs_CZ

da da_DK de de_AT de_AT_EURO

de_CH de_DE de_DE_EURO de_LU de_LU_EURO

el el_GR en en_AU en_BE

en_BW en_CA en_GB en_IE en_IE_EURO

en_NZ en_SG en_US en_ZA en_ZW

eo es es_AR es_BO es_CL

es_CO es_CR es_DO es_EC es_ES

es_ES_EURO es_GT es_HN es_MX es_NI

es_PA es_PE es_PR es_PY es_SV

es_US es_UY es_VE et et_EE

eu eu_ES

fa fa_IR fi fi_FI fi_FI_EURO

fo fo_FO fr fr_BE fr_BE_EURO

fr_CA fr_CH fr_FR fr_FR_EURO fr_LU

fr_LU_EURO

ga ga_IE gl gl_ES gv

gv_GB

he he_IL hi hi_IN hr

hr_HR hu hu_HU

id id_ID is is_IS it

JBase - User Guide - Release R15.000 - Page 218 of 629


it_CH it_IT it_IT_EURO

ja ja_JP

kl kl_GL ko ko_KR kok

kok_IN kw kw_GB

lt lt_LT lv lv_LV

mk mk_MK mr mr_IN mt

mt_MT

nl nl_BE nl_BE_EURO nl_NL nl_NL_EURO

no no_NO no_NO_B no_NO_NY

pl pl_PL pt pt_BR pt_PT

pt_PT_EURO

ro ro_RO ru ru_RU ru_UA

sh sh_YU sk sk_SK sl

sl_SI sq sq_AL sr sr_YU

sv sv_FI sv_FI_AL sv_SE sw

sw_KE sw_TZ

ta ta_IN te te_IN th

th_TH tr tr_TR

uk uk_UA

vi vi_VN

zh zh_CN zh_HK zh_SG zh_TW

Language Codes (ISO-639)

aa         Afar ab        Abkhazian af         Afrikaans am        Amharic

ar         Arabic as         Assamese ay         Aymara az         Azerbaijani

ba        Bashkir be       Byelorussian bg       Bulgarian bh        Bihari

bi         Bislama bn        Bengali; Bangla bo        Tibetan br         Breton

ca         Catalan co        Corsican cs         Czech cy         Welsh

da        Danish de        German dz         Bhutani el          Greek

en         English eo        Esperanto es         Spanish et         Estonian

eu         Basque fa         Persian fi          Finnish fj          Fiji

fo         Faroese fr          French fy         Frisian ga         Irish

gd        Scots; Gaelic gl          Galician gn         Guarani gu         Gujarati

JBase - User Guide - Release R15.000 - Page 219 of 629


ha         Hausa he         Hebrew (formerly iw) hi          Hindi hr         Croatian

Hu        Hungarian hy         Armenian ia          Interlingua id         Indonesian (formerly


in)

Ie         Interlingue ik         Inupiak is          Icelandic it          Italian

iu          Inuktitut ja         Japanese jw        Javanese ka        Georgian

kk        Kazakh kl         Greenlandic km       Cambodian kn        Kannada

ko        Korean ks         Kashmiri ku        Kurdish ky        Kirghiz

la          Latin ln          Lingala lo         Laothian lt          Lithuanian

lv          Latvian; Lettish mg        Malagasy mi         Maori mk       Macedonian

Ml        Malayalam mn        Mongolian mo       Moldavian mr        Marathi

ms        Malay mt        Maltese my        Burmese na         Nauru

ne         Nepali nl          Dutch no        Norwegian oc        Occitan

om       (Afan) Oromo or         Oriya pa        Punjabi pl         Polish

ps         Pashto, Pushto pt         Portuguese qu Quechua rm        Rhaeto-Romance

rn         Kirundi ro         Romanian ru         Russian rw        Kinyarwanda

sa         Sanskrit sd         Sindhi sg         Sangho sh         Serbo-Croatian

si          Sinhalese sk         Slovak sl          Slovenian sm        Samoan

sn         Shona so         Somali sq         Albanian sr         Serbian

ss         Siswati st          Sesotho su         Sundanese sv         Swedish

sw        Swahili ta         Tamil te         Telugu tg         Tajik

th         Thai ti          Tigrinya tk         Turkmen tl          Tagalog

tn         Setswana to         Tonga tr          Turkish ts          Tsonga

tt          Tatar tw        Twi ug         Uighur uk        Ukrainian

ur         Urdu uz         Uzbek vi         Vietnamese vo        Volapuk

wo       Wolof xh         Xhosa yi          Yiddish (formerly ji) yo        Yoruba

za         Zhuang zh         Chinese zu         Zulu

Country Codes (ISO 3166)


Updated by the RIPE Network Coordination Centre, in coordination with the ISO 3166 Maintenance Agency, Berlin

Country A2 A3 Number

AFGHANISTAN AF AFG 004

ALBANIA AL ALB 008

ALGERIA DZ DZA 012

JBase - User Guide - Release R15.000 - Page 220 of 629


AMERICAN SAMOA AS ASM 016

ANDORRA AD AND 020

ANGOLA AO AGO 024

ANGUILLA AI AIA 660

ANTARCTICA AQ ATA 010

ANTIGUA AND BARBUDA AG ATG 028

ARGENTINA AR ARG 032

ARMENIA AM ARM 051

ARUBA AW ABW 533

AUSTRALIA AU AUS 036

AUSTRIA AT AUT 040

AZERBAIJAN AZ AZE 031

BAHAMAS BS BHS 044

BAHRAIN BH BHR 048

BANGLADESH BD BGD 050

BARBADOS BB BRB 052

BELARUS BY BLR 112

BELGIUM BE BEL 056

BELIZE BZ BLZ 084

BENIN BJ BEN 204

BERMUDA BM BMU 060

BHUTAN BT BTN 064

BOLIVIA BO BOL 068

BOSNIA AND HERZEGOWINA BA BIH 070

BOTSWANA BW BWA 072

BOUVET ISLAND BV BVT 074

BRAZIL BR BRA 076

BRITISH INDIAN OCEAN TERRITORY IO IOT 086

BRUNEI DARUSSALAM BN BRN 096

BULGARIA BG BGR 100

BURKINA FASO BF BFA 854

BURUNDI BI BDI 108

CAMBODIA KH KHM 116

JBase - User Guide - Release R15.000 - Page 221 of 629


CAMEROON CM CMR 120

CANADA CA CAN 124

CAPE VERDE CV CPV 132

CAYMAN ISLANDS KY CYM 136

CENTRAL AFRICAN REPUBLIC CF CAF 140

CHAD TD TCD 148

CHILE CL CHL 152

CHINA CN CHN 156

CHRISTMAS ISLAND CX CXR 162

COCOS (KEELING) ISLANDS CC CCK 166

COLOMBIA CO COL 170

COMOROS KM COM 174

CONGO CG COG 178

COOK ISLANDS CK COK 184

COSTA RICA CR CRI 188

COTE D'IVOIRE CI CIV 384

CROATIA (local name: Hrvatska) HR HRV 191

CUBA CU CUB 192

CYPRUS CY CYP 196

CZECH REPUBLIC CZ CZE 203

DENMARK DK DNK 208

DJIBOUTI DJ DJI 262

DOMINICA DM DMA 212

DOMINICAN REPUBLIC DO DOM 214

EAST TIMOR TP TMP 626

ECUADOR EC ECU 218

EGYPT EG EGY 818

EL SALVADOR SV SLV 222

EQUATORIAL GUINEA GQ GNQ 226

ERITREA ER ERI 232

ESTONIA EE EST 233

ETHIOPIA ET ETH 231

FALKLAND ISLANDS (MALVINAS) FK FLK 238

JBase - User Guide - Release R15.000 - Page 222 of 629


FAROE ISLANDS FO FRO 234

FIJI FJ FJI 242

FINLAND FI FIN 246

FRANCE FR FRA 250

FRANCE, METROPOLITAN FX FXX 249

FRENCH GUIANA GF GUF 254

FRENCH POLYNESIA PF PYF 258

FRENCH SOUTHERN TERRITORIES TF ATF 260

GABON GA GAB 266

GAMBIA GM GMB 270

GEORGIA GE GEO 268

GERMANY DE DEU 276

GHANA GH GHA 288

GIBRALTAR GI GIB 292

GREECE GR GRC 300

GREENLAND GL GRL 304

GRENADA GD GRD 308

GUADELOUPE GP GLP 312

GUAM GU GUM 316

GUATEMALA GT GTM 320

GUINEA GN GIN 324

GUINEA-BISSAU GW GNB 624

GUYANA GY GUY 328

HAITI HT HTI 332

HEARD AND MC DONALD ISLANDS HM HMD 334

HONDURAS HN HND 340

HONG KONG HK HKG 344

HUNGARY HU HUN 348

ICELAND IS ISL 352

INDIA IN IND 356

INDONESIA ID IDN 360

IRAN (ISLAMIC REPUBLIC OF) IR IRN 364

IRAQ IQ IRQ 368

JBase - User Guide - Release R15.000 - Page 223 of 629


IRELAND IE IRL 372

ISRAEL IL ISR 376

ITALY IT ITA 380

JAMAICA JM JAM 388

JAPAN JP JPN 392

JORDAN JO JOR 400

KAZAKHSTAN KZ KAZ 398

KENYA KE KEN 404

KIRIBATI KI KIR 296

KOREA, DEMOCRATIC PEOPLE'S REPUBLIC OF KP PRK 408

KOREA, REPUBLIC OF KR KOR 410

KUWAIT KW KWT 414

KYRGYZSTAN KG KGZ 417

LAO PEOPLE'S DEMOCRATIC REPUBLIC LA LAO 418

LATVIA LV LVA 428

LEBANON LB LBN 422

LESOTHO LS LSO 426

LIBERIA LR LBR 430

LIBYAN ARAB JAMAHIRIYA LY LBY 434

LIECHTENSTEIN LI LIE 438

LITHUANIA LT LTU 440

LUXEMBOURG LU LUX 442

MACAU MO MAC 446

MACEDONIA, THE FORMER YUGOSLAV REPUBLIC OF MK MKD 807

MADAGASCAR MG MDG 450

MALAWI MW MWI 454

MALAYSIA MY MYS 458

MALDIVES MV MDV 462

MALI ML MLI 466

MALTA MT MLT 470

MARSHALL ISLANDS MH MHL 584

MARTINIQUE MQ MTQ 474

MAURITANIA MR MRT 478

JBase - User Guide - Release R15.000 - Page 224 of 629


MAURITIUS MU MUS 480

MAYOTTE YT MYT 175

MEXICO MX MEX 484

MICRONESIA, FEDERATED STATES OF FM FSM 583

MOLDOVA, REPUBLIC OF MD MDA 498

MONACO MC MCO 492

MONGOLIA MN MNG 496

MONTSERRAT MS MSR 500

MOROCCO MA MAR 504

MOZAMBIQUE MZ MOZ 508

MYANMAR MM MMR 104

NAMIBIA NA NAM 516

NAURU NR NRU 520

NEPAL NP NPL 524

NETHERLANDS NL NLD 528

NETHERLANDS ANTILLES AN ANT 530

NEW CALEDONIA NC NCL 540

NEW ZEALAND NZ NZL 554

NICARAGUA NI NIC 558

NIGER NE NER 562

NIGERIA NG NGA 566

NIUE NU NIU 570

NORFOLK ISLAND NF NFK 574

NORTHERN MARIANA ISLANDS MP MNP 580

NORWAY NO NOR 578

OMAN OM OMN 512

PAKISTAN PK PAK 586

PALAU PW PLW 585

PANAMA PA PAN 591

PAPUA NEW GUINEA PG PNG 598

PARAGUAY PY PRY 600

PERU PE PER 604

PHILIPPINES PH PHL 608

JBase - User Guide - Release R15.000 - Page 225 of 629


PITCAIRN PN PCN 612

POLAND PL POL 616

PORTUGAL PT PRT 620

PUERTO RICO PR PRI 630

QATAR QA QAT 634

REUNION RE REU 638

ROMANIA RO ROM 642

RUSSIAN FEDERATION RU RUS 643

RWANDA RW RWA 646

SAINT KITTS AND NEVIS KN KNA 659

SAINT LUCIA LC LCA 662

SAINT VINCENT AND THE GRENADINES VC VCT 670

SAMOA WS WSM 882

SAN MARINO SM SMR 674

SAO TOME AND PRINCIPE ST STP 678

SAUDI ARABIA SA SAU 682

SENEGAL SN SEN 686

SEYCHELLES SC SYC 690

SIERRA LEONE SL SLE 694

SINGAPORE SG SGP 702

SLOVAKIA (Slovak Republic) SK SVK 703

SLOVENIA SI SVN 705

SOLOMON ISLANDS SB SLB 090

SOMALIA SO SOM 706

SOUTH AFRICA ZA ZAF 710

SOUTH GEORGIA AND THE SOUTH SANDWICH ISLANDS GS SGS 239

SPAIN ES ESP 724

SRI LANKA LK LKA 144

ST. HELENA SH SHN 654

ST. PIERRE AND MIQUELON PM SPM 666

SUDAN SD SDN 736

SURINAME SR SUR 740

SVALBARD AND JAN MAYEN ISLANDS SJ SJM 744

JBase - User Guide - Release R15.000 - Page 226 of 629


SWAZILAND SZ SWZ 748

SWEDEN SE SWE 752

SWITZERLAND CH CHE 756

SYRIAN ARAB REPUBLIC SY SYR 760

TAIWAN TW TWN 158

TAJIKISTAN TJ TJK 762

TANZANIA, UNITED REPUBLIC OF TZ TZA 834

THAILAND TH THA 764

TOGO TG TGO 768

TOKELAU TK TKL 772

TONGA TO TON 776

TRINIDAD AND TOBAGO TT TTO 780

TUNISIA TN TUN 788

TURKEY TR TUR 792

TURKMENISTAN TM TKM 795

TURKS AND CAICOS ISLANDS TC TCA 796

TUVALU TV TUV 798

UGANDA UG UGA 800

UKRAINE UA UKR 804

UNITED ARAB EMIRATES AE ARE 784

UNITED KINGDOM GB GBR 826

UNITED STATES US USA 840

UNITED STATES MINOR OUTLYING ISLANDS UM UMI 581

URUGUAY UY URY 858

UZBEKISTAN UZ UZB 860

VANUATU VU VUT 548

VATICAN CITY STATE (HOLY SEE) VA VAT 336

VENEZUELA VE VEN 862

VIET NAM VN VNM 704

VIRGIN ISLANDS (BRITISH) VG VGB 092

VIRGIN ISLANDS (U.S.) VI VIR 850

WALLIS AND FUTUNA ISLANDS WF WLF 876

WESTERN SAHARA EH ESH 732

JBase - User Guide - Release R15.000 - Page 227 of 629


YEMEN YE YEM 887

YUGOSLAVIA YU YUG 891

ZAIRE ZR ZAR 180

ZAMBIA ZM ZMB 894

ZIMBABWE ZW ZWE 716

Configured Code Pages and Aliases


When internationalizing applications it is necessary to ensure that data is correctly represented in the expected character set for the end user.
This requirement is usually dependent upon the code page capabilities of the input and output devices used. Eventually this should move more
and more to communicating solely in UTF-8, however for applications that deal with other character sets, this means that data must be con-
verted to and from UTF-8.

The ICU library package provides a comprehensive character set conversion framework, mapping tables, and implementations for many encod-
ings, including Unicode encodings. These mapping tables have mostly originated from the IBM code page repository. However, for non-IBM
code pages there is usually an equivalent code configured. However, the textual data format is generic, and data for other code page mapping
tables can be added. There is no single, authoritative source of precise definitions of many of the encodings and their names. However, IANA is
the best source for names, and the Character Set repository provided by ICU is a good source of encoding definitions for each platform.

UTF and ASCII Code Pages


Code Page : utf-8

Aliases       : cp1208, ibm-1208, utf-8, UTF8

Code Page : utf-16be

Aliases   : utf-16be, UTF16_BigEndian

Code Page : utf-16le

Aliases   : utf-16le, UTF16_LittleEndian

Code Page : ISO-10646-UCS-2

Aliases   : utf-16, ucs-2, cp1200, ibm-1200, utf-16, csUnicode, ISO-10646-UCS-2

Code Page : utf-32be

Aliases   : utf-32be, UTF32_BigEndian

Code Page : utf-32le

Aliases   : utf-32le, UTF32_LittleEndian

Code Page : ISO-10646-UCS-4

Aliases   : utf-32, ucs-4, utf-32, csUCS4, ISO-10646-UCS-4

Code Page : ANSI_X3.4-1968

Aliases : us-ascii, iso-ir-6, 646, csASCII, us, iso646-us, ISO_646.irv:1991, ANSI_X3.4-1986, ANSI_X3.4-1968, US-ASCII, ascii-7, ascii, us-
ascii, ibm-367

Latin Code Pages


Code Page : ISO_8859-1:1987

Aliases    : iso-8859-1, ANSI_X3.110-1983, l1, ISO_8859-1:1987, cp367, iso-ir-100, csisolatin1, 8859-1, latin1, cp819, ibm-819, iso-8859-1,
LATIN_1

Code Page : ISO_8859-2:1987

JBase - User Guide - Release R15.000 - Page 228 of 629


Aliases   : iso-8859-2, l2, ISO_8859-2:1987, iso-ir-101, csisolatin2, 8859-2, latin2, cp912, iso-8859-2, ibm-912

Code Page : ISO_8859-3:1988

Aliases   : iso-8859-3, l3, ISO_8859-3:1988, iso-ir-109, csisolatin3, 8859-3, cp913, latin3, iso-8859-3, ibm-913

Code Page : ISO_8859-4:1988

Aliases   : iso-8859-4, l4, ISO_8859-4:1988, iso-ir-110, csisolatin4, 8859-4, cp914, latin4, iso-8859-4, ibm-914

Code Page : ISO_8859-5:1988

Aliases   : iso-8859-5, ISO_8859-5:1988, iso-ir-144, csisolatincyrillic, 8859-5, cp915, cyrillic,  iso-8859-5, ibm-915

Code Page : ISO_8859-6:1987

Aliases   : iso-8859-6, asmo-708, ecma-114,ISO_8859-6:1987, iso-ir-127, csisolatinarabic, 8859-6, cp1089, arabic, iso-8859-6, ibm-1089

Code Page : ISO_8859-7:1987

Aliases   : iso-8859-7, ISO_8859-7:1987, iso-ir-126, csisolatingreek, 8859-7, ecma-118, elot_928, greek8, greek, iso-8859-7, cp813, ibm-4909

Code Page : ISO_8859-8:1988

Aliases   : iso-8859-8, ISO_8859-8:1988, iso-ir-138, csisolatinhebrew, 8859-8, cp916, hebrew, iso-8859-8, ibm-916

Code Page : ISO_8859-9:1989

Aliases   : iso-8859-9, l5, ISO_8859-9:1989, iso-ir-148, csisolatin5, 8859-9, cp920, latin5, ECMA-128,  iso-8859-9, ibm-920

Code Page : iso-8859-15

Aliases   : csisolatin9, csisolatin0, latin0, 8859-15, cp923, latin9, iso-8859-15, ibm-923

Mircosoft Windows Code Pages


Code Page : windows-1250

Aliases   : windows-1250, cp1250, windows-1250, ibm-5346

Code Page : windows-1251

Aliases   : windows-1251, cp1251, windows-1251, ibm-5347

Code Page : windows-1252

Aliases   : windows-1252, cp1252, windows-1252, ibm-5348

Code Page : windows-1253

Aliases   : windows-1253, cp1253, windows-1253, ibm-5349

Code Page : windows-1254

Aliases   : windows-1254, cp1254, windows-1254, ibm-5350

Code Page : windows-1255

Aliases   : windows-1255, cp1255, windows-1255, ibm-5351

Code Page : windows-1256

Aliases   : windows-1256, cp1256, windows-1256, ibm-5352

Code Page : windows-1257

Aliases   : windows-1257, cp1257, windows-1257, ibm-5353

Code Page : windows-1258

Aliases   : windows-1258, cp1258, windows-1258, ibm-5354

JBase - User Guide - Release R15.000 - Page 229 of 629


Japanese, Chinese, Korean Code Pages
Code Page : ISO-2022

Aliases   : cp2022, 2022, ISO-2022, ISO_2022

Code Page : ISO-2022-JP

Aliases   : ISO-2022-JP, csISO2022JP, ISO-2022-JP, ISO_2022,locale=ja,version=0

Code Page : ISO-2022-KR

Aliases   : ISO-2022-KR, csISO2022KR, ISO-2022-KR, ISO_2022,locale=ko

Code Page : ISO-2022-CN

Aliases   : csISO2022CN, ISO-2022-CN, ISO_2022,locale=zh,version=0

Code Page : Shift_JIS

Aliases   : x-sjis, windows-31j, csshiftjis, ms_kanji, cp932, cp943, sjis, csWindows31J, Shift_JIS, ibm-943

Code Page : Big5

Aliases   : cp950, x-big5, csBig5, Big5, ibm-1370

Code Page : GB_2312-80

Aliases   : GB2312, zh_cn, cp936, gb2312-1980, GB2312, gb, chinese, gbk, csISO58GB231280, iso-ir-58, GB_2312-80, ibm-1386

Code Page : EUC-JP

Aliases   : X-EUC-JP, extended_unix_code_packed_format_for_japanese, eucjis, ibm-eucJP, EUC-JP, ibm-33722

Code Page : EUC-KR

Aliases   : EUC-KR, csEUCKR, ibm-eucKR, EUC-KR, ibm-970

Code Page : EUC-TW

Aliases   : cns11643, ibm-eucTW, EUC-TW, ibm-964

Code Page : EUC-CN

Aliases   : ibm-eucCN, EUC-CN, ibm-1383

Code Page : KOI8-R

Aliases   : KOI8-R, cskoi8r, koi8, cp878, KOI8-R, ibm-878

Code Page : korean

Aliases   : ksc, cp949, cp1363, ibm-1363

JBase - User Guide - Release R15.000 - Page 230 of 629


jBASE ODBC

l Introduction
l Configuration
l Developing Client Applications
l Enabling TABLEFILE functionality for jODBC

JBase - User Guide - Release R15.000 - Page 231 of 629


Introduction

The jBASE ODBC Connector is an ODBC driver implementing the Open Database Connectivty (ODBC) 3.0 API. This driver release sup-
ports a driver-manager based interface, featuring support for transactions and calling stored procedures. The ODBC Connector is only available
to Windows platforms but SQL requests may be issued against a remote jBASE instance running on other platforms.

jAgent is a jBASE component responsible for accepting and processing incoming client requests. As shown in this diagram, jAgent must be
running to accept and dispatch SQL requests to the jBASE Server. jAgent, as well as ODBC, use TCP socket connections to communicate
between each other and therefore need to be configured to use the same TCP port. More details about jAgent may be found in the jAgent user
guide.

The ODBC Driver Manager is a system component which on Windows is part of the MDAC (Microsoft Data Access Components) package
and automatically included with the latest Windows operating systems. Odbcad32.exe is the ODBC Data Source Administrator and odbc32.lib/
odbccp32.lib are import libraries to be used by client applications.

Assumptions
Fore more information about the ODBC API and how to use it, refer to

JBase - User Guide - Release R15.000 - Page 232 of 629


http://support.microsoft.com/kb/110093

If the ODBC driver is to be used to develop client applications accessing a jBASE instance, the following prerequisite knowledge is required:

l C
l General DBMS knowledge
l jBASE and concepts of Multivalue databases
l Secure Sockets Layer (SSL) protocol

Environment
The ODBC Connector is available on the following platforms:

l 32-bit Windows XP
l 32-bit Windows 2003 Server
l 32-bit Windows 2000

JBase - User Guide - Release R15.000 - Page 233 of 629


jBASE Locale Configuration

Locales can be configured for the user id through the JBASE_LOCALE environment variable. Display a full list of available locales from the com-
mand line by the “jlocales” command.

Configured locales are only applicable when executing an application in international mode or the JBASE_ I18N environment variable is con-
figured. The locale is based on the underlying OS locale configuration and the configured locale for the user id has no effect.

As configuration of the international mode is on an account basis, the state of international mode can change on execution of a LOGTO. If con-
figuring an account with international mode ‘false’ then the JBASE_I18N environment variable will be unset as the result of the LOGTO.

JBase - User Guide - Release R15.000 - Page 234 of 629


Developing Client Applications

ODBC CLI is an API written in C but other frameworks like e.g. .NET provide ODBC wrapper classes. The following Visual Basic .NET
examples use .NET’s Microsoft.Data.Odbc module.

Example 1:

Reads data from table MY_TEST_TABLE. A DSN named T24 is required.

Imports System

Imports Microsoft.Data.Odbc

Module Module1

Sub Main()

Dim connectionString AsString = "DSN=T24;UID=test;PWD=test"

Dim SQL AsString = "SELECT * FROM MY_TEST_TABLE"

Dim conn AsNew OdbcConnection(connectionString)

Dim cmd AsNew OdbcCommand(SQL)

cmd.Connection = conn

conn.Open()

Dim reader As OdbcDataReader = cmd.ExecuteReader()

While reader.Read()

Console.Write(("ID:" + reader.GetString(0).ToString()))

Console.Write(" ,")

Console.Write(("NAME:" + reader.GetString(1).ToString()))

Console.Write(" ,")

Console.WriteLine(("AGE:" + reader.GetInt32(2).ToString()))

EndWhile

reader.Close()

conn.Close()

EndSub

EndModule

Example 2:

Creates a table with 100 records, followed by a SELECT. A DSN named T24 is required.

Imports System

Imports Microsoft.Data.Odbc

Module Module1

Sub Main()

Dim TimeStart, TimeEnd AsDate

TimeStart = Date.Now()

REM Open a connection

JBase - User Guide - Release R15.000 - Page 235 of 629


Dim conn AsNew OdbcConnection("DSN=T24;UID=test;PWD=test")

conn.Open()

REM Create table

Dim createCmd AsNew OdbcCommand("CREATE TABLE MY_TEST_TABLE(ID INTEGER, NAME VARCHAR(255), AGE SMALLINT,
CREDIT_SCORE INTEGER, BALANCE DOUBLE, PRIMARY KEY(ID))", conn)

Try

createCmd.ExecuteNonQuery()

Catch e As Exception

REM Drop and create table

Dim dropCmd AsNew OdbcCommand("DROP TABLE MY_TEST_TABLE", conn)

dropCmd.ExecuteNonQuery()

createCmd.ExecuteNonQuery()

EndTry

REM Insert records

Dim insertCmd AsNew OdbcCommand("INSERT INTO MY_TEST_TABLE(ID, NAME, AGE, BALANCE, CREDIT_SCORE) VALUES
(?, ?, 30, 345, 876.67)", conn)

insertCmd.Prepare()

insertCmd.Parameters.Add("@ID", OdbcType.Int)

insertCmd.Parameters.Add("@NAME", OdbcType.VarChar, 255)

Dim i AsInteger

For i = 1 To 100 Step 1

insertCmd.Parameters("@ID").Value = i

insertCmd.Parameters("@NAME").Value = "Customer " & i.ToString()

insertCmd.ExecuteNonQuery()

Next

REM Select all records

Dim selectCmd AsNew OdbcCommand("SELECT ID, NAME, AGE, BALANCE, CREDIT_SCORE FROM MY_TEST_TABLE ORDER BY
ID", conn)

Dim reader As OdbcDataReader = selectCmd.ExecuteReader()

While reader.Read()

Console.Write(("ID: " + reader.GetInt32(0).ToString()))

Console.Write(", ")

Console.Write(("NAME: " + reader.GetString(1)))

Console.Write(", ")

Console.Write(("AGE: " + reader.GetInt32(2).ToString()))

Console.Write(", ")

JBase - User Guide - Release R15.000 - Page 236 of 629


Console.Write(("BALANCE: " + reader.GetInt32(3).ToString()))

Console.Write(", ")

Console.WriteLine(("CREDIT SCORE: " + reader.GetDouble(4).ToString()))

EndWhile

reader.Close()

REM Close connection

TimeEnd = Date.Now()

Console.WriteLine("Elapsed: {0} seconds", DateDiff(DateInterval.Second, TimeStart, TimeEnd))

conn.Close()

EndSub

EndModule

SQLGetFunction() provides a list of supported SQL CLI methods.

Stored procedures are supported via the ODBC CALL statement and provide way of calling jBASE subroutines.

Resources
ODBC API  http://support.microsoft.com/kb/110093

The Open Group X/Open SQL Call Level Interface (CLI) http://www.opengroup.org/

JBase - User Guide - Release R15.000 - Page 237 of 629


Enabling TABLEFILE functionality for jODBC

The previous jDP functionality allowed a list of files accessible to the current datasource to be specified in the connections string.
Similar functionality is now provided via 'TABLEFILE' functionality. 

To use:
l Create and populate a catalog file, on the jAgent server, in the normal way.
l When creating a new data source, Specify the full path of the of the catalog file in either the advanced options dialog of odbcad32 or the
'USER_CATALOG'  parameter of the connection string e.g.

jODBCManager -add="DSN=MyTestjODBC;SERVER=localhost;UID=test;USER_CATALOG=c:\data\myCatalog"

JBase - User Guide - Release R15.000 - Page 238 of 629


jBASE Remote File Service

Introduction
This user guide provides insight on configuring jRFS Driver on Application Server(s) to achieve remote access to files present on Database
Server to form Multiple Application Server (MAS) architecture.

By abbreviation "jRFS" stands for "jBASE Remote File Service".

Main benefits of the jBASE Remote File Service (hereafter referred to as 'jRFS') is:

l Application Architecture can be split from the Database.


l More than one Application Server can connect to a jBASE Database.
l For high availability, T24 can be deployed on two or more Application Servers.
l Load sharing.
l No single point of failure.
l Provides access when there is a requirement to share the database between multiple systems.

Assumptions
Familiarity with the following is assumed:

l T24 Architecture
l Usage of jAgent
l Secure Sockets Layer (SSL) protocol

Installation and Configuration

l Overview
l Installation
l Example Deployment
l jRFS and Multiple Application Server (MAS) Architecture

JBase - User Guide - Release R15.000 - Page 239 of 629


Overview

With the concept of jRFS, a T24 Application could be run on and/or data kept on a separate server, and thus the architecture could be split.

This split in architecture helps in achieving load sharing on and high availability of the Application server.

With the jRFS Driver concept, requests, either in the form of file access or query execution, are sent from Application Server and are resolved at
the Database Server. The resulting data is then sent to the Application Server for further processing which could involve any T24 business
logic.

Configuration of the jRFS Driver is achieved via the "tafc.ini" configuration file, which defines where the Database Server jRFS Driver resides on
the Application Server. The "tafc.ini" file is located under the "$TAFC_HOME/config/$TAFC_CONTEXT" directory.

At the Database Server the "jAgent" daemon/service is started, which services requests sent from Application Server.

When a request is made from Application Server(s), once the connection has been established with jAgent, the driver checks the stub file as
pointed to by the "JEDIFILENAME_MD" environment variable. This stub file contains file name of the VOC file present on the Database
server.

Limitations               
l jFRS does not support acces to UD file types from the Application server access.
In such cases those directories on Database server need to be NTFS mounted, so that they can be accessible from the Application
server.

JBase - User Guide - Release R15.000 - Page 240 of 629


l The use of the "jstat" command for getting statistics of the remote file on the Application server is not supported.

Resources
l jAgent User Guide
l jBASE Dataguard
l Open SSL Website (http://www.openssl.org/)
l jRemote User Guide

JBase - User Guide - Release R15.000 - Page 241 of 629


Installation

Database Server Configuration


"jAgent" is a service that resolves requests on the Database Server that are sent from Application Server(s).  Therefore jAgent should be running
on the Database Server to process such requests.

l Before starting jAgent, the environmental variable "JEDIFILENAME_MD" should be set to point location of VOC file.

{export|set} JEDIFILENAME_MD = <location in which VOC file is present>

l Create a VOC entry for "VOC" under "VOC" file itself. This entry is required by jRFS on Application server.

For example:

If the "VOC" file is present under "/glodev2/Pareas/TestBase/TestBase.run/VOC", then create a record with name "VOC" as below spe-
cifying the absolute path:

AIX-/glodev2/Pareas/TestBase/TestBase.run: JED VOC VOC File VOC , Record 'VOC'


Insert 16:22:16 Command-> 0001 F 0002 /glodev2/Pareas/TestBase/TestBase.run/VOC 0003
/glodev2/Pareas/TestBase/TestBase.run/VOC]D

Note: For complete list of options related to configuring and starting "jAgent", refer to the jAgent User Guide.

Finally, start jAgent on a specific port:

jbase_agent -p <port number>

Application Server Configuration

Environmental Variables
On Application server the following environmental variables should be set:

JEDIFILENAME_ Export/set this environmental variable to the location of the local stub file.
MD
For further information related to the local stub file see the section Stub entry of the remote VOC Filename.

TAFC_CONTEXT Export/set this environmental variable to "default".

In "$TAFC_ HOME/config" directory there are 3 directories present, namely "default", "multiapp" and "minimal".
As the "tafc.ini" configuration file is located under "default" directory, this environmental variable should be set to
"default".

 JDIAG To turn on logging set this environment variable.

"JDIAG" should be export/set to:

jRFS=TRACE:filename=<name of the log file>

For Example:

export JDIAG=jRFS=TRACE:filename=first.log

Configuration file
"tafc.ini" is the configuration file required by jRFS, which holds information related to remote Database server to which Application Server
should communicate.

Add an entry with "[jrfs]" as the section name under the "tafc.ini" file, located under "$TAFC_HOME/config/$TAFC_CONTEXT".

JBase - User Guide - Release R15.000 - Page 242 of 629


IPAddress Database server IP Address to which Application server should communicate.

PortNumber Port number on which "jAgent" is listening for the request.

Username Name of the user.

Password Password of the user.

SSL Set to "ON" in case SSL encryption is desired else to "OFF".

For- [jrfs] IPAddress=<IP Address on which jAgent is started> PortNumber=<Port number on which jAgent is
mat listening> Username=<name of user> Password=<encrypted password> SSL={ON|OFF}
of
[jrf-
s]
sec-
tio-
n:

For
exa-
mpl-
e:

Stub entry of the remote VOC Filename


As mentioned in the overview there is another file which jRFS Driver refers to on the Application Server.

l Create a JBC__SOB JediInitjRFS <Name of the remote VOC file present on the Database Server>
normal
file with
contents
as
shown
here:

l Execute export/set JEDIFILENAME_MD=<location of the local stub file>


the fol-
lowing
com-
mand:

For
example:

JBase - User Guide - Release R15.000 - Page 243 of 629


Example Deployment

In this example, a Windows machine is used as the Application server and an AIX machine with IP address 10.92.5.15 will be configured to
work as Database server.

We will create a J4 file on the Database server from the Application server.

l Configuration on Database Server (AIX)


l Configuration on Application Server (Windows)
l Creating J4 file on Database server from Application server
l Creating VOC entry for the file created from the Application server

JBase - User Guide - Release R15.000 - Page 244 of 629


jRFS and Multiple Application Server (MAS) Architecture

With jRFS there is a split between the Application server architecture and the Database.

The application server only maintains a pointer to Database VOC file.  This makes it possible to have multiple Application servers pointing to
the same instance of the Database Server.

The implication of this is that each application server has no direct, individual database storage, but shares access to a central database.

High Availability on the Application server with jRFS

High availability is often associated with fault-tolerant systems. This means during any system fault it is expected that the faulty component
can either be quickly replaced or corrected with minimal interruption of service. Availability has long been a critical component for online sys-
tems because business processes can quickly come to a halt when a computer system is down.

This type of architecture assists in quick replacement of the Application Server, as only it requires configuring Database server information on
the Application server and reference to Database VOC file. It simplifies replacement of the Application server during a failure/crash scenario (as
data is always stored separately from the Application server).

On the Database Server(s), Transaction Journaling facilities are available for recovery of any data lost due to a failure at Database level.

Integrating additional Application servers in a MAS implementation

Adding to our previous example we will use a Linux machine as another Application server connecting to the same Database server.

JBase - User Guide - Release R15.000 - Page 245 of 629


In this example we will create a record named "FIRSTRECORD1" in the file "FIRSTFILE1" which was created in the previous example on the
Database server and will "LIST" its records from new Application server.

1. Update "tafc.ini" file located under "$TAFC_ HOME\config\default" with Database server details.
In this example "tafc.ini" file is update as below:

2. Export "TAFC_ CONTEXT" to the name of the folder in which "tafc.ini" is present.
In this example we have "tafc.ini" file located under the "default" directory of "$TAFC_ HOME/config" directory.

export TAFC_CONTEXT=default

3. Create a normal file anywhere with any name. This will act as a stub file holding name of the remote VOC file.

In this example we create a file name called "localVOC" under "$TAFC_HOME".

Format of the content is:

JBC__SOB JediInitjRFS <name of the database VOC file>

export environmental variable "JEDIFILENAME_ MD" to point this file.

export JEDIFILENAME_MD=$TAFC_HOME/localVOC

4. To turn on logging on the Application server we need to set JDIAG environmental variable:

export JDIAG=TRACE=jRFS

(By setting as above this log messages on the console.)

export JDIAG=TRACE=jRFS:filename=newfile.log
(This will create "newfile.log" and logs all messages in this file).

The additional Application server is now ready to communicate with Database server.

JBase - User Guide - Release R15.000 - Page 246 of 629


jBASE Triggers

l Overview
l Assignment of Trigger Subroutine Arguments
l CREATE-TRIGGER

JBase - User Guide - Release R15.000 - Page 247 of 629


Overview

The mechanism provided to define the action that takes place when a database trigger event occurs is a jBC subroutine. The name of the sub-
routine is specified in the create-trigger command. A different subroutine can be defined for each of the nine database trigger events, however it
is usually more convenient to use one subroutine for each file that has a trigger defined, distinguishing between the different events in the sub-
routine.

The subroutine can used to define ancillary updates that need to occur as a result of the primary update. The seven parameters passed to the
subroutine allow interrogation and (where applicable) manipulation of the record being updated.

JBase - User Guide - Release R15.000 - Page 248 of 629


Subroutine Parameter Description

filevar
The file variable associated with the update. For example, you can do:

WRITE var ON filevar,"newkey"

however you must then be very careful of calling this subroutine recursively.

Event
One of the TRIGGER_ TYPE_xxx values to show which of the 9 events is currently about to take place.['TRIGGER_ TYPE_xxx' values are
defined in $JBCRELEASEDIR/include/JBC.h (Unix) and %JBCRELEASEDIR%\include\JBC.h (Windows).

Type Event

TRIGGER_TYPE_PREWRITE - before a WRITE occured

TRIGGER_TYPE_POSTWRITE - after a WRITE occured

TRIGGER_TYPE_PREDELETE - before a DELETE occured

TRIGGER_TYPE_POSTDELETE - after a DELETE occured

TRIGGER_TYPE_PRECLEAR - before a CLEARFILE occured

TRIGGER_TYPE_POSTCLEAR - after a CLEARFILE occured

TRIGGER_TYPE_PREREAD - before a READ occured

TRIGGER_TYPE_POSTREAD - after a READ occured

TRIGGER_TYPE_POSTOPEN - after an OPEN occured

prerc
The current return code (i.e. status) of the action.

For all the TRIGGER_TYPE_PRExx events, it will be 0.

For all the TRIGGER_TYPE_ POSTxx events, it will show the current status of the action, with 0 meaning that the action was performed suc-
cessfully and any other value showing the update failed. For example, if a WRITE fails because the lock table is full, the value in prerc is 1.

flags
Flags to show whether a WRITE or WRITEV was requested. Currently not implemented.

RecordKey
The record key (or item-id) of the WRITE or DELETE being performed.

For CLEARFILE, this is set to null.

JBase - User Guide - Release R15.000 - Page 249 of 629


Record
For the WRITE actions, this is the record currently being updated. For the DELETE or CLEARFILE actions, this is set to null. This variable
can be modified within the Subroutine if required. However, the modification will be discarded unless the create-trigger command was executed
with the -a option.

userrc
This vatiable can be set to a non-zero value for the TRIGGER_TYPE_PRExxx actions in order to abort the current action. However, unless the
-t option was used with the create-trigger command, it will be meaningless.

There are two options to setting this value:

Any negative value will cause the action to be terminated. However, nothing will be flagged to the application, and it will appear to all intents
and purposes that the action performed.

Any positive value is taken to be the return code for the action.

For example, when a WRITE completes it will normally give a return code of 0.

If this variable is then set to say 13 (which is the Unix error number for "Permission denied") then the application will fall into the jBASE debug-
ger with error code 13.

NOTES
Processing carried out inside a trigger should be as economic as possible. They are not designed to allow copious application logic. Any files
opened inside a trigger should be opened once and the file descriptor stored in named common such that files are not opened in every iteration.
Care should be taken that logic inside a trigger will not result in overhead or in an infinite loop of trigger calls.

JBase - User Guide - Release R15.000 - Page 250 of 629


Assignment of Trigger Subroutine Arguments

The arguments of a trigger subroutine are generally assigned by the database management system at the time the subroutine is invoked, but
there are exceptions. The subroutine can in turn assign or reassign argument values if the trigger was created with the -a option.

The table below summarizes the state of each argument at the time the subroutine is invoked, according to each trigger type. Note that there
are three cases where record is null even though the record key is assigned, i.e., pre- and post-delete and pre-read. This is so for the read event
because there is no need to read a record before reading a record, and in the case of the delete events, because the attempt to delete a non-exist-
ent record warrants no further action.

If an application requires a record to be verified prior to deleting it, then that operation that should be performed at a higher level.

Trigger Type filevar* event prerc flags recordkey record userrc

Pre-Write YES YES YES N/A YES YES UD

Post-Write YES* YES YES N/A YES YES UD

Pre-Delete YES* YES YES N/A YES NULL UD

Post-Delete YES* YES YES N/A YES NULL UD

Pre-Clear YES* YES YES N/A NULL NULL UD

Post-Clear YES* YES YES N/A NULL NULL UD

Pre-Read YES* YES YES N/A YES NULL UD

Post-Read YES* YES YES N/A YES YES UD

Post-Open YES* YES YES N/A NULL NULL UD

YES means that the variable is assigned in this trigger. UD means that it is user definable, N/A means that the variable is not used. Null means
that the variable is assigned a null value.

Note that filevar is not the name of the file, but rather the system-level file unit, ie the 'OPEN' file descriptor. It can be treated as such for file
operations within the subroutine, but cannot be treated as a typical variable, e.g., it cannot be used with a PRINT or CRT statement.

JBase - User Guide - Release R15.000 - Page 251 of 629


CREATE-TRIGGER

The CREATE-TRIGGER command is used to specify the database events for which the trigger subroutine is called.

COMMAND SYNTAX
CREATE-TRIGGER -Options FileName {triggername|*} subroutine

SYNTAX ELEMENTS
FileName can reference either a jBASE hashed file or a directory.

triggername must be * or one of the nine database events: POSTOPEN, PREREAD, POSTREAD, PREWRITE, POSTWRITE, PREDELETE,
POSTDELETE, PRECLEAR, POSTCLEAR. If * is specified then the trigger subroutine will be called for each of the nine database events.

subroutine is the name of a jBC subroutine. Also see Trigger API.

The valid options for CREATE-TRIGGER are:

Option Name Explanation

-a or (A) amend flag subroutine can amend the record

-d or (D) debug flag subroutine can be debugged

-t or (T) terminate flag subroutine terminates update

-o or (O) overwrite flag overwrite any existing definitions

NOTES
CREATE-TRIGGER can be run multiple times for the same file. If a trigger has already been defined for the specified event then the overwrite
flag must be used to effect the change.

EXAMPLES
CREATE-TRIGGER BP POSTOPEN SUBBPOPEN

The subroutine SUBBPOPEN will be called immediately after the BP file is successfully opened by any jBASE process.

CREATE-TRIGGER -o PAYROLL * SUBBP

The subroutine SUBBP will be called for every database event to the PAYROLL file. Existing trigger definitions will be overwritten.

JBase - User Guide - Release R15.000 - Page 252 of 629


Environment Variables

jBASE uses a number of environment variables to modify jBASE behaviour. Suitable defaults apply to most of them. Although most envir-
onment variables can be set any time, the best place to do so is in the .profile script.

Setting/Getting Environment Variables


Windows UNIX

set variable=value variable=value


export variable
echo %variable%

Variables can be configured in the System environment for all users, and/or on a per user basis via echo $variable
the user environment. Additional variables for jBASE can also be added to the current user con-
figuration registry. This works for all shells, although
one can do “export variable=value” in
Win9x variables are usually configured in the AutoExec.bat. Care should be taken that the envir- ksh, etc.
onment area does not become overwritten on Win9x as it is initially quite small, approximately 512
bytes. Subsequent .bat commands should increase the required environment space. Setting it in the Variables are usually configured in
config.sys file can explicitly increase the environment space: the .profile of the user login directory
although global variables can be
shell=c:\command.com /e:2048 /p added to the /etc/profile script.

jBASE PROGRAMS
The jBASE BASIC functions PUTENV and GETENV can be used to manipulate environment variables. For example:

IF PUTENV (envar=x) THEN ELSE NULL

IF GETENV (envar) THEN ELSE NULL

jBASE Initialization
Some environment variables can only be set before jBASE initialization. jBASE initialization occurs when the first jBASE program is executed
for a particular “PORT”.

The jBASE initialization process reads the environment entries looking for possible variables required by jBASE. These environment variables
continue to be valid as long as the “PORT” is still active. Some environment variables can be changed by subsequent program execution. The
state of these variables is imported back into the local environment after program execution.

For instance:

T-ATT requires a “PORT” against which it saves the tape device assignment

.SP-ASSIGN requires a “PORT” with which to save assignment status for print jobs

READNEXT in a program after SELECT/GET-LIST

With jBASE 5.2 all programs execute in the same process unless explicitly executed via the chars(255) *.k construct.

UNIX Windows

jBASE initialization on UNIX is usually performed in the jBASE initialization on Windows usually occurs when the first jBASE program
.profile. executes.

JBase - User Guide - Release R15.000 - Page 253 of 629


Initial Environment Variables
Variables cannot be imported again after jBASE initialization.

PATH Pathnames of executables

HOME Pathname of user home directory

LD_LIBRARY_PATH Pathnames of system libraries (UNIX only)

LIBPATH Pathnames of system libraries (AIX only)

SHLIB_PATH Pathnames of system libraries (HPUX only)

LANG Language type (UNIX only)

LC_ALL Locale (Unix only)

TZ Timezone (Unix only)

TERM Specifies terminal type as per terminfo database

TERMINFO Specifies directory for terminal settings

JBCPORTNO Forced Port number for use by user. (Usually allocated)

JBCLOGNAME User name to use in-place of login id

JBCGLOBALDIR Pathname of jBASE global configuration directory

JBCRELEASEDIR Pathname of jBASE release directory

JBCEMULATE Emulation to be used for this user

JEDIFILEPATH Directory Paths of application files location

JEDIFILENAME_MD Pathname of file to be used for MD entries

JEDIFILENAME_SYSTEM Pathname of file to be used for SYSTEM entries

JBase - User Guide - Release R15.000 - Page 254 of 629


Additional jBASE Environment Variables

EXECUTION - Environment Variables


JBCBACKGROUND Set to 1 to run “PORT” as background task

JBCRUNDIR Set to executable directory for RUN command

JEDIENABLEQ2Q Set to 1 to force detection of Qptr to Qptr

JEDI_DISTRIB_ Set to 1 to defer OPENs of distributed file parts


DEFOPEN

JEDI_SECURE_LEVEL Set security level for flushable files (such as J3s or jPLUS files)

Level 1. No, flush

Level 2. Flush on link modification

Level 3. Flush after update, default.

(Network failure)

JEDI_INDEX_MMAP_ Set to force use of memory mapping on indexes when updating memory mapped files
ON

JEDI_ AIX_ FILE_ Set to force use of memory mapping of j4 files on AIX multi-processor machines
MMAP_ON

JEDI_ AIX_ OBJECT_ Set to force use of memory mapping of .el files on AIX multi-processor machines
MMAP_ON

JEDI_OBJECT_MMAP_ Turn off memory mapping of .el files


OFF

JBC_TCLRESTART Set to command to execute instead of shell

JBC_ENDRESTART Set to command to execute after end from debugger

JBCRESTARTPROG Set to command to execute after off

JBCOBJECTLIST Set to alternate path(s) for user subroutine libraries

Windows - %home%\lib

UNIX - $HOME/lib

JBC_BLOCK_SYSTEM14 Set to 1 to force a 100-millisecond delay on SYSTEM (14) calls.

JBASE_ERRMSG_NON_ Controls behaviour when a numeric operation on a non-numeric value is encountered


NUMERIC

JBASE_ ERRMSG_ Controls behaviour when a zero used condition is encountered


ZERO_USED

JBASE_WIN_TERM_ This should be set on servers running Windows Terminal Server before starting the License Server, and for all
SVR sessions wishing to access jBASE licences.

JBase - User Guide - Release R15.000 - Page 255 of 629


DEVELOPMENT - Environment Variables

JBCDEV_BIN Set to alternate path to catalog executables.

Windows - %home%\bin

UNIX - $HOME/bin

JBCDEV_LIB Set to alternate path to catalog libraries.

Windows - %home%\lib

UNIX - $HOME/bin

JBCDEBUGGER Set to 1 to force entry into debugger.

JBCTTYNAME Specify alternate tty name for output. (UNIX only)

LIB Specify additional paths for linking with libraries. (NT only)

INCLUDE Specify additional paths for header files

JPQDEBUG Set to 1 for PROC to enter “DEBUG” at IP input

JBase - User Guide - Release R15.000 - Page 256 of 629


MISCELLANEOUS - Environment Variables

JBCERRFILE Specify alternate error message file

JBCSPOOLERDIR Specify alternate spooler directory

JBC_DESPOOLSLEEP Specify the interval for despoolers to check for queued jobs

JBC_CRREQ Controls linefeeds, formfeed and carriage returns in print jobs

JBC_OLD_SP_EDIT Specifies the alternative SP-EDIT format

JBCLISTFILE Specify alternate select list file

JBase - User Guide - Release R15.000 - Page 257 of 629


TERMINAL - Environment Variables

JBCSCREEN_ Specify alternate terminal depth


DEPTH

JBCSCREEN_ Specify alternate terminal width


WIDTH

JBCPRINTER_ Specify alternate printer depth


DEPTH

JBCPRINTER_ Specify alternate printer width


WIDTH

JBCPRISM Set hard coded prism sequences (NT only)

JBC_STDERR Set to 1 to redirect standard error to standard out. Useful for Capturing output that would normally be sent to the
screen.

JBCCREATEFLAGS Set to 0, 1, and 2 for output redirection. (NT only)

0 Direct to current console (default)

1 Direct to new console

2 Detached for no console

JBase - User Guide - Release R15.000 - Page 258 of 629


EMBEDDED SQL - Environment Variables

Setting these environment variables overrides the jcompile built-ins when processing files containing Embedded SQL using the -Jq<flavour>
option.

JBC_SQLLIBS Set alternate SQL libraries for embedded SQL

JBC_SQLPREPROC Set alternate SQL pre-compiler command

JBC_SQLCOPTS Set alternate SQL options for C compiler (also passed via nsqlprep for MSSQL)

EXAMPLE
For Oracle Pro*C Embedded SQL pre-compiler, on Windows the following environment variables can be set (assuming e.g. ORACLE_ HOME-
E=C:\Oracle\product\9.2.0.1.0\Client_1):

JBC_ SQLLIBS=%ORACLE_ HOME%\oci\lib\msvc\oci.lib /libpath:%ORACLE_ HOME%\precomp\lib /libpath:%ORACLE_


HOME%\precomp\lib\msvc orasql9.LIB
JBC_SQLPREPROC=proc mode=oracle ltype=none ireclen=255 oreclen=255 iname=

Assuming that the PATH environment is also configured for Embedded SQL, the command jcompile -Jqo SqlDemo.b compiles the jBASE
BASIC program, including passing it through the Oracle Pro*C pre-processor.

JBase - User Guide - Release R15.000 - Page 259 of 629


CREATE-FILE - Environment Variables

JEDI_PREFILEOP Parameters take precedence before command line

JEDI_POSTFILEOP Parameters take precedence after command line

EXAMPLE
To convert all files on “jbackup” tape to J4 files set the following environment variable is using jrestore.
Export JEDI_ PREFILEOP=TYPE=J4 (UNIX) Can use quotes to surround multiple parameters
set JEDI_PREFILEOP=TYPE=J4 (NT)

Don’t use quotes.

JBase - User Guide - Release R15.000 - Page 260 of 629


jRFS – Environment Variables

JBCNETACCESS Specify the location of the jRFS security access file

JBCNETDIR Specify the location of the jRFS configuration files

JRFS_SERVERNAME Allows the jRFS client to override the service port

JRFS_HOSTNAME Allows the jRFS client to override the target host

JBase - User Guide - Release R15.000 - Page 261 of 629


PUTENV - Command

Used to set environment variables for the current process

COMMAND SYNTAX
PUTENV (expression)

SYNTAX ELEMENTS
Expression should evaluate to a string of the form:

EnvVarName=value

Where EnvVarName is the name of a valid environment variable and value is any string that makes sense to variable being set.

If PUTENV function succeeds it returns a Boolean TRUE value, if it fails it will return a Boolean FALSE value.

NOTES
PUTENV only sets environment variables for the current process and processes spawned (say by EXECUTE) by this process. These variables
are known as export only variables.

See also GETENV.

EXAMPLE
IF PUTENV (“JBCLOGNAME=”:UserName) THEN
CRT “Environment configured”
END

JBase - User Guide - Release R15.000 - Page 262 of 629


GETENV - Command

All processes have an environment associated with them that contains a number of variables indicating the state of various parameters. The
GETENV function allows a jBASE BASIC program to determine the value of any of the environment variables associated with it.

COMMAND SYNTAX
GETENV (expression, variable)

SYNTAX ELEMENTS
The expression should evaluate to the name of the environment variable whose value is to be returned. The function will then assign the value
of the environment variable to variable. The function itself returns a Boolean TRUE or FALSE value indicating the success or failure of the func-
tion.

NOTES
See the UNIX documentation for the Bourne shell (sh) or the Windows on-line help for information on environment variables.  Click here for
information regarding environment variables unique to the jBASE system.

See also PUTENV

EXAMPLE
IF GETENV (“PATH”, ExecPath) THEN
CRT “Execution path is “:ExecPath
END ELSE
CRT “Execution path is not set up”
END

PATH

DESCRIPTION
The PATH variable contains a list of all directories that contain executable programs. As a minimum, this should contain the shell default value
plus the path /the shell sees usr/jbc/bin so that j JBASE commands. You will also wish to add the path of your application executable dir-
ectory (such as ${HOME}/bin).

VALUES
for any directory, the user has privileges

DEFAULT
The default depends entirely upon your UNIX system and how it has been set up.

SETTINGS
Normal UNIX environment variable, so it can be set at any time by the commands:

UNIX Windows

JBase - User Guide - Release R15.000 - Page 263 of 629


PATH=$PATH:/apps/bin SET PATH=%PATH%;D:\apps\bin
export PATH

JBase - User Guide - Release R15.000 - Page 264 of 629


LD_LIBRARY_PATH

DESCRIPTION
This is a SVR4 UNIX only variable and should be set to /usr/jbc/lib.

VALUES
Colon separated library file paths.

DEFAULT
None

SETTINGS
Normal UNIX environment variable, so it can be set at any time by the commands:

LD_ LIBRARY_ PATH=$LD_ LIBRARY_ PATH:/usr/jbc/lib


export LD_LIBRARY_PATH

TERM

DESCRIPTION
On UNIX, this variable should be set to your terminal type as defined by the UNIX terminfo database

On Windows, it should be set to a value in any of the directories under %JBCRELEASEDIR%\misc.

VALUES
On UNIX, any valid terminfo database entry

On Windows, any file name (up to the underscore) in the directories under %JBCRELEASEDIR%\misc. Additional terminal definitions can be
created using the jtic command.

DEFAULT
On UNIX, the default depends upon your system and how it has been set up.

SETTING
Normal environment variable, so it can be set at any time by the commands:

UNIX Windows

TERM=vt220 SET TERM=vt220


export TERM

JBase - User Guide - Release R15.000 - Page 265 of 629


TERMINFO

DESCRIPTION
The TERMINFO environment variable is used for terminal handling. The environment variable is supported only on platforms that provide full
support for the terminfo libraries that System V and Solaris UNIX systems provide.

VALUES
The TERMINFO environment variable defines a directory where the terminal settings are read from.

DEFAULT
On UNIX, the default depends upon your system and how it has been set up.

SETTING
Normal environment variable, so it can be set at any time by the commands:

UNIX Windows

TERMINFO=/usr/term SET TERMINFO=c:\term


export TERMINFO

JBase - User Guide - Release R15.000 - Page 266 of 629


JBCPORTNO

DESCRIPTION
This defines your current port number and is useful when a particular user wishes to keep the same port number whenever they log on. On
UNIX, it takes a sensible default, but this default may change if the UNIX configuration is changed. On Windows, port numbers are allocated
sequentially from zero.

VALUES
Decimal port number

On UNIX, lists and ranges of port numbers can be specified.

DEFAULT
None

SETTING
UNIX WINDOWS

Set in the .profile prior to execution of initial jBASE program set before invoking the jSHELL

NOTES
UNIX Windows

JBCPORTNO=300,304,310,350,360- 390 SET JBCPORTNO=300


export JBCPORTNO

On UNIX platforms, jBASE will assign the low- On Windows, if the specified port number is in use then the connecting process is given
est available port number from the list or range the next highest port number available. jBASE OBjEX processes are automatically
specified. If all port numbers specified by assigned port numbers from 5,000. Processes run in the background (see jstart -b) are
JBCPORTNO are already in use then the user is assigned port numbers from 10,000 but a GETENV () on JBCPORTNO will always
denied access. return -1.
Port number is already logged on and in use

From Port 45, tty /dev/pts/1, JBASE pid 16754

JBase - User Guide - Release R15.000 - Page 267 of 629


JBCLOGNAME

DESCRIPTION
The account name as perceived by commands such as “WHO” or conversions such as U50BB will normally be returned as the login name of the
UNIX user (LOGNAME variable). However if you wish your users to login with personal ids but execute as if they were all on the same account
you may set this variable to override the default. The account name will be returned to whatever this environment variable is set.

VALUES
any character string

DEFAULT
None

SETTING
As per normal environment variable

UNIX WINDOWS

setup in the . profile set before running any jBASE program

NOTES
UNIX Windows

JBCLOGNAME=PAYROLL SET JBCLOGNAME=HARRY


export JBCLOGNAME

JBase - User Guide - Release R15.000 - Page 268 of 629


JBCGLOBALDIR

DESCRIPTION
Defines the directory for jBASE global files

VALUES
Valid file path

DEFAULT
The default value is the same as JBCRELEASEDIR

UNIX Windows

/usr/jbc C:\JBASE5\5.2

SETTING
UNIX Windows

As per normal environment variable, should be setup in the This is set in the registry when jBASE is installed. See
*.profile
JBCGLOBALDIR=/usr/jbc HKEY_ LOCAL_ MACHINE/SOFTWARE/JAC/jJBASE/3.0/CURRENT_
export JBCGLOBALDIR CONFIG
This value can be overridden by setting JBCGLOBALDIR as an environment
variable.

JBase - User Guide - Release R15.000 - Page 269 of 629


JBCRELEASEDIR

DESCRIPTION
Defines the release directory for the jBASE system executables and libraries

VALUES
Valid file path

UNIX Windows

/usr/jbc (default) C:\JBASE5\5.2 (default)

SETTING
UNIX Windows

On UNIX, as per normal environment variable, should be Set in the .profile prior to execution of initial SET JBCRELEASEDIR = c:\j-
jBASE program base5\5.2

JBCRELEASEDIR=/usr/jbc3.1
export JBCRELEASEDIR

JBase - User Guide - Release R15.000 - Page 270 of 629


JBCDATADIR

DESCRIPTION
Defines the location for jBASE to determine any configured databases. Overrides the default setting for the spooler directory.

NOTES
When the JBCSPOOLERDIR is not defined, the default setting for the jBASE spooler directory is $JBCDATADIR/jbase_ data. When
JBCDATADIR is not set, the default setting is $JBCGLOBALDIR/jbase_data.

If the JBCGLOBALDIR is not set, it defaults to $JBCRELEASEDIR.


If the JBCRELEASEDIR is not set, the default settings are /opt/jbase5/5.2 (Unix) or c:\jbase5\5.2 (Windows)

VALUES
Valid file path

UNIX Windows

/opt/jbase4/4/1/jbase_data C:\JBASE5\5.2\jbase_data

SETTING
UNIX Windows

On UNIX, as per normal environment variable, should be Set in the .profile prior to execution of initial SET JBCDATADIR =
jBASE program c:\mydata

JBCDATADIR=/usr/jbc/data

JBase - User Guide - Release R15.000 - Page 271 of 629


JBCDEFDICTS

DESCRIPTION
Specifies one or more files that are used to hold dictionary items for use by jQL. When JBCDEFDICTS is set, jQL will scan each specified file
for dictionary items that cannot be located in the dictionary of the queried file. When JBCDEFDICTS is not set, jQL will scan just the dic-
tionary of the queried file and then the MD / VOC.

VALUES
Colon separated file paths (Unix)
Semicolon separated file paths (Windows)

DEFAULT
None

SETTING
UNIX Windows

JBCDEFDICTS=/mydicts SET JBCDEFDICTS=c:\mydicts


export JBCDEFDICTS

JBase - User Guide - Release R15.000 - Page 272 of 629


JBCEMULATE

DESCRIPTION
When importing legacy applications, this variable tells the jBASE what system it originally ran on. NOTE: that programs and subroutines impor-
ted from different systems may be freely mixed.

VALUES
jBASE, adds, ape, fuj, prime, ros, r83, r91, ultimate, universe.

The values reference labels in the Config_EMULATE file.

DEFAULT
The default is jBASE, which will suit most imported applications.

SETTING
Normal environment variable, so it can be set at any time by the commands:

UNIX Windows

JBCEMULATE=Value SET JBCEMULATE=Value


export JBCEMULATE

JBase - User Guide - Release R15.000 - Page 273 of 629


JDIAG

DESCRIPTION
This environment variable provides a variable amount of jBASE trace information depending on which options are specified.

VALUES
Colon separated name and value pairs from the following options;
profile= {off|short|long|user|jcover|all}
filename= {stdout|stderr|tmp|pathname,refresh_ mins} %p can be used for process ID
memory= {off|on|verify}
branch= {off|on|verbose}
trace=env_name{,env_name …}

DEFAULT
Not set.

SETTING
UNIX Windows

JDIAG=profile=on:branch=on SET JDIAG=profile=on:trace=on


export JDIAG

JBase - User Guide - Release R15.000 - Page 274 of 629


JEDIFILEPATH

DESCRIPTION
This environment variable provides a list of directories in which to search for jBASE data files. If an MD or VOC file is configured with F / Q
pointers, these take precedence over the directories in the JEDIFILEPATH.

VALUES
Colon separated file paths (UNIX)

Semicolon separated file paths (Windows).

DEFAULT
The current directory

SETTING
As per normal environment variable, so it can be set at any time. The use of relative file paths (such as “.”) should be avoided as it can result in
unintended file access.

UNIX Windows

JEDIFILEPATH=/appvol/WB1:/appvol/WB2:/appvol/WB3 SET JEDIFILEPATH=F:\apps\WB1;F:\apps\WB2;F:\apps\WB3


export JEDIFILEPATH

JBase - User Guide - Release R15.000 - Page 275 of 629


JEDIFILENAME_MD

DESCRIPTION
This variable should be used if you require the use of the MD/VOC file to hold Q pointers, jCL programs, paragraphs or entries for the jQL lan-
guage. If you have loaded an account-save into your home directory then you might wish to set this variable. This will then allow you to:

Execute jCL programs and paragraphs directly from the MD/VOC (using jsh or EXECUTE/CHAIN etc.) On systems with 14 char filename lim-
its, create cross-reference items for executables from the original name to the new name. F pointers and Q pointers in an MD / VOC take pre-
cedence over paths in the JEDIFILEPATH.

VALUES
Valid file path; while it is not required, it is strongly advised that this value be set to the complete path of the MD and not a relative path (as an
example, “/home/bob/MD]D” should be used instead of “./MD]D”).

DEFAULT
None

SETTING
As per normal environment variable, so it can be set at any time by the commands:

UNIX Windows

JEDIFILENAME_MD=/usr/GLOBAL/MD SET JEDIFILENAME_MD=D:\GLOBAL\VOC


export JEDIFILENAME_MD

JBase - User Guide - Release R15.000 - Page 276 of 629


JEDIFILENAME_SYSTEM

DESCRIPTION
If you are using Q pointers in a defined MD/VOC file then you may well need to create a SYSTEM file to define the home directories of other
accounts. By default Q-pointers are resolved by using the $JBCRELEASEDIR/src/SYSTEM file. Setting the JEDIFILENAME_ SYSTEM vari-
able to an alternative hash file or directory can change this.

While it is not required, it is strongly advised that this value be set to the complete path of the system file and not a relative path (as an
example, “/home/islandjim/SYSTEM]D” should be used instead of “./SYSTEM]D”).

VALUES
Valid file path

DEFAULT
None

SETTING
As per normal environment variable, so it can be set at any time by the commands:

UNIX Windows

export JEDIFILENAME_SYSTEM=/home/alternative/SYSTEM SET JEDIFILENAME_SYSTEM=D:\home\alternative\SYSTEM

JBase - User Guide - Release R15.000 - Page 277 of 629


JEDIENABLEQ2Q

DESCRIPTION
Resolve this environment variable by setting to Q-pointer-to-Q-pointer chains. The maximum chain length allowed is 11. NOTE:: that this envir-
onment variable enables Q-pointer-to-Q-pointer resolution. Q-pointer to F-pointer resolution is not supported.

VALUES
1

DEFAULT
Not set

SETTING
As per normal environment variable

UNIX Windows

JEDIENABLEQ2Q=1 SET JEDIENABLEQ2Q=1


export JEDIENABLEQ2Q

JBase - User Guide - Release R15.000 - Page 278 of 629


JEDI_DISTRIB_DEFOPEN

DESCRIPTION
Setting this environment variable will defer the OPENing of component or part files in a distributed file set until the component file is required
to be opened by the application program.

VALUES
1

DEFAULT
Not set.

SETTING
As per normal environment variable

It should be setup before the main file is accessed.

UNIX Windows

JEDI_ DISTRIB_ DEFOPEN=1 SET JEDI_DISTRIB_DEFOPEN=1


export JEDI_DISTRIB_DEFOPEN

JBase - User Guide - Release R15.000 - Page 279 of 629


JEDI_SECURE_LEVEL

DESCRIPTION
Defines the security level for files which support configurable flushing.

VALUES
1 Switches off secure mode.

2 When certain changes occur that could corrupt the file in the event of a failure, the file data is flushed from memory to disk. Normal
updates will not be flushed.

3 All file updates will cause the file data to be flushed from memory to the disk.

DEFAULT
3

SETTING
As per normal environment variable

UNIX Windows

JEDI_ SECURE_ LEVEL=2 SET JEDI_SECURE_LEVEL=2


export JEDI_SECURE_LEVEL

Performance Implications
There is a performance penalty to pay for running in secure mode levels 2 and 3.

Level 2 will protect against file corruption by flushing the file from memory to disk when certain operations occur. However, it will not protect
against loss of data. Most operating systems will periodically flush this data, usually a tuneable system and often with a default of every 60
seconds. Therefore, if you can withstand a loss of up to 60 seconds of data, and your primary concern is that the files are not corrupted in the
event of a system failure, then this is the level for you. Minimal impact on performance is seen so long as your files are properly sized. Even if
they go out of the main group, performance is only impacted if the extended group size keeps varying considerably.

Level 3 will protect against almost everything including loss of data. This impacts most  on the system. The actual level of performance impact
depends greatly on your application. For example, most of your updates may be to very large files in a pseudo-random manner (e.g. updating
stock records, customer details etc.). In this situation, all this does is move the overhead from the operating system flush daemon that runs
about every 60 seconds (see Level 2 above) to the process doing the update. Therefore, it may be a case of “What you lose on the roundabouts
you gain on the swings!” On the other hand, you may have a small file regularly being updated with things like current days orders. In this case
the impact will be substantial as you will be causing a disk update for each application WRITE, whereas without this you might do many of
these WRITEs before the operating system daemon does a single write.

Another way to control your flushing of data to disk is to use transaction boundaries. For example, the following jBASE BASIC code will cause
all data to be flushed to disk for all files regardless of the file type or file status

TRANSTART ELSE PRINT “Error” ; STOP

WRITE record1 TO filevar1

WRITE record2 TO filevar2

TRANSEND SYNC ELSE PRINT “Error” ; STOP

This mechanism guards against data loss but is less effective in protecting against file corruption should the server fail while the TRANSEND is
actually in progress.

JBase - User Guide - Release R15.000 - Page 280 of 629


You should set JEDI_SECURE_LEVEL=1 when doing batch updates on a secure mode file. For example, when copying a number of records
from a temporary file to a secure mode file called CUSTOMERS:

jsh - - >export JEDI_ SECURE_ LEVEL=1


jsh - - >COPY TEMPFILE * (O
TO: (CUSTOMERS
1217 Record (s) copied
jsh -->unset JEDI_SECURE_LEVEL

In the above example the secure mode is disabled during the COPY, command and so will perform much quicker. When the COPY is com-
pleted, it is normal operating system practice to flush all modified file data to disk anyway.

Refer also: CREATE-FILE, Transaction Boundaries, Transaction Journaling

JBase - User Guide - Release R15.000 - Page 281 of 629


JBC_TCLRESTART

DESCRIPTION
Enables the Command Level Restart feature

VALUES
Restart Program

DEFAULT
Command Level Restart feature disabled

SETTING
UNIX Windows

Create the JBC_ TCLRESTART environment variable Set before any jBASE program is invoked. The environment variable should contain
in the .profile prior to execution of initial jBASE pro- the command string to execute when the user would otherwise go to a shell
gram Prompt.

To later enable the feature, use the BITSET(-2); to later disable the feature, use the BITRESET(-2)

JBase - User Guide - Release R15.000 - Page 282 of 629


JBC_ENDRESTART

DESCRIPTION
Enables the Break/End Restart feature

VALUES
Restart program name

DEFAULT
Break/End Restart feature disabled

SETTING
UNIX Windows

Create the JBC_ ENDRESTART environment in the .pro- Set before any jBASE program is run. The environment variable should contain
file prior to execution of the initial jBASE program the command string to execute when the debugger is entered/exited.

To later enable the feature, use the BITSET (-3); to later disable the feature, use the BITRESET (-3).

JBase - User Guide - Release R15.000 - Page 283 of 629


JBCOBJECTLIST

DESCRIPTION
Defines the directories to find user shared object libraries where user subroutines are located.

VALUES
File paths Colon separated on UNIX. Semi-colon separated on Windows.

DEFAULT
%HOME%\lib (Windows)

$HOME/lib (UNIX)

Note: It is good practice to set JBCOBJECTLIST explicitly rather than relying on the default setting. This is because the value of the
HOME environment variable may change (for example after a LOGTO).

SETTING
UNIX Windows

Set in the .profile before execution of the initial jBASE Program. Set before the jSHELL is invoked.

JBCOBJECTLIST=$HOME/lib:/home/TESTJBASE/lib SET JBCOBJECTLIST=%HOME%\lib;C:\dev\TESTJBASE\lib


export JBCOBJECTLIST

JBase - User Guide - Release R15.000 - Page 284 of 629


JBC_BLOCK_SYSTEM14

DESCRIPTION
When this environment variable is set, it calls SYSTEM(14) which results in a 100-millisecond delay.

VALUES
1

DEFAULT
Not set

SETTING
As per normal environment variable, the environment variable can be set dynamically with PUTENV

UNIX Windows

SET JBC_BLOCK_SYSTEM14=1

JBC_ BLOCK_ SYSTEM14=1


export JBC_BLOCK_SYSTEM14

Note: Looking for type ahead data using SYSTEM(14) in a tight loop can have a detrimental impact on system performance because left
unchecked, such loops can consume all available system resources. With JBC_BLOCK_SYSTEM14 set, each call to SYSTEM(14) incurs a
100-millisecond delay, so a loop with SYSTEM(14) doesn’t waste system resources by looping too quickly.

It should be noted that the accuracy of the pause is dependent on the granularity of the system clock and the load on the system. Most oper-
ating systems and hardware will provide a granularity of 10 milliseconds.

JBase - User Guide - Release R15.000 - Page 285 of 629


JBASEUNIQUE

DESCRIPTION
When this environment variable is set to a directory, jBASE dynamically creates and deletes workfiles jBASEWORK_nn where nn is the port
number. This can be used in place of JBASETMP.

VALUES
Any valid directory.

DEFAULT
Not set

SETTING
UNIX Windows

JBASEUNIQUE=$HOME/jBASEWORK SET JBASEUNIQUE=%HOME%\jBASEWORK


export JBASEUNIQUE

Setting this environment variable is recommended in a high user environment as a single workfile for all ports can result in a bottleneck.

JBase - User Guide - Release R15.000 - Page 286 of 629


JBASE_ERRMSG_NON_NUMERIC

DESCRIPTION
Defines behaviour when a BASIC program encounters a numeric operation being attempted on a non-numeric value. The default behaviour is to
raise an error and drop into the debugger.

VALUES
1 Don’t display an error message

2 Don’t enter the debugger

16 Caller to place “0” in the target variable after operation

32 Caller to place “” in the target variable after operation

64 Caller to leave target variable alone after operation

128 Caller to place source variable in the target variable after operation

DEFAULT
0 - Raise an error and drop into the debugger.

SETTING
The value stored in a bit mask so different behaviours can be combined by adding them together. For example, to suppress the error message
and avoid going into the debugger – set the variable to 3. As per normal environment variable, the environment variable can be set dynamically
with PUTENV

UNIX Windows

JBASE_ ERRMSG_ NON_ NUMERIC=3 SET JBASE_ERRMSG_NON_NUMERIC=3


export JBASE_ERRMSG_NON_NUMERIC

Note: Supersedes JBASE_WARNLEVEL from previous versions of jBASE..

JBase - User Guide - Release R15.000 - Page 287 of 629


JBASE_ERRMSG_TRACE

DESCRIPTION
Defines behaviour when a BASIC program encounters an error

VALUES
1 – Log an error message to $JBCRELEASEDIR/tmp/jbase_error_trace

DEFAULT
0 – Do not log the error.

SETTING
The only valid values for this variable are 1 or 0. Setting this variable will not interfere with the behaviour set by other JBASE_ERMSG envir-
onment variables. As per normal environment variables, it can be set dynamically using PUTENV

UNIX Windows

JBASE_ ERRMSG_ TRACE=1 SET JBASE_ERRMSG_TRACE=1


export JBASE_ERRMSG_TRACE

Note: Supersedes JBASE_WARNLEVEL from previous versions of jBASE.

JBase - User Guide - Release R15.000 - Page 288 of 629


JBASE_ERRMSG_ZERO_USED

DESCRIPTION
Defines behaviour when a BASIC program encounters a null variable. The default behaviour is to raise an error and drop into the debugger.

VALUES
1 Don’t display an error message

2 Don’t enter the debugger

16 Caller to place “0” in the target variable after operation

32 Caller to place “” in the target variable after operation

64 Caller to leave target variable alone after operation

128 Caller to place source variable in the target variable after operation

DEFAULT
0 - Raise an error and drop into the debugger.

SETTING
The value stored in a bit mask so different behaviours can be combined by adding them together. For example, to suppress the error message
and avoid going into the debugger – set the variable to 3. As per normal environment variable, the environment variable can be set dynamically
with PUTENV

UNIX Windows

SET JBASE_ERRMSG_ZERO_USED=3
JBASE_ ERRMSG_ ZERO_ USED=3
export JBASE_ERRMSG_ZERO_USED

Note: Supersedes JBASE_WARNLEVEL from previous versions of jBASE.

JBase - User Guide - Release R15.000 - Page 289 of 629


JBASE_WIN_TERM_SVR

DESCRIPTION
This should be set on servers running Windows Terminal Server before starting the License Server, and for all sessions wishing to access jBASE
licences. It enables global access to shared memory to enable MTS sessions to obtain a jBASE licence.

VALUES
Set or unset.

DEFAULT
Unset.

SETTING
UNIX Windows

N/A SET JBASE_WIN_TERM_SVR=1

JBase - User Guide - Release R15.000 - Page 290 of 629


JBASE_SVR_SESSION

DESCRIPTION
On a machine with mixed enterprise and server licenses available, indicates that a server license is required.

VALUES
Set or unset.

DEFAULT
Unset.

SETTING
On sites with both server and enterprise licenses installed, an enterprise license will be assumed unless JBASE_SVR_ SESSION is set to 1.
With server only licenses installed, JBASE_SVR_SESSION must be set in order to obtain a license. Failure to do so will result in a licensing
error. With enterprise only licenses installed, setting this environment variable will not allow a license to be allocated and a license error will be
produced.

UNIX Windows

JBASE_ SVR_ SESSION=1 SET JBASE_SVR_SESSION=1


export JBASE_SVR_SESSION

JBase - User Guide - Release R15.000 - Page 291 of 629


JBC_INVERT_ALPHA_CHARS

DESCRIPTION
Provided to emulate input on UniVerse systems. If this environment variable is set, all INPUT, KEYIN() and IN statements will receive input
values in the opposite case. In other words, lower case characters will become upper case and vice-versa. Characters within cursor control
sequences are also inverted, consequently up, down, left and right arrows will no longer work as required with this variable set.

VALUES
Set or unset.

DEFAULT
Unset.

UNIX Windows

JBC_ INVERT_ ALPHA_ CHARS=1 SET JBC_INVERT_ALPHA_CHARS=1


export JBC_INVERT_ALPHA_CHARS

JBase - User Guide - Release R15.000 - Page 292 of 629


Internationalisation

JBASE_I18N

DESCRIPTION
Setting this environment variable switches on UTF8 processing in jBASE.

VALUES
Set or unset.

DEFAULT
Not set.

SETTING
UNIX Windows

JBASEI18N=1 SET JBASEI18N=1


export JBASEI18N

More information on Internationalisation can be found in the jBASE Internationalisation manual.

JBASE_CODEPAGE

DESCRIPTION
Setting this environment variable sets the codepage to use for UTF8 conversion. This will have no effect unless internationalisation is switched
on using JBASEI18N..

VALUES
Any valid code page. Use jcodepages utility for a list of supported code pages.

DEFAULT
Not set.

SETTING
UNIX Windows

JBASE_CODEPAGE=latin1 SET JBASE_CODEPAGE=latin1


export JBASE_CODEPAGE

More information on Internationalisation can be found in the jBASE Internationalisation manual.

JBASE_LOCALE

DESCRIPTION
Setting this environment variable sets the locale to use for UTF8 collation, sorting and date settings. This will have no effect unless inter-
nationalisation is switched on using JBASEI18N..

JBase - User Guide - Release R15.000 - Page 293 of 629


VALUES
Any valid locale. Use jlocales utility for a list of supported locales.

DEFAULT
Not set.

SETTING
UNIX Windows

JBASE_LOCALE=en_GB SET JBASE_LOCALE=en_GB


export JBASE_LOCALE

More information on Internationalisation can be found in the jBASE Internationalisation manual.

JBASE_TIMEZONE

DESCRIPTION
Setting this environment variable sets the timezone to use for UTF8 timestamp conversion into local time for display. This will have no effect
unless internationalisation is switched on using JBASEI18N..

VALUES
Any valid timezone. Use jcodepages utility for a list of supported code pages.

DEFAULT
Not set.

SETTING
UNIX Windows

JBASE_TIMEZONE=Europe/London SET JBASE_TIMEZONE=Europe/London


export JBASE_TIMEZONE

More information on Internationalisation can be found in the jBASE Internationalisation manual.

JBase - User Guide - Release R15.000 - Page 294 of 629


Development

JBCDEV_BIN

DESCRIPTION
Defines the directory where user executables will be built when programs are CATALOGed.

VALUES
Valid file path

DEFAULT
%HOME%\bin (Windows)
$HOME/bin (UNIX)

Note: It is good practice to set JBCDEV_BIN explicitly rather than relying on the default setting. This is because the value of the HOME
environment variable may change (for example after a LOGTO

The value of JBCDEV_BIN can be overridden with the CATALOG -o option.

Refer also: JBCDEV_LIB, PATH.

SETTING
As per normal environment variable

UNIX Windows

JBCDEV_BIN=/home/TESTJBASE/bin SET JBCDEV_BIN=C:\dev\TESTJBASE\bin


export JBCDEV_BIN

JBCDEV_LIB

DESCRIPTION
Defines the directory where user shared object libraries will be built when subroutines are CATALOGed.

VALUES
Valid file path

DEFAULT
%HOME%\lib (Windows)
$HOME/lib (UNIX)

Note: It is good practice to set JBCDEV_LIB explicitly rather than relying on the default setting. This is because the value of the HOME
environment variable may change (for example after a LOGTO).

The value of JBCDEV_LIB can be overridden with the CATALOG -L option.

Refer also: JBCDEV_BIN, JBCOBJECTLIST.

JBase - User Guide - Release R15.000 - Page 295 of 629


SETTING
As per normal environment variable

UNIX Windows

JBCDEV_LIB=/home/TESTJBASE/lib SET JBCDEV_LIB=C:\dev\TESTJBASE\lib


export JBCDEV_LIB

JBCTTYNAME

DESCRIPTION
This variable defines your UNIX tty name. If this variable is not defined then jBASE must use the UNIX system call ttyname () to locate it. On
some systems, this function call is very slow but the use of this variable will greatly improve execution start-up times.

VALUES
Any character string

DEFAULT
None

SETTING
As per normal UNIX environment, variable should be setup in the .profile before executing the initial jBASE program.

JBCTTYNAME=Jterm
export JBCTTYNAME

JBCERRFILE

DESCRIPTION
Sets the location of the jBASE error message file

VALUES
Valid path to a hashed file

DEFAULT
$JBCRELEASEDIR/jbcmessages (UNIX)”
%JBCRELEASEDIR%\jbcmessages (Windows)

SETTING
As per normal environment variable must be set before jBASE is invoked.

UNIX Windows

JBCERRFILE=/usr/global/jBASEerrors SET JBCERRFILE=C:\jstuff\jbcmessages


export JBCERRFILE

JBase - User Guide - Release R15.000 - Page 296 of 629


Notes: Setting this environment variable allows you to have more than one version of the messages displayed by jBASE. This could be
desirable if you want different messages or different behavior when an error is encountered, depending on the user. For example, to pre-
vent a program entering the debugger when an uninitialised variable is encountered, remove the ^WARNING^ string from the ZERO_
USED message.

JBCSPOOLERDIR

DESCRIPTION
This environment variable defines the directory where the jBASE spooler entries are located.

VALUES
Valid file path

DEFAULT
/usr/jspooler (UNIX)
C:\JJBASE30\jspooler

SETTING
As per normal environment variable

UNIX Windows

setup in the .profile before executing the initial set before the jSHELL is invoked. If using telnet it should be set before the first execut-
jBASE program able in REMOTE.cmd.

JBCSPOOLERDIR=/home/alternative/jspooler SET JBCSPOOLERDIR=C:\home\alternative\jspooler

JBC_DESPOOLSLEEP

DESCRIPTION
By default, the jBASE despooler processes on Windows check for queued jobs every 30 seconds. This environment variable can be used to
decrease or increase that interval. The environment variable is not required on UNIX because the despooler processes are sent a signal when a
new job has been generated.

VALUES
Number of seconds

DEFAULT
30

SETTING
Windows only: As per normal environment variable it should be set before form queues are started.

SET JBC_DESPOOLSLEEP=12

JBC_CRREQ

DESCRIPTION
Controls whether line feeds and form feeds are followed by a carriage return when printing to the spooler.

JBase - User Guide - Release R15.000 - Page 297 of 629


VALUES
0 No translation is performed

linefeed -> linefeed (unchanged)

formfeed -> formfeed (unchanged)

1 Specifies that a carriage return is required after each and every line feed when printing to the spooler

linefeed -> linefeed + carriage return

formfeed -> formfeed (unchanged)

2 Specifies that a carriage return is required after each form feed when printing to the spooler.

linefeed -> linefeed (unchanged)

formfeed -> formfeed + carriage return

3 specifies that a carriage return is required after each line feed and form feed when printing to the spooler.

linefeed -> linefeed + carriage return

formfeed -> formfeed + carriage return

DEFAULT
zero

Note: When printing to a Printronix printer on UNIX (which converts ‘linefeeds’ to ‘linefeed + carriage return’ but does not append ‘car-
riage return’ to ‘form feeds’) you should set JBC_CRREQ=two.

When printing binary data to a laser (or similar printer) on Windows you should set JBC_CRREQ=3

In addition, the device definition for the appropriate form queue should specify the -l and -n options to ‘jlp’ e.g. fqfred PROG jlp -d \\prin-
tername -l -n

Alternatively, use the default Windows printer e.g. STANDARD NT

SETTING
As per normal environment variable, it must be setup before connecting to jBASE.

UNIX Windows

JBC_ CRREQ=2 SET JBC_CRREQ=3


export JBC_CRREQ

JBCLISTFILE

DESCRIPTION
This environment variable specifies the file where stored lists are kept.

VALUES
Any valid path to a directory or hashed file

JBase - User Guide - Release R15.000 - Page 298 of 629


DEFAULT
If not set, jBASE will attempt to store lists in POINTER-FILE. If it can’t be opened then it will store lists in jBASEWORK.

SETTING
As per normal environment variable, See also List Storage.

UNIX Windows

JBCLISTFILE=/home/jim/mylists SET JBCLISTFILE=C:\globals\SAVEDLISTS


export JBCLISTFILE

JBCSCREEN_WIDTH

DESCRIPTION
Specifies the page width for paged terminal output, and overrides the value specified by the TERM type.

VALUES
Decimal number

DEFAULT
None

SETTING
As per normal environment variable, it should be setup before the jSHELL is invoked.

UNIX Windows

JBCSCREEN_ WIDTH=132 SET JBCSCREEN_WIDTH=132


export JBCSCREEN_WIDTH

JBCPRINTER_DEPTH

DESCRIPTION
This environment variable specifies the page depth for paged spooler output, and overrides the value specified by the TERM type.

VALUES
Decimal number

DEFAULT
None

SETTING
As per normal environment variable

JBase - User Guide - Release R15.000 - Page 299 of 629


UNIX Windows

Setup in the .profile before executing the initial jBASE program SET JBCPRINTER_DEPTH=112

JBCPRINTER_ DEPTH=112 Set before any jBASE program is invoked.


export JBCPRINTER_DEPTH

JBCPRINTER_WIDTH

DESCRIPTION
Specifies the page width for paged spooler output, and overrides the value specified by the TERM type.

VALUES
Decimal number

DEFAULT
None

SETTING
As per normal environment variable

UNIX Windows

setup in the. profile before the jbcconnect command. set before any jBASE program is invoked.

JBCPRINTER_ WIDTH=125 SET JBCPRINTER_WIDTH=125


export JBCPRINTER_WIDTH

jBASE Remote File Server (jRFS)

JBCNETACCESS
DESCRIPTION

Defines the location of the jRFS security access file jnet_access

VALUES

Valid file path

DEFAULT

/usr/jbc/config (UNIX)

%JBCRELEASEDIR%\config (Windows)

SETTING

As per normal environment variable

UNIX Windows

JBCNETDIR=/usr/jJBASEsetup SET JBCNETDIR=C:\JJBASESETUP


export JBCNETDIR

JBase - User Guide - Release R15.000 - Page 300 of 629


JBCNETDIR
DESCRIPTION

Defines the location of the jRFS configuration files

VALUES

Valid file path

DEFAULT

/usr/jbc/config (UNIX)

%JBCRELEASEDIR%\config (Windows)

SETTING

As per normal environment variable

UNIX Windows

JBCNETDIR=/usr/jJBASEsetup SET JBCNETDIR=C:\JJBASESETUP


export JBCNETDIR

JRFS_REMOTE_JQL
DESCRIPTION

Specifies that the jQL command will run on the remote server and send the data back rather than querying line by line over the network

VALUES

DEFAULT

Not set

SETTINGS

As per normal environment values

UNIX Windows

JRFS_ REMOTE_ JQL=1 SET JRFS_REMOTE_JQL=1


export JRFS_REMOTE_JQL

JBase - User Guide - Release R15.000 - Page 301 of 629


JRFS_LOCALPATH_JQL
DESCRIPTION

Specifies that the jRFS Server process will use the file name as 'opened' on the remote system
rather than using the file name specified in the original select statement.

VALUES

DEFAULT

Not set

SETTINGS

As per normal environment values

UNIX Windows

JRFS_ LOCALPATH_ JQL=1 SET JRFS_LOCALPATH_JQL=1


export JRFS_LOCALPATH_JQL

JRFS_SERVERNAME
DESCRIPTION

Allows the jRFS client to override the service port.

VALUES

DEFAULT

Not set

SETTINGS

As per normal environment values

UNIX Windows

JRFS_ SERVERNAME=1 SET JRFS_SERVERNAME=1


export JRFS_SERVERNAME

JBASE_GROUP_LOCK
DESCRIPTION

Allows the POSIX semaphore locking to override the default locking in UNIX. This setting is to handle the jBASE scalability problem in UNIX
based systems.

VALUES

JBase - User Guide - Release R15.000 - Page 302 of 629


DEFAULT

Not set

SETTINGS

As per normal environment values

UNIX Windows

JBASE_ GROUP_ LOCK=1 NA


export JBASE_GROUP_LOCK

JBase - User Guide - Release R15.000 - Page 303 of 629


Deployment

The jBASE JDBC Driver is packaged as a Java Archive (jar) file.

To use the JDBC Driver from a non-managed client application, it necessary to place this archive inside your CLASSPATH.

To deploy this archive on a managed environment it is necessary to configure a deployment descriptor specific to the application server.

JBase - User Guide - Release R15.000 - Page 304 of 629


JBase - User Guide - Release R15.000 - Page 305 of 629
JBoss deployment
The following deployment descriptor is used by JBoss to load the jBASE JDBC Driver, as specified by “driver-class”. This file should be mod-
ified according to deployment requirements.

jbasejdbc-ds.xml

<?xml version="1.0" encoding="UTF-8"?>

<!--========================================================================== -->

<!-- -->

<!-- JBoss deployment descriptor for jBASE JDBC Data Sources                  -->

<!-- -->

<!-- ========================================================================= -->

<datasources>

<!—jBASE JDBC Data Source -->

<local-tx-datasource>

<jndi-name> jdbc/jBaseJdbcDS </jndi-name>

<connection-url>

jdbc:jbase:thin:@127.0.0.1:20002/mytestaccount

</connection-url>

<driver-class>

com.jbase.jdbc.driver.JBaseJDBCDriver

</driver-class>

<user-name> test </user-name>

<password> test </password>

</local-tx-datasource>

</datasources>

After configuring the deployment descriptor, follow the steps below to deploy the jBASE JDBC driver:

l Copy the jBASE JDBC Driver (jbasejdbc.jar) archive to the lib directory of the JBoss default configuration.
l Copy the JBoss deployment descriptor to the deploy directory of the JBoss default configuration.

JBase - User Guide - Release R15.000 - Page 306 of 629


Deployment

The jBASE JDBC Driver is packaged as a Java Archive (jar) file.

To use the JDBC Driver from a non-managed client application, it necessary to place this archive inside your CLASSPATH.

To deploy this archive on a managed environment it is necessary to configure a deployment descriptor specific to the application server.

JBase - User Guide - Release R15.000 - Page 307 of 629


JBase - User Guide - Release R15.000 - Page 308 of 629
JBoss deployment
The following deployment descriptor is used by JBoss to load the jBASE JDBC Driver, as specified by “driver-class”. This file should be mod-
ified according to deployment requirements.

jbasejdbc-ds.xml

<?xml version="1.0" encoding="UTF-8"?>

<!--========================================================================== -->

<!-- -->

<!-- JBoss deployment descriptor for jBASE JDBC Data Sources                  -->

<!-- -->

<!-- ========================================================================= -->

<datasources>

<!—jBASE JDBC Data Source -->

<local-tx-datasource>

<jndi-name> jdbc/jBaseJdbcDS </jndi-name>

<connection-url>

jdbc:jbase:thin:@127.0.0.1:20002/mytestaccount

</connection-url>

<driver-class>

com.jbase.jdbc.driver.JBaseJDBCDriver

</driver-class>

<user-name> test </user-name>

<password> test </password>

</local-tx-datasource>

</datasources>

After configuring the deployment descriptor, follow the steps below to deploy the jBASE JDBC driver:

l Copy the jBASE JDBC Driver (jbasejdbc.jar) archive to the lib directory of the JBoss default configuration.
l Copy the JBoss deployment descriptor to the deploy directory of the JBoss default configuration.

JBase - User Guide - Release R15.000 - Page 309 of 629


Developers Guide

The following section provides a detailed guide on how to connect and access the jBASE server.

JBase - User Guide - Release R15.000 - Page 310 of 629


JBase - User Guide - Release R15.000 - Page 311 of 629
jAgent
jBASE jAgent is a server-side jBASE component which must be listening on a user-defined TCP port on the remote jBASE instance. It accepts
socket connections to process incoming requests from the JDBC Driver. Please refer to the jBASE jAgent user guide for more information on
how to configure and start jAgent.

JBase - User Guide - Release R15.000 - Page 312 of 629


JBase - User Guide - Release R15.000 - Page 313 of 629
Connecting to jBASE
JDBC provides two mechanisms to establish a connection to a data source:

l DriverManager: This class requires an application to load the specific JDBC driver which in our case would be the jBASE JDBC
Driver. This interface is typically used on a non-managed two-tier deployment scenario where a java naming service is not available.
l DataSource: This interface is preferred on managed scenarios because JNDI is typically used to lookup a data source. The advant-
ages of having a data source managed by the application are e.g. connection pooling, security and distributed transaction processing for
XA-compliant JDBC drivers as is the jBASE JDBC driver.

DataSource and DriverManager provide the following methods to create a new connection.

For more information on these methods, please read the JDBC API documentation.

l getConnection(String url): Obtain a new connection for the specified connection string. Connection properties must be specified
inside the connection string.
l getConnection(String url, String user, String password): Obtain a new connection for the specified connection string. Connection
properties, except user and password must be specified inside the connection string.

DriverManager provides an additional method:

l getConnection(String url, Properties info): Obtain a new connection for the specified connection string. The second parameter spe-
cifies the connection properties.

Authentication
jAgent will attempt to authenticate a user given the user credentials provided to the getConnection() method.

The jBASE JDBC Driver implements the following connection properties to provide user credentials:

l user : Specifies the user to be authenticated


l password : Specifies the user’s password

Encryption
jAgent can be configured to use SSL encrypted connections for deployment scenarios which require enhanced security.

The jBASE JDBC Driver implements the following connection properties:

l SSL [Default value:  false] :  Specifies whether the connection should use SSL encryption. SSL should only be
used if the jAgent instance running on the jBASE server has also been configured to accept SSL connections.
l enableNaiveTrustManager        [Default value:  false] : This property forces the JDBC Driver to trust all server certificates.

Example using the DataSource interface:

Connectioncx = null;

try {

InitialContext ic = new InitialContext();

Object cxfObj = ic.lookup("java:comp/env/jdbc/jBaseDB");

DataSource cxf = (DataSource) cxfObj;

cx = (Connection) cxf.getConnection();

} catch(NamingException e) {

// error

JBase - User Guide - Release R15.000 - Page 314 of 629


}

Example 1 using the DriverManager interface:

//Load jBASE JDBC Driver

Class.forName("com.jbase.jdbc.driver.JBaseJDBCDriver");

//Set connection properties and request a new connection

String url = "jdbc:jbase:thin:@127.0.0.1:20002";

Properties cxProps = new Properties();

cxProps.setProperty("user", "test");

cxProps.setProperty("password", "newpassword");

cxProps.setProperty("SSL", "true"); //Enable SSL

cxProps.setProperty("NaiveTrustManager", "true");

Connection cx = DriverManager.getConnection(url, cxProps);

Example 2 using the DriverManager interface:

//Load jBASE JDBC Driver

Class.forName("com.jbase.jdbc.driver.JBaseJDBCDriver");

//Set connection properties and request a new connection

String url = "jdb-


c:jbase:thin:@127.0.0.1:20002/MyTestAccount?user=test&password=newpassword&SSL=true&NaiveTrustManager=true";

Connection cx = DriverManager.getConnection(url);

JBase - User Guide - Release R15.000 - Page 315 of 629


JBase - User Guide - Release R15.000 - Page 316 of 629
Closing a connection
After finishing with the connection, it must be closed:

cx.close();

JBase - User Guide - Release R15.000 - Page 317 of 629


JDBC API reference

The jBASE JDBC 2.0 Driver implements a subset of the JDBC 2.0 API.

Please read the JDBC specification documentation or refer to the JDBC API javadoc documentation for further information.

The following example shows how a client application executing an SQL SELECT query and display the obtained result set:

Statement stat = null;

try {

//Create an SQL statement and perform a SQL SELECT query

stat = cx.createStatement();

ResultSet rs = stat.executeQuery("SELECT NAME FROM MYTABLE");

//Obtain the meta data associated to the result set to print the no. of columns

ResultSetMetaData rsMetaData = rs.getMetaData();

System.out.println("Number of columns: " + rsMetaData.getColumnCount());

//Fetch all rows and display the first column

while(rs.next()) {

System.out.println("NAME: " + rs.getString("NAME"));

} catch(SQLException e) {

throw e;

} finally {

closeDB(stat);

JBase - User Guide - Release R15.000 - Page 318 of 629


JDBC Driver

Contents:

l Overview
l Deployment
l Developers Guide
l JDBC API reference
l Resources

JBase - User Guide - Release R15.000 - Page 319 of 629


Overview

This user guide provides detailed instructions for the configuration and deployment of the jBASE JDBC 2.0 Driver.

The jBASE JDBC 2.0 Driver is a jBASE component implementing the JDBC API. The JDBC API is part of the JavaTM 2 Platform Standard
Edition 5.0 (J2SETM).

The following diagrams show two of the most common deployment scenarios. In both cases, the JDBC API implemented by the jBASE JDBC
2.0 Driver provides client applications with the ability to perform SQL queries against a jBASE server.

Two-tier model:

This model represents deployment scenarios where a Java Client Application has the responsibility to create and manage connection, trans-
action and security resource.

Three-tier model:

A three-tier deployment scenario would often involve an application server hosting different application components as e.g EJBs, servlets, etc.
Deploying the jBASE JDBC Driver on a J2EE application server does not only allow those applications to perform SQL queries against jBASE,
but also allows the application server to manage its connections, transactions and security aspects.

JBase - User Guide - Release R15.000 - Page 320 of 629


JBase - User Guide - Release R15.000 - Page 321 of 629
Assumptions
This document describes many concepts and methodologies that are highly technical in nature, and as such prerequisite knowledge of the fol-
lowing is considered essential:

l Java Standard Edition


l Java Enterprise Edition
l SQL
l jBASE
l Secure Sockets Layer (SSL) protocol

JBase - User Guide - Release R15.000 - Page 322 of 629


Resources

Java JDK - http://java.sun.com

JDBC Specification and API - http://java.sun.com/products/jdbc/download.html

J2EE Connector Architecture (JCA) Specification - http://java.sun.com/j2ee/connector/

JBoss - http://www.jboss.org/

JBase - User Guide - Release R15.000 - Page 323 of 629


jDLS Distributed LockService

l Overview
l Distributed Lock Service Deployment
l Client Distributed Lock Deployment
l jBASE Distributed Lock Service process flow
l Lock Mechanisms
l Distributed Lock Information
l Utilities
l Resilience
l Recovery

JBase - User Guide - Release R15.000 - Page 324 of 629


Overview

Although T24 has been successfully deployed over Multiple Applications Servers, certain idiosyncrasies related to operating systems, per-
formance and recovery of file locks over networked file systems have prompted the requirement to provide an alternative lock strategy for Mul-
tiple Application Server deployment. As such the jBASE Distributed lock service is now offered as an alternative mechanism, to the networked
file system, by which locks can be propagate between servers.

The Distributed lock service simply extends the existing lock mechanisms already available within jBASE by the provision of a distributed lock
interface.

The Distributed lock service can be deployed as a service executing on a dedicated server or, as is more likely, deployed on one or two of the
Application Servers in the Multiple Application Server configuration.

The Distributed lock service is provided via a daemon process executing on Linux/Unix systems or as an installable service for the Windows
platform. The Distributed lock service can be initiated using either the lower case form of the executable, ‘jdls’, or the jBASE capitalized con-
vention for process daemons, jDLS, (jBASE Distributed Lock Service).

The Distributed lock service also supersedes the jRLA, (jBASE Record Lock Arbiter), which provided the shared memory lock mechanism for
record locks. Linux/Unix system boot scripts should be modified to initialise the lock mechanism using the jDLS rather than the jRLA execut-
able.

Client processes on the Application Servers are configured to connect to the distributed lock service in order to request a lock be taken,
request the status of a lock or request locks be released. Once initialised the client remains connected to the distributed lock service for the
remainder of the life of the client process, with all lock requests issued and acknowledged through the same connection.

The connection comprises of a TCPIP socket, which uses a network byte oriented structure to pass specific lock only information. The inform-
ation for example being lock type, client port number, client process id, client thread id, etc. No application data is passed over the network
and hence there is no requirement for message encryption. The use of the TCP protocol is deliberate such that any break in network service can
be detected quickly and if enabled, resilience activated

Once initialised the jBASE Distributed Lock Service process undertakes two distinct operations:

The first operation is to initialise the Shared memory lock table and then continuously monitor the lock table for orphaned locks and tidy up as
required. This operation was formerly undertaken by the jRLA daemon process and effectively remains exactly the same.

The second operation is to initialise a socket listener for connecting clients who wish to take locks on the local system. This operation is star-
ted as a second process on Linux and Unix system and as an additional thread on Windows. The distributed lock listener continuously listens
for client connections, when a client connection is detected a separate independent process is started that will handle all the lock requirements
for the connecting client process.

Each lock server/service process once started runs as a single thread within its own process space and is completely independent from any
other lock server/service process as well as the daemon listener process. This enables the lock listener service to be stopped without impacting
existing lock server processes and also ensures any potential lock server process failure does not impact other already executing client pro-
cesses.

This approach provides for a robust, scalable and easily extendable implementation, which avoids many of the complications and restrictions
involved with multi threaded servers such as forked threads, signal handling and error recovery.

The one to one process relationship ensures that locks can be handled by either of the currently available locking strategies, i.e. Shared memory
locks or OS file locks and that locks can be easily identified to point of origin and the release of locks will be automatic in the event of a prob-
lem with the client process or client Application Server failure.

Although the Distributed Lock Service can be deployed on dedicated servers the more usual configuration is to deploy the Lock Service on one
or two of the Application Servers in the Multiple Application Server environment. Quite often a mix of Application Servers are used whereby the
most powerful Application Server is used for core processes and other Application Servers used for online processing such as enquires, etc. In
this case it is more efficient to configure the main Application Server with the Distributed lock service for the other Application Servers and use
local lock processing rather than Distributed locking for the core processes. The local processes will automatically detect this configuration,
such that all local lock requests will automatically use the same lock mechanism as the Distributed Lock service, whereby local and distributed
locks become seamlessly integrated.

JBase - User Guide - Release R15.000 - Page 325 of 629


Distributed Lock Service Deployment

Once the servers that will provide the distributed lock service have been determined the service should be configured and deployed as follows: 

The jBASE software should be installed local to the distributed lock server and JBCRELEASEDIR and JBCGLOBALDIR environment variables
configured for the user id by which the lock service will execute. In the case of a standalone lock server no license installation is required as the
Distributed lock service is unlicensed.

Once the jBASE release is installed and configured then the Distributed Lock Service can be initialised and started in background. 

The full set of options for the Distributed lock service can be displayed using the – h option on the jDLS command line. However specific
option combinations for the Distributed Lock Service daemon are as follows:

jdls -i {-bPTAD} {-sr,g} {-tnn}

jdls -k {-AD}

jdls -K {-o}

Where :

-A            Arbiter only, do not start/stop distributed listener

-b            Run in the Background (Normal mode of operation)

-D            Distributed listener only, do not start/stop lock monitor

-i             Initialise shared memory.

-k            Kill the Shared memory Lock Monitor and/or Listener

-snn,mm   Set Shared memory lock table size to 'nn' record locks over 'mm' groups

-tnn         Set tidy up period to nn minutes

-K            Kill the IPC resources , shared memory and semaphores

-P            Port based locks used (default is process id based locks)

-T            Time stamp all shared memory locks

Server Deployment Examples


jDLS –ibs13000,50

This command initializes the jDLS to start both the jDLS Shared memory lock monitor service and the jDLS Distributed lock listener service in
background. The shared memory will be configured to provide 13000 locks with 50 locks per group. The lock table algorithm will actually use
the next prime number for the number of groups to provide a better spread of locks over the groups and so in this case configure the shared
lock table with 13150 locks in 263 groups with 50 locks per group. 

jDLS –ibD

This command instructs the jDLS to initialize ONLY the jDLS Distributed lock listener service. Unless the jDLS Shared memory lock mon-
itor/arbiter service had been previously started then OS file locks will be used for the default lock mechanism for both distributed locks and
local process locks. 

jDLS -kD

This command will stop ONLY the jDLS Distributed lock listener service. If active the jDLS Shared memory lock monitor/arbiter service will
be unaffected. 

jDLS –k

This command will stop both the jDLS Distributed lock listener and the jDLS Shared memory lock monitor/arbiter service.         

JBase - User Guide - Release R15.000 - Page 326 of 629


jDLS –K

This command will remove the IPCS resource. Note all processes must be disconnected and the effective user id for the command must have
adequate permissions to remove the resource.

Note some command line options are not applicable to Windows as the jDLS executable runs in background as a Windows Service. See the jdls
–h command display on Windows for list of available options.

Installing jDLS as a Windows Service 


The jBASE Distributed Lock Service should be installed as a Windows Service when used on the Windows operating system. 

Along with other jBASE services, the jBASE Distributed Lock Service can be installed using the jBASE jServControl command from the Win-
dows console command line. 

e.g.

jServControl –v –s manual –p%JBCRELEASEDIR%\bin\jDLS.exe jDLS install

Once installed the service can then be stopped or started using Windows Services panel. 

Alternatively the service can also be stopped or started from the command line, via the jBASE jServControl command. 

jServControl –v jDLS start | stop

To remove the service, use the jServControl command. 

jServControl –v jDLS remove

All jBASE processes must be disconnected before stopping and removing the jDLS service.

JBase - User Guide - Release R15.000 - Page 327 of 629


Client Distributed Lock Deployment

To configure the client system to use the Distributed Lock Service, each client user must be configured with the JDLS environment variable.
This variable should be set in the users profile prior to program execution.

To be properly effective ALL users of the same database must be configured with exactly the same Distributed Lock Service parameters, oth-
erwise locks will NOT be correctly respected and data inconsistencies may occur. 

The following basic options can be specified in the JDLS environment variable: 

JDLS={SERVER=Hostname{, Port}}{,SERVER2=Hostname{, Port}}

Where:

SERVER Specifies the primary lock service specification

SERVER2 Specifies the secondary lock service specification for resilience.

Hostname is either the DNS hostname or the dotted IP address of the system where the jBASE Distributed
Lock Service is executing.

Port is the socket port number  (default 50002) on which the jBASE Distributed Lock Service is listen-
ing.

Note: The above specifications are completely optional as denoted by the braces, although SERVER2 spe-
cification has no meaning without specification of SERVER. If SERVER is not specified but the
JDLS environment is set then the configuration will default to ‘localhost’ and port 50002.

Additional configuration options and their descriptions are as follows:

WAIT

The WAIT option can be used to control the action of distributed lock retries. If the WAIT option is configured then the client will wait for
acknowledgement that the lock request has been completed without any interim communication, (see “distributed lock retries”). With this
option set the default acknowledgement timeout period is not used. This option is not recommended as processes may wait a considerable
time in the case of lock contention without update to the lock status of the process.

TIMEOUT=Seconds

The TIMEOUT option can be used to override the timeout period, within which any distributed lock request must be acknowledged. The
default timeout period is set for thirty seconds. This period allows for multiple retries for the lock on the server system, as such should only be
adjusted upward.

BINARY

The BINARY option can be used to intercept all binary type locks, i.e. locks other than record locks and redirect them to the Distributed Lock
Service. Locks that would normally be taken on the local system will be intercepted and redirected to the Distributed Lock Service, such that
they can be propagated and hence respected across multiple systems. This option should not be required except when using jBASE Hash files
over NFS and/or File and Execution Locks.

OSLOCKS

The OSLOCKS option can be used to force all record locks to be routed via the OS file lock path such that OS file locks are taken on the Dis-
tributed Lock Service Server by default rather than using the configured lock mechanism on the lock server.

LOCK=EXTERNAL|INTERNAL|ALL

JBase - User Guide - Release R15.000 - Page 328 of 629


The LOCK option can be used to differentiate the interception of locks for internal or external lock handlers. The default is for ALL locks both
internal and external to be intercepted and redirected to the Distributed Lock Service. However certain external database drivers may require
their own lock functions be invoked, in which case LOCK option should be set to INTERNAL. RDBMS drivers use INTERNAL locking and
hence the default configuration or INTERNAL value will redirect all record locks required for the application irrespective of the underlying
RDBMS locking schemes.

VERBOSE | TRACE=Tracefile

The TRACE option will override the VERBOSE option such that Distributed Lock trace information will be redirected from standard error to
the specified trace file. These options are intended for debugging and problem analysis only.

The JDLS client connection configuration can be tested using the –C option to the jDLS executable at the command line.

e.g. jDLS –Cteststring

If the Distributed Lock Service cannot be reached the process will time out and display the following error message: 

Client: Using host 'localhost', service '50002'

Client: Unable to allocate socket

If the Distributed Lock Service cannot be reached for a lock request the process will time out and exit with the following message: 

Client: unable to connect to distributed lock service, locks not enabled

Client: connection failed for host ‘10.44.1.56’, service '50002', error Connection refused

JBase - User Guide - Release R15.000 - Page 329 of 629


jBASE Distributed Lock Service process flow

Locks are taken either in the shard memory lock table or via local OS file locks

JBase - User Guide - Release R15.000 - Page 330 of 629


Lock Mechanisms

There are two types of lock mechanism that can be implemented on the lock server used for the jDLS, jBASE Distributed Lock Service. One
being shared memory locking the other being OS file locks.

When starting the jDLS service the default is to use the shared memory lock mechanism. The jDLS service initialisation, by default, will start
both the jDLS Shared memory lock monitor service and the jDLS Distributed lock listener service.

The jDLS Shared memory lock monitor will create a shared memory structure for the locks, which is then used for inter process com-
munication of lock information by both jDLS lock server processes, which acquire locks on behalf of remote jBASE client processes and also
local jBASE processes executing on the same system as the jDLS Lock Service. If the shared memory lock area is already allocated then the
shared memory lock group structure cannot be changed and any lock configuration options specified on the jDLS command line ignored.

The default lock mechanism can be force to be OS file locks by inhibiting the initialisation of the jDLS Shared memory lock monitor process. If
the jDLS Shared memory lock monitor service is not initialised then the default lock mechanism will be OS file locks.

OS Lock Mechanism
To initialise the lock service without the jDLS Shared memory lock monitor, start the lock service using the –D option. This option causes
only the jDLS Distributed lock listener service to be initialised and as such the default lock mechanism will be OS file locks.

e.g.

jDLS -ibD

When the jDLS Distributed lock service is active but using the OS file lock mechanism, all record locks are taken on lock files created in the
/tmp/jbase subdirectory for Unix systems or the %SYSTEMROOT%\jbase subdirectory for Windows. The file name of the lock file represents
an 8 digit hexadecimal value of the inode and device numbers of the original file or pseudo file.

e.g.

/tmp/jbase/jlock_xxxxxxxx_yyyyyyyy

Where ‘xxxxxxxx’ is the hexadecimal value of the inode and ‘yyyyyyyy’ is the hexadecimal value of the device.

Note: When the jDLS Distributed lock service is active and a physical file is used, rather than pseudo MD/VOC entries, then the device number
is defaulted to a value of –1. The reason for defaulting the device number to a value of –1 is because the device number allocated to the moun-
ted NFS partition can vary on each of the Multiple Application Servers.

To initialise the lock service to use jDLS Shared memory locking simply use the –ib options (initialise services and run in background) on the
jDLS command line. This is the default configuration for jDLS when run as a Windows Service.

e.g.

jDLS -ib

Shared Memory Lock Mechanism


The shared memory lock monitor process is essentially the same as the eld jRLA program, in that its sole function is to periodically examine
the state of the shared memory lock table and look for orphaned locks. Orphaned locks can occur when a process exits prematurely without
being able to wrap up correctly and release associated locks. These premature processes exits can be due to resource allocation, program failure
or because the process has been deliberately interrupted by a fatal signal (usually signal 9) from another process. The default tidy up period is
set at five minutes.

The Shared Memory Lock Monitor will scan all the locks in the shared memory lock table on a tidy up and when a suspected orphaned lock is
discovered, the lock is thoroughly checked against the process identifier to ensure that the associated process is no longer in existence; if that
is the case then the lock is released, as such locks left behind by processes will automatically be cleaned up every five minutes. 

JBase - User Guide - Release R15.000 - Page 331 of 629


It should not be necessary to clean up locks taken by remote client, which exit prematurely, as the lock server process handling locks on behalf
of the client should automatically handle the lock release on detection of communication failure with the client process. 

The shared memory lock table is currently only used for record locks as group locks or other binary locks are taken as OS file locks on the phys-
ical files or pseudo files in /tmp/jbase_lock or %SYSTEMROOT\jbase_lock directories.

The Shared Memory Lock Monitor can be stopped and restarted, (using the –k and –ib options together with the –A option on the jDLS com-
mand line), without interfering with the Distributed Lock Listener service or the currently active lock sever processes working on behalf of
remote clients. However this action is not recommended, and should only be used in extreme circumstances, as the preferred locking mech-
anism should be chosen prior to any local or remote client connection and the Distributed Lock Service initialized accordingly

JBase - User Guide - Release R15.000 - Page 332 of 629


Distributed Lock Information

Although the lock mechanisms keeps track of outstanding locks taken by processes, or even threads in the case of the shared memory lock
table, this information is relatively limited and usually insufficient to easily determine lock ownership.

In the case of OS file locks all that is retrieval is the process id of the process, which has taken the lock and maybe the device and inode of the
file or stub file. The shared memory mechanism provides additional independent information in the lock table such as port number, record key
and thread id. Unfortunately the record key alone is not usually enough for lock diagnosis and additional information such as the file/table
information is also usually required. Finding the filename associated with an inode may not be simple for some platforms and in later Multiple
Application Servers implementations, which will not use stub files this information will be unavailable.

The only process that knows the application file/table name and other associated information is usually the client process, as this was the pro-
cess that opened or referenced the file/table and obtained the variable on which to take or release locks.

As such when using distributed locking, the internal client lock and file/table information is periodically written out to a native file using the
port number for the process. This port information is written to the JBCRELEASEDIR/proc/info directory of the lock server system.

In the case of remote clients the information is sent to the associated lock server processes, which in turn write the data, with appended stat-
istics, into the info directory on behalf of the client process.

In the case of local processes executing on the same system as the jDLS lock service, these processes write their lock and file information dir-
ectly into the JBCRELEASEDIR/proc/info directory.

This information can then be retrieved, interpreted and displayed by the lock and file utilities, such as SHOW-ITEM-LOCKS and LIST-OPEN-
FILES.

This procedure is also a change to the ‘polling’ procedure done by the utilities that would otherwise occur when not using jDLS, as it is not pos-
sible to use shared memory between Multiple Application Servers.

The client or local processes only write out lock information when the lock information has changed and the process is either initialised, block-
ing on a lock, no longer waiting on a blocked lock, about to get input or about to sleep. As such the lock information can only be used to
provide a snapshot of the lock or open file status for the Multiple Application Server processes at any one point in time. The lock information
is deleted on process exit however should a process exit abnormally this lock information may persist.

JBase - User Guide - Release R15.000 - Page 333 of 629


Utilities

There is essentially one utility program, although referenced by other program names, which is used to display record lock information, namely
SHOW-ITEM-LOCKS.

The jDLS executable can also be used directly to display the shared memory lock table information, but is unable to display associated file/t-
able name information.

SHOW-ITEM-LOCKS
The SHOW-ITEM-LOCK utility has been modified to include the IP address of the port when displaying information. The utility has also been
modified to obtain the lock information for each port from the JBCRELEASEDIR/proc/info directory when either the jDLS Lock Service is
deemed active on the system or the client JDLS environment variable is configured, thus enabling the utility to be executed from a remote cli-
ent system.

e.g.  note, the filename, etc fields have been modified/truncated to fit this document. 

show-item-locks information retrieved from process information entries generated in JBCRELEASEDIR/proc/info dir-
ectory on host 10.44.1.56

IPADDR PORT PID FILENAME RECORD KEY LOCK# PORT/-PID

0.0.0.0 2 15071 ac/FBNK.ACCOUNT 32549 0x58ba67d8,W ---

10.44.1.55 1000 15031 ac/FBNK.ACCOUNT 33537 0x0df361bc,W ---

127.0.0.1 4 15112 ac/FBNK.ACCOUNT USD163170001 0x6bc61286,W ---

Where:

Port 2 is a local process on the same system as the jDLS server and hence has a dotted address of 0. This pro-
cess (pid 15071) takes locks directly on the same server.

Port 1000 is a remote client (on system 10.44.1.56) with the JDLS environment variable configured as JDLS-
S=SERVER=10.44.1.56. The client process is communicating with the lock service (jDLS) on the lock server system
(10.44.1.56) and has an associated lock server process (15031). The dotted host address of the client system,
(10.44.1.55), is displayed by show-item-locks. The jDLS lock server process (pid 15031) has taken the lock on
record key 33537 on behalf of the remote client on port 1000 executing on the remote system, (10.44.1.55).

Port 4 is another local process on the same system as the active jDLS server but has also been configured with a
JDLS environment variable. This time the variable is set to use the default configuration and as such this pro-
cess is using the reserved loop back local host address of 127.0.0.1.

jDLS –dvL
In the above case the shared memory lock mechanism was deployed as the default locking mechanism.  As such the shared memory lock table
information can also be displayed using the –dvL command line options to the jDLS executable. 

e.g.  Executon of the jDLS command with –dvL option on system 10.44.1.56.

jDLS –dvL

JBase - User Guide - Release R15.000 - Page 334 of 629


Lock monitor at pid: 14960 - Active

Lock listener at pid: 14961 - Active

Program started: Thu Apr 27 17:28:17 2006

Time last ran: Thu Apr 27 18:26:30 2006

Time last tidied up: Thu Apr 27 18:23:50 2006

Lock retries: 0

Tidy-up time: 5 minutes

Locking mechanism: IPC semaphores based on THREAD id

Tidy-up operations: 0

Semaphore IDs: 1441792, 1474561

Memory: 6624 bytes used , 128544 bytes free

CPU Usage: 0.09 usr , 0.09 sys

Record locks outstanding

Group value pid type port i-node dev queued ipaddr key

89 0x0df361bc 15031 WRITE 1000 01483651 -1 None 10.44.1.55 33537

161 0x6bc61286 15112 WRITE 4 01483651 –1 None 127.0.0.1 USD163170001

189 0x58ba67d8 15071 WRITE 2 01483651 -1 None 0.0.0.0 32549

Record locks: 13150 locks maximum in 263 groups of 50 locks/group

3 locks currently in use

1 is max. locks found in one group

This display shows similar information to the show-item-lock utility however the file name information is not held within the shared memory
lock table, only the associated inode, also note the device information is defaulted to minus one as the values for the devices for the mounted
file partitions can vary between application servers and hence cannot be used. 

Additional information regarding the process and status of the Distributed Lock Monitor and the Distributed Lock Listener processes is dis-
played along with the time the Lock service was started.  For the Windows platform the process numbers for the two function would be the
same as the Lock Monitor and the Lock Listener run as different threads within the same process.

Lock Server processes


In the previous example of three locks the following lock service processes are in use on the lock server system (10.44.1.56). 

ps –ef | grep jdls

locks 14960 1 0 17:28 ? 00:00:00 jdls -ib

locks 14961 14960 0 17:28 ? 00:00:00 jdls -ib

locks 15031 14961 0 17:29 ? 00:00:00 jdls -ib

locks 15112 14961 0 17:41 ? 00:00:00 jdls -ib

JBase - User Guide - Release R15.000 - Page 335 of 629


Where:

The lock service has been started as user ‘locks’.

Process 14960 is executing as the Distributed Shared Memory Lock Monitor.

Process 14961 is executing as Distributed Lock Listener Service.

Process 15031 is executing on behalf of Port 1000 on client 10.44.1.55.

Process 15112 is executing on behalf of Port 4 on local host 10.44.1.56.

As can be seen from the utility displays, Port 2 is executing on the same local system as the distributed lock service, (10.44.1.56), on process
15071 and taking locks directly in the shared memory lock table.

ps –ef | grep 15071

betatest 15071 15064 0 17:30 pts/2 00:00:00 ED FBNK.ACCOUNT 32549

This example demonstrates the integration capabilities of the Distributed Lock Service whereby the distributed lock configuration can be adjus-
ted to take best advantage of system topology. For example a 32 CPU system mixed with a couple 4 CPU systems could be allocated to form
the Application Server tier. The lock service can be configured such that Distributed Lock Service executes on the 32 CPU system such that
lock intensive processing jobs like the COB, which would probably be best scheduled to run on the larger server, can run using the standard dir-
ect lock mechanisms avoiding network requirement for lock requests, whereas other online or interface processes could be enabled to process
on the smaller application servers and hence configured to communicate with the Distributed Lock Service for their lock requirements. The Dis-
tributed Lock Service is fully compatible with the existing lock mechanisms and hence the disparate systems can be fully integrated to coordin-
ate lock activity.

JBase - User Guide - Release R15.000 - Page 336 of 629


Resilience

Client Lock Resilience


The Distributed Lock mechanism provides lock resilience by simply duplicating the original lock request to a second Distributed Lock server.
The distributed lock resilience model allows for a single point of failure and two or more system configuration failures are not covered. Single
point of failure coverage is normally adequate for resilience technology. Network failure between localized systems is extremely rare especially
with duplicated network components.

In resilience mode the client process will issue a second lock request, to the secondary Distributed Lock server, only once the original lock
request has been acknowledged as successful by the primary distributed lock server. The response of the lock requests will be compared and if
the secondary response is different an error logged such that the problem can be investigated. As such the performance cost of resilience is an
additional socket send and receive message per lock request. While both primary and secondary Distributed Lock Servers continue to respond
the process is executing in resilient mode.

If communication to the primary Distributed Lock server should be interrupted or lost, an error is logged and then the client process will auto-
matically promote the secondary Distributed Lock server to take over from the original primary server and become the new primary. At this
point the duplication of lock requests will cease and the process will continue to communicate only with the new primary lock server. At this
point the process is also no longer resilient and any subsequent communication failure with the Distributed Lock server will result in the client
process wrapping up and exiting the client system.

If communication to the secondary Distributed Lock server should fail while in resilient mode, an error message is logged and the process con-
tinues to communicate only with the primary Distributed Lock server and is hence therefore no longer resilient.

Once communication fails to one or other of the Distributed Lock servers further communication with the failed server is never attempted for
the remainder of the lifetime of the process as attempting to do could cause lock confusion and undermine the lock mechanism. All com-
munication errors are logged to the jbase_error_trace. 

The resilient mode should not be used with a configuration that integrates with direct local locking processes, as the local processes do not
even communicate with the primary lock server let alone a secondary lock server. If resilience is required then all processes both local and
remote must be configured to communicate to the same primary and secondary Distributed Lock servers via the JDLS environment variable.

Server Lock Resilience


Client failure resilience is built into the Distributed Lock server processes, irrespective of resilience mode.

If communication with a client process fails then the distributed lock server process handling lock requests on behalf of that client will release
and outstanding locks and then exit. 

This procedure ensures that absent or misbehaving clients cannot continue to hold locks irrespective of the state of the client system. The
release of locks in this scenario, by the distributed lock server process, only effects the local system and has no effect on any other distributed
lock server executing on either another primary or secondary lock server system.

The Distributed Lock Listener service can be stopped or restarted, (using the –k and –ib options together with the –D option on the jDLS com-
mand line), without interfering with the communications of the currently connected remote clients.  Obviously new clients will be unable to
connect while the Distributed Lock Listener service is not currently listening, hence these options should be used with great care.

JBase - User Guide - Release R15.000 - Page 337 of 629


Recovery

Currently there is no automated procedure to recover the Distributed Lock Service on systems that have failed when using resilient mode, as
the lock table or OS file locks cannot be easily resynchronized with the current primary lock server and guarantee that all locks will be valid.

Once the failed system is recovered and the Distributed Lock service restarted, all remote client processes will need to exit and then reconnect
using the JDLS environment variable configuration in order to use the original Distributed Lock Service configuration and renew com-
munication with the restarted Distributed Lock Service.

This procedure ensures that all locks are released and retaken such that the lock table and/or OS file locks on both Distributed Lock Service
systems are correctly synchronized.

JBase - User Guide - Release R15.000 - Page 338 of 629


Query Language

jQL (or jBASE Query Language) is the data retrieval language for jBASE data. This query language uses english-like constructs to selectively
retrieve, sort and display data held in jBASE files (or in other databases through the relevant Direct Connect driver). jQL commands can be
entered directly at the shell prompt or embedded in jBC programs so that the data can be processed programmatically. 

Overview

jQL Sentences

jQL Predefined words and Symbols

jQL Sentence Construction

jQL Verbs

BSELECT

COUNT

EDELETE

ESEARCH

I-DUMP / S-DUMP

LIST

LIST-LABEL

LISTDICT

REFORMAT

SELECT

SORT

SORT - LABEL

SREFORMAT

SSELECT

File Modifiers

Types of Item List

Explicit Item-id list

Implicit Item-id list

Value Strings

Single and Double Quotes

Between Connective

Relational Operators

Logical Connectives

Synonyms

Left Ignore examples

Wild Card Examples

AND Connective Examples

Apparent item-id List Example

JBase - User Guide - Release R15.000 - Page 339 of 629


Further Examples of item Lists

Sort Criteria Clause

Output Specification Clause

CNV Connective

COL.HDG Connective

FMT Connective

Total Connectives

BREAK-ON Connective

Using Report Qualifier Keywords

GRAND-TOTAL

Throwaway Connectives

Field Qualifiers

Using Clause

Command Options

Macros

jBC Statements for use with jQL

JQLCOMPILE

JQLEXECUTE

JQLFETCH

JQLGETPROPERTY

JQLPUTPROPERTY

Conversion Processing

jQL Dictionary Conversions and Correlatives

TimeStamp “W{Dx}{Tx}”

Data Conversion

A Conversion

A: Expression Format

An Format: Embedded Decimals

An:expression Format

AE:expression Format

Format Codes

Summary of Operands

jQL Operands

Remainder Function

Substring Function

Operators and conversions

Arithmetic Operators

Relational Operators

JBase - User Guide - Release R15.000 - Page 340 of 629


Logical Operators

Concatenation Operator

IF STATEMENT

B Conversion

C Conversion

D Conversion

Pre processor Conversion

D1 D2 Conversion

F Conversion

The Stack

Order of Operation

Push Operator

Arithmetic F Code Operators

Miscellaneous Operators

Relational Operators

Logical Operators

Repeat Operators

Format Codes

G Conversion

L Conversion

MC Conversion

Changing Case

Extracting Characters

Replacing Characters

Converting Characters

Converting Numeric Values

MD Conversion

MK Conversion

Ml / MR Conversion

MP Conversion

MS Conversion

MT Conversion

Output Conversion

P Conversion

R Conversion

S Conversion

T Conversion

T File Conversion

JBase - User Guide - Release R15.000 - Page 341 of 629


U Conversion

jQL Output (Reports)

jQL Basic Subroutines

Record Structure

Sublist – V Code

Calling Subroutines from Dictionary Items

Data Definition Records

Default Data Definition Records

I-TYPES

User Subroutines

ICOMP

EXPLAIN

JBase - User Guide - Release R15.000 - Page 342 of 629


Overview

The jBASE Query Language (jQL) is a powerful and easy to use facility, which allows you to retrieve data from the database in a structured
order and to present the data in a flexible and easily understood format. You can enter jQL Commands from your terminal or embed jQL Com-
mands in applications programs, procs and paragraphs to access data in Direct Connect files. The language is characterized by the use of intu-
itive Commands that resemble everyday English language Commands.

You might for instance manage a retail department and need to review a particular set of figures, which requires the phrase: “Show me the sales
figures for January sorted in date order.”

The jQL Command would look like this:

LIST SALES WITH MONTH = “JANUARY” BY DATE

By using the jQL Command LIST with a file named SALES and your predefined data definition records such as MONTH and DATE, you can
construct complex ad-hoc reports directly from the Command line interface (>). You can also choose how you want the information presented;
displayed directly to your printer or to your screen; listed in date order, or in descending or ascending order. The choice is yours as jQL con-
tains a rich range of commands for listing, sorting, selecting and controlling the presentation of your details and is a safe language for end users.

With the exception of the “EDELETE” Command, jQL will not alter the contents of the source data files.

All jQL Command sentences begin with a verb-like Command such as LIST or SELECT followed by a file name such as SALES or PERSONNEL,
and then a series of qualifiers and modifiers with which you control elements such as eligible data, report formatting, any totals that you want
to appear and so on.

Most data files on the system will have two assigned storage areas:

For the data (the data section) and

For the data definition records (the dictionary section)

Some files might be single level and others might have multiple data sections. (See the File Management chapter of the System Administrators
Guide for more details)

Data definition records kept in the dictionary portion of the file defines all the data fields in a file. These data definition records do not have to
exist (you can use defaults provided in the environment variables or even the dictionaries of other files). However, where you need to manip-
ulate ‘say’ dates (which are held in internal format), or to join data held in different files, you will find that one or more definition records will
be required for each data field.

The data definition records are simple to create and maintain.

EXAMPLE
Data definition records (or DICT records) allow you to specify the position of the data in a record (its field number); a narrative to be used as a
column heading;  any input or output conversions required (such as for dates); the data type (left or right justified, or text that will break on
word boundaries) and a column width, used in reports

Input and output conversion codes can also be used to manipulate the data by performing mathematical functions, concatenating fields, or by
extracting specific data from the field.

Multivalued Files
JBASE uses a three-dimensional file structure called a non-first normal form data model to store multiple values for a field in a single record
known as multivalued fields. A multivalued field holds data that would otherwise be scattered among several interrelated files. Two or more
multivalued fields can be associated with each other when defined in the file dictionary. Such associations are useful in situations where a
group of multivalued fields forms an array or are a nested table within a file. You can define multivalued fields as belonging to associations in
which the first value in one multivalued field relates to the first value in each of the other multivalued fields in the association, the second value
relates to all the other second values. Each multivalue field can be further divided into subvalues, again obeying any relationships between
fields.

JBase - User Guide - Release R15.000 - Page 343 of 629


JBase - User Guide - Release R15.000 - Page 344 of 629
jQL Sentences

A jQL Command sentence is entered at the shell in response to a Command prompt (:) or a select prompt (>). If a Command such as SELECT
or GET-LIST creates an implicit list whilst in jSHELL, it displays the select prompt. Each sentence must start with a jQL Command and can be
of any length. Press <ENTER> to submit the constructed sentence. If you enter an invalid Command, the system will reject it and display an
appropriate error message.

EXAMPLE
jsh ~ -->SORT jcustomers FIRSTNAME LASTNAME CITY STATE NUMUSERS WITH FIRSTNAME = "TED" AND NUMUSERS > “10” BY
CITY DBL-SPC HDR-SUPP (P

The verb in this case is SORT. The file specifier is jcustomers. The fields specified in the output specification are FIRSTNAME, LASTNAME,
CITY, STATE & NUMUSERS. The selection criteria specify that only those records with a FIRSTNAME of TED and with more than 10 users
should be returned. The sort criterion says to order the results by the CITY field. The format specifier  sets the output to be double spaced
with no header. The (P option sends all output to the printer rather than the screen.

Line Continuation
When you are typing words in response to the TCL prompt the system allows you to enter up to 240 characters before it performs an auto-
matic linefeed. You can extend a line by entering the line continuation characters. To enter the continuation sequence hold down the CTRL key
and press the underscore key (_), which may require you to hold down the shift key. Follow this combination immediately with the RETURN
key.

JBase - User Guide - Release R15.000 - Page 345 of 629


jQL Predefined words and Symbols

Use the following words and symbols as described in this manual as all have special significance within a jQL sentence. These words are
defined in each Master Dictionary (MD) and their definitions should not be changed in any way.

! # &

<  <= =

=< => > 

>=

A AFTER AN

AND ARE

BEFORE BETWEEN BREAK-ON

BSELECT BY BY-DSND

BY-EXP BY-EXP-DSND

CAPTION CHECK-SUM COL-HDR-SUPP

COL-SPACES COUNT

DATA DEL-SPC DET-SUPP

DICT

EACH EDELETE EQ

ESEARCH EVERY

FILE FOOTING FOR

GE GRAND-TOTAL GT

HASH-TEST HDR-SUPP HEADER

HEADING I-DUMP ID-SUPP

IF IN ISTAT

ITEMS LE LIST

LIST-ITEM LIST-LABEL LPTR

LT

NE NO NOPAGE

NOT

OF  ONLY OR

PAGE PG REFORMAT

S-DUMP SELECTSORT SORT-ITEM

SORT-LABEL SREFORMAT SSELECT

JBase - User Guide - Release R15.000 - Page 346 of 629


ST-DUMP STAT SUBVALUE

SUM SUPP T-DUMP

T-LOAD TAPE = THE

TOTAL USING VALUE

WITH WITHIN WITHOUT

JBase - User Guide - Release R15.000 - Page 347 of 629


jQL Sentence Construction

A jQL Command sentence must contain at least a verb and a File name. The verb specifies which process to perform and the filename indicates
the initial data source.

You can add optional clauses to refine the basic Command. You can use clauses to control the range of eligible record keys, define selection
and sorting criteria, or to specify the format of the output, and so on.

REMEMBER: only a verb and filename are required. The following list summarizes each element in the Syntax.

COMMAND SYNTAX
jQL-verb {DICT} file-specifier  {field-list} {record-list} {selection-criteria} {FROM #} {sort-criteria} {USING file- specifier} {macro-call} {out-
put-specification} {format-specification} {output-limiter}{(options}

SYNTAX ELEMENTS

Element Description

Verb One of the verbs like Commands detailed later. Most Commands will accept any or all of the
optional clauses

file modifier file modifiers DICT, ONLY=, WITHIN and TAPE modify the use of the file, and how it is accessed

file specifier Identifies the main data file to be processed. Usually the data section of a file, but could be a dic-
tionary or a secondary data area.

record-list Defines which records will be eligible for processing. Comprises an explicit list of record keys or
record selection clauses. An explicit list comprises one or more record keys enclosed in single or
double quotes. A selection clause uses value strings enclosed in single or double quotes and has
at least one relational operator. If no record list is supplied, all records in the file will be eligible
for processing unless an “implicit” record list is provided by preceding the Command with a selec-
tion Command such as GET-LIST or SELECT.

FROM list# A number from 0 through 10 of an active select list that contains record IDs. The query operates
on records whose IDs are in the select list.

Selection-cri- Qualify the records to be processed. Comprises a selection connective (WITH or IF) followed by a
teria field name. Field names can be followed by relational operators and value strings enclosed in
double quotes. Logical Connectives AND/OR ca also be used. Expressions can be parenthesized
to specify precedence.

sort-criteria Specify the order in which the data is returned. Comprises a sort modifier, such as BY or BY-
DSND, followed by a field name. Used also to “explode” a report by sorting lines corresponding to
multivalued fields by value, and to limit the output of values (see output specification).

USING file Defines an alternate file for use as the dictionary.


specifier

macro call jQL allows the use of macros to predefine parts of a sentence. The macro definition contains one
or more optional sentence elements. You invoke the macro by including its name in a sentence.
The jQL processor looks for the macro in the currently active dictionary and includes all of its text
parts in the sentence.

JBase - User Guide - Release R15.000 - Page 348 of 629


output- spe- Comprises the names of the fields to be included in the report, optionally preceded by a BREAK-
cification ON connective or ‘TOTAL’ connective. Print limiters (Values strings enclosed in double quotes
after the field name, optionally preceded by relational operators) can be used to restrict multivalue
output

Format spe- Comprise modifiers, such as HEADING, ID-SUPP, and DBL-SPC, which define the overall format
cification of the report.

output- lim- The WHEN clause, used to limit the output of multivalued fields
iter

report- qual- Special keywords used in formatting reports


ifiers

JBase - User Guide - Release R15.000 - Page 349 of 629


A Conversion

"A" codes provide many powerful features, which include arithmetic, relational, logical, and concatenation operators, the ability to reference
fields by name or FMC, the capability to use other data definition records as functions that return a value, and the ability to modify report data
by using format codes.

The A code also allows you to handle the data recursively, or “nest” one A code expression inside another.

SYNTAX SUMMARY
The A code function uses an algebraic format. There are two forms of the A code:

l A uses only the integer parts of stored numbers unless a scaling factor is included.
l AE handles extended numbers. Uses both integer and fractional parts of stored numbers.

COMMAND SYNTAX
A {n} {;expression}
AE;expression

SYNTAX ELEMENTS
n              is a number from 1 to 6 that specifies the required scaling factor.

expression            Comprise operands, operators, conditional statements, and special functions.

Comments: The A code replaces and enhances the functionality of the F code

A;expression evaluates the expression.

An converts to a scaled integer

An;expression converts to a scaled integer.

AE;expression evaluates the expression.

JBase - User Guide - Release R15.000 - Page 350 of 629


information

JBase - User Guide - Release R15.000 - Page 351 of 629


AE;expression Format

The AE format uses both the integer and fractional parts of stored numbers. Use format codes to scale do scaling of output..

EXAMPLES OF NUMERIC RESULTS

Data Record A Code

Field 1 Field 2 A;1 + 2 A3;1 + 2 AE;1 + 2

4 012 16 16000 16

-77 -22 -99 -99000 -99

0.12 22.09 22 22210 22.21

-1.234 -12.34 -13 -13574 -13.574

-1.234 123.45 122 122216 122.216

Does not allow Input Conversion

JBase - User Guide - Release R15.000 - Page 352 of 629


An;expression Format

The "An;expression" format performs the functions specified in expression on values stored with an embedded decimal point. It then converts
the resulting value to a scaled integer.

JBase - User Guide - Release R15.000 - Page 353 of 629


An Format: Embedded Decimals

The "An" format converts a value stored with an embedded decimal point to a scaled integer. The stored value’s explicit or implied decimal
point is moved n digits to the right with zeros added if necessary. Returns only the integer portion

Field 2 of the data definition record must contain the FMC of the field that contains the data to be processed.

JBase - User Guide - Release R15.000 - Page 354 of 629


AND Connective Examples

The following sentence lists information about ORDER numbered 200 to 399.

LIST ORDER => ‘200’ AND < ‘400’


The following sentence results in a report listing customer information only about customer 40823 because in the absence of a relational oper-
ator, assumes an equal (=). The only customer number greater than 40823and equal to 40825 is 40825.

LIST CUSTOMER > ‘40823’ AND ‘40825’

JBase - User Guide - Release R15.000 - Page 355 of 629


Apparent item-id List Example

The following sentences do not list information regarding 117 and 119 because they would not be on the implicit list. Although this sentence
seems to have an explicit item-id list and an item-id selection clause, the whole series is a selection clause because there is a relational operator
somewhere in the list.

SELECT ORDER GT ‘200’

42 RECORDS SELECTED

JBase - User Guide - Release R15.000 - Page 356 of 629


Arithmetic F Code Operators

The arithmetic F code operators work on just the top stack entry or the top two stack entries. They are:

+ Add the top two stack entries together and push result into entry 1.

- Subtract stack entries and push result into entry 1:

F - subtract entry 1 from entry 2

FS, FE - subtract entry 1 from entry 2

F - subtract entry 2 from entry 1 (ROS emulation)

*{n} Multiply the top two stack entries and push result into entry 1. If n is specified, the result is divided by 10
raised to the power of n.

/ Divide stack entries and push quotient into entry 1:

F - divide entry 2 by entry 1

FS, FE - divide entry 2 by entry 1

F - divide entry 1 by entry 2 (ROS emulation)

R Compute remainder from the top two stack entries and push result into entry 1:

F - remainder of entry 2 / entry 1

FS, FE - remainder of entry 2 / entry 1

F - remainder of entry 1 / entry 2

I Return the integer part of entry 1 to the top of the stack.

S Replace the multivalued entry 1 with the sum of the multivalues and subvalues.

JBase - User Guide - Release R15.000 - Page 357 of 629


Arithmetic Operators

Arithmetic operators are: 

+      Sum of operands

- Difference of operands

*      Product of operands

/       Quotient (an integer value) of operands

JBase - User Guide - Release R15.000 - Page 358 of 629


A: Expression Format

Performs the functions specified in expression on values stored without an embedded decimal point.

JBase - User Guide - Release R15.000 - Page 359 of 629


B Conversion

Provides interface for jBASIC subroutines or C functions to manipulate data during jQL processing. Synonymous with CALL code

See Calling Subroutines from Dictionary Items for more details.

JBase - User Guide - Release R15.000 - Page 360 of 629


Between Connective

The connective BETWEEN followed by two value strings is a shorthand way of saying ‘all values greater than the first value string and less than
the second’. The value of the second value string must be greater than the value of the first to select items. Value strings including special char-
acters ^, [ and ] are not valid.

JBase - User Guide - Release R15.000 - Page 361 of 629


BREAK-ON Connective

The BREAK-ON connective causes monitoring of the following fields for change permitting up to fifteen breaks within one sentence treated in
hierarchical left to right order. The first BREAK-ON in the sentence is the highest level.

When detected, the change in the value of the field outputs a blank line, followed by a line with three asterisks, and then another blank line. If
the BREAK-ON clause specifies text, it outputs the text in place of asterisks. If the text is wider than the column width, the processor applies
the same justification as the named field.

You can suppress the BREAK-ON output by setting the column width of the field to zero.

You can use BREAK-ON in conjunction with the TOTAL connective to generate subtotals. If using the modifier DET-SUPP with TOTAL and
BREAK-ON, it displays only the subtotal and grand total lines.

BREAK-ON Options

B Break. Works in conjunction with the B option of the heading and footing modifiers to put the break
values in the heading or footing

D Data. Suppresses the break line if there is only one detail since the last BREAK. This is the line with
the asterisks, any text that is specified, or totals

L Line. Suppresses the blank line preceding the break data lie. Overrides the U option if both are spe-
cified

P Page. Causes each break item to be output on a separate page

R Rollover. Inhibits a page break until all the data associated with the current break is output

U Underlines. Places underlines on the line above the accumulated totals if the TOTAL modifier was spe-
cified. Ignored if used with the ‘L’ option

V Value. Causes the values of the control Break attribute to be inserted at this point in the BREAK-ON
label

Controlling and Dependent Fields


Controlling and dependent fields provide a method for creating sublists from records.

A controlling field is one, which has the code D1 in field 8 of its data definition record and points

to its controlling field.

When the system finds a controlling field, it will:

1.       Look for the first field specified in the output specification clause that matches each FMC (Field Mark Count) of its dependent field and
has D2 code in field 8 of the data definition item specifying the controlling field.

2.       Position the found fields in the order found to the immediate right of the controlling field for display.

3.       Display an asterisk (*) under the column heading of each found field.

4.       Dependent fields are output immediately to the right of their controlling field regardless of the order in which you specify them.

5.       An independent field found between the controlling and dependent fields is moved “logically” to the right of the controlling and depend-
ent fields.

6.       Will ignore dependent fields unless you specify the controlling field.

JBase - User Guide - Release R15.000 - Page 362 of 629


EXAMPLE 1
SORT SALES P.CODE S.CODE =”ABCORDER ORD.ID ORD.QTY = “5””

Selects all the records in the ORDER file and outputs the ORD.ID data. The ORD.QTY data will only be included if it matched 5 - any other
value will be shown as blank.

EXAMPLE 2
SORT ORDER BY ORD.QTY BREAK-ON ORD.QTY ORD.ID

Selects all the records in the SALESORDER file in ORD.QTY order and outputs a line for each record until the ORD.QTY changes. At this
point, a control break triggers and outputs the running total of ORD.QTY. At the end of the report, it displays a cumulative total for ORD.ID.

Formatting Reports with Report Qualifiers


Using report qualifiers, you can tailor the layout of the entire report by setting up headers and footers on each page, adjusting margins and spa-
cing, and determining output orientation (horizontal or vertical). In addition, there are two jQL commands, LIST-LABEL and SORT-LABEL,
which enable you to format and sort mailing labels.

JBase - User Guide - Release R15.000 - Page 363 of 629


BSELECT

Retrieves selected records and generates a list composed of data fields from those records as specified by any explicit or default output spe-
cifications. Each subvalue within a field becomes a separate entry within the list.

COMMAND SYNTAX
BSELECT file-specifier {record-list} {selection-criteria} {sort-criteria} {USING file-specifier}{output-specification} {(options}

Comments: When the Command terminates, it displays the total number of entries in the generated list and makes the list available as if gen-
erated by a SELECT, GET-LIST or other list-providing Command.

If you do not specify a sort-criteria clause, the record list will be unsorted.

If you do not specify an output-specification, it uses the default data definitions “1”, “2” etc. .

EXAMPLE
BSELECT ORDER WITH ORD.QTY = “500]” ORD.AMT

Creates a list containing all ORD.QTY values from all the records in the ORDER file, which have an ORD.QTY that CONTAINS ORDERS =
500

JBase - User Guide - Release R15.000 - Page 364 of 629


C Conversion

Concatenates fields, literals, and the results of a previous operation

COMMAND SYNTAX
C{;}n{xn}...

SYNTAX ELEMENTS
;      Optional in that it has no function other than to provide compatibility.

x      The character for insertion between the concatenated elements. If you specify a semicolon (;), no separator will be used. Any non-numeric
character except system delimiters (value, subvalue, field, start buffer, and segment marks) is valid.

n      can be any one of the following: field number (FMC)

l a literal enclosed in single quotes, double quotes, or backslashes


l an asterisk (*) to specify the last generated value of a previous operation

Comments: See the descriptions of the function codes (A, F, FS and their variants) for other concatenation methods.

Input Conversion: does not invert; applies the concatenation to the input data.

EXAMPLE 1
C1;2

Concatenates the contents of field 1 with field 2, with no intervening separator character

EXAMPLE 2
C1*2

Concatenates the contents of field 1 with an asterisk (*) and then the content of field 2

EXAMPLE 3
C1*”ABC” 2/3

Concatenates the contents of field 1 with an asterisk (*), the string ABC, a space, field 2 a forward slash (/) and then field 3.

JBase - User Guide - Release R15.000 - Page 365 of 629


Calling Subroutines from Dictionary Items

The syntax for calling a subroutine from a dictionary item is: 

B; {filename} subname 

Or 

CALL {filename} subname 

SYNTAX ELEMENTS
filename is ignored but provided for compatibility with older systems

subname is the name of the called subroutine (or function).  This subroutine must reside in one of the libraries defined by the user. 

The subroutine can be called as a conversion (attribute 7 of the dictionary item) or as a correlative (attribute 8 of the dictionary item). Data is
passed to and from the subroutine with named COMMON elements. In each subroutine the following line must be included: 

INCLUDE /usr/jbc/include/qbasiccommonpick (Unix)

OR

INCLUDE \jbase30\include\qbasiccommonpick (Windows)

For ex-Sequoia users, you may INCLUDE the file qbasiccommonseq, which provides compatibility with that platform.

The INCLUDE file defines the named common that is used by jQL. The named common consists of 2 arrays: access and newpick. 

USAGE

access 
access(1) Data file open variable

access(2) Dictionary file open variable

access(3) Data item currently being processed

access(4) Item count

access(5) Attribute being processed. This is the value in attribute 2 of the calling dictionary item.

access(6) Value mark counter

access(7) Sub value mark counter

access(8) reserved

access(9) reserved

access(10) Item id

access(11) Data file name

access(12) reserved

access(13) reserved

access(14) Multivalue number from an exploded select-list (3.3.8 and above)

access(15) reserved

JBase - User Guide - Release R15.000 - Page 366 of 629


access(16) reserved

access(17) reserved

By default, jBASE will only call a subroutine once per item. This is normally desirable, since value and sub value manipulation can be done
within the subroutine. In addition, it is clearly more efficient to only call the subroutine once per item. However, for backward compatibility,
jBASE can be configured to call the subroutine for every value and sub value processed. If this is required then set jql_mv_ subcall = true in
usr/jbc/Config_EMULATE. If this setting is in place, access(6) and access(7) are incremented appropriately as each value and sub value is pro-
cessed. Otherwise the values in access(6) and access(7) have no meaning.

newpick 
newpick(1) through newpick(11) – reserved

newpick(12) - On entry to the subroutine this will contain the value of the data passed from jQL to the subroutine. By default, this will be all
the data defined by the calling dictionary item (i.e. all values and sub values). However if "jql_mv_ subcall = true" is set, then the subroutine is
called for every value/sub value and newpick(12) contains just each value or sub value as it is processed.

It is worth noting that a subroutine can be called as part of a multi-valued correlative. For example, the calling dictionary item could look like:

<1>S

<2>17

<8>F;"ABCD"]CALL SUB1

In this instance, the data defined by the calling dictionary item is "ABCD". But if the calling dictionary item is:

<1>S

<2>17

<8>CALL SUB1

Then the data passed to the subroutine in newpick (12) is simply the contents of attribute 17 of the current item, which may be multi/sub val-
ued.

On exit of the subroutine, newpick(12) contains the value used by jQL. 

EXAMPLE
COMMENTS (in DICT of SALES file)

001 A

002 3

003 Comments

004

005

006

007 B;comments

008

009 T

010 25

JBase - User Guide - Release R15.000 - Page 367 of 629


comments (jBC subroutine in available library)

001 SUBROUTINE comments

002 INCLUDE qbasiccommonpick

003 * Interpret Comment code

004 IF newpick(12) = "A" THEN newpick(12) = "Grade 1"

005 IF newpick(12) = "B" THEN newpick(12) = "Grade 2"

006 RETURN

LIST SALES COMMENTS

SALES........ Comments.................

ABC Grade 1

DEF Grade 2

PERSISTENT VARIABLES
When calling subroutines from dictionary items it is sometimes advantageous for the values of variables to persist between CALLs, for the dur-
ation of the jQL execution. An example of how persistent variables can be employed is when it is necessary to READ from a file in the sub-
routine. Rather than open the file every time the subroutine is called (i.e. for each record processed by jQL), it is more efficient to open the file
when the first record is processed and keep the file open variable available for subsequent records. This can be achieved with the following code
in the subroutine: 

...

IF UNASSIGNED(CustFileVar) THEN

OPEN "CUSTOMER" TO CustFileVar ELSE

GOSUB FatalError

ABORT

END

END

...

In order that the variables are persistent, a compiler directive must be supplied:

The (V) option to BASIC

The -JCV option to jbc

The -V option to jbccom

Persistent variables should be treated as COMMON variables. The one exception is that they are initialized for each jQL command. If a sub-
routine is called from two or more dictionary items in the same jQL command then the variables will be shared in the same way that COMMON
variables are. If the subroutine is called recursively, then the variables will be shared between each level of recursion, in the same way that
COMMON variables are.

JBase - User Guide - Release R15.000 - Page 368 of 629


Changing Case

se the following MC codes to transform text from upper to lower case and visa versa are:

MCL Convert all upper case letters (A-Z) to lower case

MCT Convert all upper case letters (A-Z) in the text to lower case, starting with the second character in each
word. Change the first character of each word to upper case.

MCU Convert all lower case letters (a-z) to upper case.

Input conversion does not invert. The conversion code will be applied to the input data.

EXAMPLE 1
MCL

Assuming a source value of AbCdEf, MCL will return abcdef.

EXAMPLE 2
MCT

Assuming a source value of AbC dEf “ghi, MCT will return Abc Def “ghi.

EXAMPLE 3
MCU

Assuming a source value of AbCdEf, MCU will return ABCDEF.

JBase - User Guide - Release R15.000 - Page 369 of 629


CNV Connective

The CNV connective allows the query to override the default conversion as supplied in the dictionary with another conversion.

EXAMPLE
LIST CUSTOMER *A1

CUST..... *A1......

1 FRED BLOGGS

2 TOM JONES

LIST CUSTOMER *A1 CNV “MCT”

CUST..... *A1......

1 Fred Bloggs

2 Tom Jones

JBase - User Guide - Release R15.000 - Page 370 of 629


COL.HDG Connective

The COL.HDG connective allows the query to override the default column header as supplied in the dictionary with another textual descrip-
tion.

EXAMPLE
LIST CUSTOMER *A1

CUST..... *A1......

1 FRED BLOGGS

2 TOM JONES

LIST CUSTOMER *A1 COL.HDG “Customer name”

CUST..... Customer name

1 FRED BLOGGS

2 TOM JONES

JBase - User Guide - Release R15.000 - Page 371 of 629


Command Options

Command options are letters enclosed in parentheses, which modify the action of the jQL command sentence. The options described here are
common to most commands. Where the options are command-specific, they are described with the command.

Do not confuse options for commands with options for modifiers and connectives such as HEADING and BREAK-ON. Commas or spaces can
separate options; when the options are at the end of the sentence (as is recommended) omit the closing parenthesis. jQL ignores any option,
not used by a particular command

Options

B Suppress initial LINEFEED prior to out put

C Suppresses column headings, page and date, line at the start and summary line at the end of a report: Equi-
valent to the COL-HDR-SUPP modifier

D Suppress detail output equivalent to the DET-SUPP modifier

H Suppress page and date line at the start and summary line at the end of the report: Equivalent to HDR-
SUPP modifier

I Suppress record keys: equivalent to the ID-SUPP modifier

N Suppress automatic paging: equivalent to the NOPAGE modifier.

P Output report to the printer: equivalent to the LPTR modifier

S Suppress summary line at the end of the report

EXAMPLE
LIST CUSTOMER (HIP

List the SALES file (using the default data definition records) but suppress the output of a header and the record keys. Send the output to the
assigned printer.

JBase - User Guide - Release R15.000 - Page 372 of 629


Concatenation Operator

Use a colon (:) to concatenate the results of two expressions.

For Example: the following expression concatenates the character “Z” with the result of adding together fields 2 and 3:

A;”Z”:2 + 3

JBase - User Guide - Release R15.000 - Page 373 of 629


Conversion Processing

A Algebraic functions.

B Subroutine call.

C Concatenation.

D Internal and external dates.

D1 and D2 Associates controlling and dependent fields.

F Mathematical functions.

G Group extract.

L Length.

MC Mask character.

MD Mask decimal.

MK Mask metric.

ML and MR Mask with justification.

MP Mask packed decimal.

MS Mask Sequence.

MT Mask time.

P Pattern match.

R Range check.

S Substitution.

T Text extraction.

TFILE File translation.

U User exit.

W Timestamps.

JBCUserConversions How to create user-defined conversion codes

JBase - User Guide - Release R15.000 - Page 374 of 629


Converting Characters

The MC codes that convert ASCII character codes to their binary or hexadecimal representations or vice versa are:

MCAB{S} Convert ASCII character codes to binary representation (Use S to suppress

spaces).

MCAX or MY Convert ASCII character codes to hexadecimal representation

MCBA Convert binary representation to ASCII characters.

MCXA or MX Convert hexadecimal representation to ASCII characters.

Comments: The MCAB and MCABS codes convert each ASCII character to its binary equivalent as an eight-digit number. If there is more than
one character, MCAB puts a blank space between each pair of eight-digit numbers. MCABS suppresses the spaces.

When converting from binary to ASCII characters, MCBA uses blank spaces as dividers, if they are present. MCBA scans from the right-hand
end of the data searching for Elements of “eight-bit” binary strings. If it encounters a space and the element is not eight binary digits long, it pre-
pends zeros to the front of the number until it contains eight digits and continues until reaching the leftmost digit prepending zeros if neces-
sary, it then converts each eight-digit element to its ASCII character equivalent.

Input conversion does not invert. The original code will be applied to input data.

EXAMPLE 1
MCAX

Assuming a source value of ABC, MCAX will return 414243.

EXAMPLE 2
MCXA

Assuming a source value of 414243, MCXA will return ABC.

EXAMPLE 3
MCAB

Assuming a source value of AB, MCAB will return 01000001 01000010.

EXAMPLE 4
MCABS

Assuming a source value of AB, MCABS will return 0100000101000010.

EXAMPLE 5
MCBA

JBase - User Guide - Release R15.000 - Page 375 of 629


Assuming a source value of 01000001 1000010, MCBA will return AB. Note the missing binary digit at the start of the second element of the
source value.

EXAMPLE 6
MCBA

Assuming a source value of 0100000101000010, MCBA will return AB.

JBase - User Guide - Release R15.000 - Page 376 of 629


Converting Numeric Values

The MC codes that convert numeric values (as opposed to characters), to equivalent values in other number schemes are:

MCBX{S} Convert a binary value to its hexadecimal equivalent. Use S to suppress spaces.

MCDR Convert a decimal value to its equivalent Roman numerals. Input conversion is effective.

MCDX or MCD Convert a decimal value to its hexadecimal equivalent. Input conversion is effective.

MCRD or MCR Convert Roman numerals to the decimal equivalent. Input conversion is effective.

MCXB{S} Convert a hexadecimal value to its binary equivalent. Use S to suppress spaces.

MCXD or MCX Convert a hexadecimal value to its decimal equivalent. Input conversion is effective.

Comments: These codes convert numeric values rather than individual characters. For Example, conversion of the decimal value of 60 is to
X”3C” in hexadecimal, or LX in Roman numerals. The value 60 is converted, not the characters “6” and “0”.

With the exception of MCBX {S} that handles spaces, all conversion of these codes will stop if they encounter an invalid character that is not a
digit of the source number system.

With the exception of MCDR, if the conversion fails to find any valid digits, a zero MCDR will return null.

If you submit an odd number of hexadecimal digits to the MCXB code, it will add a leading zero (to arrive at an even number of characters)
before converting the value.

The MCXB and MCXBS codes convert each pair of hexadecimal digits to its binary equivalent as an eight-digit number. If there is more than
one pair of hexadecimal digit, MCXB puts a blank space between each pair of eight-digit numbers. MCXBS suppresses the spaces.

When converting from binary to hexadecimal digits, MCBX uses blank spaces as dividers if they are present. MCBX effectively scans from the
right-hand end of the data searching for Elements of eight-bit binary digits. If it encounters a space and the element is not a multiple of eight
binary digits, it prepends zeros to the front of the number until it contains eight digits. This continues until it reaches the leftmost digit pre-
pending zeros if necessary. Each eight-digit element is converted to a hexadecimal character pair.

Input conversion is effective for MCDR, MCDX, MCRD and MCXD. Input conversion is not inverted for the other codes. The original code will
be applied to input data.

EXAMPLE 1
MCBX

Assuming a source value of 01000001 1000010, MCBX will return 4142. Would return the same value if there was no space between the bin-
ary source Elements.

EXAMPLE 2
MCRD

Assuming a source value of MLXVI, MCRD will return 1066.

EXAMPLE 3
MCDX

Assuming a source value of 1066, MCDX will return 42A.

JBase - User Guide - Release R15.000 - Page 377 of 629


JBase - User Guide - Release R15.000 - Page 378 of 629
COUNT

Reports the total number of records found in a file, which matches the specified selection criteria.

COMMAND SYNTAX
COUNT file-specifier {record-list} {selection-criteria} {USING file- specifier} {(options}

SYNTAX ELEMENTS
Options can be one or more of the following:

B    Suppress initial line-feed.

C Display running counters of the number of records selected and records processed. Unless modified by n,
{n} the counter increments after every 500 records processed or the total number of records if less than 500.
The n specifies a number other than 500 by which to increment. For Example, (C25) increments the
counter after every 25 records processed.

P Display running counters of the number of records selected and records processed. Unless modified by n,
the counter increments after every 500 records processed or the total number of records if less than 500.
The n specifies a number other than 500 by which to increment. For Example, (C25) increments the
counter after every 25 records processed. Send the report to the printer.

EXAMPLE
COUNT ORDER WITH ORD.AMT > “1000”

91 Records counted

Count the number of records in the SALES file which have a value greater than 1000.

COUNT ORDER WITH ORD.AMT > “1000” (C50

91 Records selected 240 Records processed

91 Records counted

Count the number of records in the ORDER file which have a ORD.AMT greater than 1000, and display a running total of selected and pro-
cessed records after each group of 50 records are processed.

JBase - User Guide - Release R15.000 - Page 379 of 629


D Conversion

Converts dates between internal and external format.

COMMAND SYNTAX
D{p}{n}{s}

SYNTAX ELEMENTS

P      The special processing operator and can be any one of the following:

D     Returns only the day of the month as a numeric value.

I   Returns only dates stored in the external format in internal format. You can use this in field 7 or 8.

J      Returns the Julian day (1 - 365, or 1 - 366 for a leap year).

M    Returns the number of the month (1 - 12).

MA Returns the name of the month in uppercase letters.

Q     Returns the number of the quarter (1 - 4)

W    Returns the day of the week as a numeric value (Monday is 1).

WA              
Returns the day of the week in uppercase letters (MONDAY - SUNDAY).

Y     Returns the year (up to four digits).

n      is a number from 0 to 4 that specifies the how many digits to use for the year field. If omitted, the
year will have four digits; suppresses the year if n is 0.

s      used as a non-numeric character as a separator between month, date, and year. Must not be one of
the special processing operators.

Comments: Dates are stored internally as integers, which represent the number of days (plus or minus) from the base date of December 31,
1967.

EXAMPLE

Date Stored Value

22 September 1967 -100

30 December 1967 -1

31 December 1967 0

01 January 1968 1

09 April 1968 100

JBase - User Guide - Release R15.000 - Page 380 of 629


26 September 1967 1000

14 January 1995 9876

29 February 2000 11748

If you do not specify a special processing operator (see later) or an output separator, the default output format is two-digit day, a space, a
three-character month, a space, and a four-digit year. If you specify just an output separator, the date format defaults either to the US numeric
format “mm/dd/yyyy” or to the international numeric format “dd/mm/yyyy” (where / is the separator). You can change the numeric format for
the duration of a logon session with the DATE-FORMAT Command.

JBase - User Guide - Release R15.000 - Page 381 of 629


D1 D2 Conversion

Associates controlling and dependent fields

COMMAND SYNTAX
D1;fmcd {;fmcd}...
D2;fmcc

SYNTAX ELEMENTS
fmcd is the field number (FMC) of an associated dependent field.

fmcc is the field number (FMC) of the associated controlling field.

Comments: You can logically group multivalued fields in a record by using a controlling multivalued field and associating other fields with it.
For example, you could group the component parts of an assembly on an invoice.

The D1 code in field 8 defines the controlling field and nominates the associated dependent fields. Each dependent field will have a D2 code in
field 8.

Important: The D1 and D2 codes must be in field 8 of the data definition record and be the first code specified; other codes can follow (sep-
arated by a value mark), but it must be the first code.

Outputs the values in the dependent associative fields in order as specified in field 8 of the controlling field the specified order in the dependent
fields in the output specification clause is irrelevant.

EXAMPLE
LIST CUSTOMER “ABC” CUS.ID .CUS.ORDER

The records in data file CUSTOMER have three associated, multivalued fields, named CUS.ID and CUS.ORDER, and numbered seven, two and
five respectively.

CUS.ID is the controlling field because, for each multivalue in this field there will a corresponding value in the other fields, and also because
CUS.ID should appear first on the report. The data definition record for CUS.ID will have D1;2;5 in field 8.

The data definition records for QTY and PRICE will both have D2;7 in field eight.

The report generated by the Command will look something like this:

CUSTOMER CUS.ID CUS.ORDER

ABC123 AAA 1 10.00

BBB 11 4.00

CCC 2 3.30

JBase - User Guide - Release R15.000 - Page 382 of 629


Data Conversion

When executing programs in international mode, it processes all variable contents as UTF-8 encoded sequences. As such all data must be held
as UTF-8 encoded byte sequences. This means that data imported into an account configured to operate in international mode must be con-
verted from the data in the current code page to UTF-8. Normally if ALL the data are eight bit bytes in the range 0x00-0x7f (ASCII) then no
conversion is necessary as these values are effectively already UTF-8 encoded. However values outside of the 0x00-0x7f range must be con-
verted into UTF-8 proper such that there can be no ambiguity between character set code page values.

For instance, the character represented by the hex value 0xE0 in the Latin2 code page, (ISO-8859-2), is described as “LATIN SMALL LETTER
R WITH ACUTE”. However the same hex value in the Latin1 code page, (ISO-8859-1), is used to represent the character “LATIN SMALL
LETTER A WITH GRAVE”.

To avoid this clash of code pages the Unicode specification provides unique hex value representations for both of these characters within the
specifications 32-bit value sequence. 

EXAMPLE
Unicode value 0x00E0 used to represent LATIN SMALL LETTER A WITH GRAVE

Unicode value 0x0155 used to represent LATIN SMALL LETTER R WITH ACUTE

NOTE: that UTF-8 is an encoding of 32 bit Unicode values, which also has especially properties (as described earlier), which can be used effect-
ively with Unix and Windows platforms.

Another good reason for complete conversion from the original code page to UTF-8 is that doing so also removes the requirement for con-
versions when reading/writing to files, as this would add massive and unnecessary overhead to ALL application processing, whereas the con-
version from original code page to UTF-8 is a one off cost.

JBase - User Guide - Release R15.000 - Page 383 of 629


Data Definition Records

Data definition records (sometimes known as field definition records) define the characteristics of each field in a data file. They specify the out-
put format and the type of processing required to generate each column of a jQL report.

Use data definition records to: 

l Specify default output.


l Associate field names with field numbers (column headings).
l Perform output formatting.
l Calculate new values based on the source data
l Perform processing via conversion codes.

Although normally used to define a single physical field in a file, use the data definition records for operations that are more complex.

EXAMPLE
To “join” or derive data from other fields or files

To verify the presence (or absence) of records in other files

To format their output in the most easily understood manner (to convert numeric 0 and 1 flags to “Yes” or “No”, for Example, or to output text
like “Overdue” if one date field is older than another).

To generate statistical data like record sizes or counters

The data definition records are usually located in the dictionary of the data file (but not always - see the USING Clause and the Default Output
Specification topics). You can set up any number of data definition records. Often, there are several definitions for each field, each one used by
a different set of reports which have different output requirements.

You associate the data definition record with a particular field in the data file by specifying the target fields FMC (field-mark count) in field 2 of
the data definition record. The FMC refers to (points to) the field number (also known as the line number) of the data within the records of the
data file.

JBase - User Guide - Release R15.000 - Page 384 of 629


Default Data Definition Records

When issuing a jQL Command without containing specific references to data definition records, nor do you suppress the output of the report
detail, the system will attempt to locate any default data definition records, which may be set up.

For Example: if you issue the Command “LIST SALES”, the system will look in the dictionary of the SALES file for a data definition record
named “1”. If it finds “1”, this will become the default output for column two. The system will then look for a data definition record named “2”
and so until the next data definition record is not found. If “1” is not found in the file dictionary, the system will search the default dictionaries
for the same sequence of data definition records.

When you issue a jQL Command, which does not contain specific references to data definition records, the system will first attempt to locate
each data definition record in the dictionary of the file (or in the file specified in a USING clause). If no data definition is found in the dictionary
(or the file specified in a USING clause), the system will look for the data definition in the file defined by the JEDIFILENAME_
MD environment variable.

For Example: if you issue the Command “LIST SALES VALUE”, the system will look in the dictionary of the SALES file for a data definition
record named “VALUE”. If it cannot find “VALUE” in the file dictionary, the system will look in the file specified by the JEDIFILENAME_MD
environment variable. In this way, you can set up data-specific, file-specific or account-specific defaults for use with any jQL Command.

JBase - User Guide - Release R15.000 - Page 385 of 629


JBase - User Guide - Release R15.000 - Page 386 of 629
Record Layout
All data definition records are defined in the same way:

Field|Description

1. D/CODE|Defines the record as a data definition record. Must be one of the following codes:

A Marks a normal data definition record.

S Obsolete but still supported. Was like the A type, but suppressed default column headings when field 3 was
blank. Replaced by the A type with a backslash in field 3 to defeat heading.

X Forces the definition to be ignored if selected as part of a default set of data definitions. Use only when expli-
citly named. See Default Output Specification later.

2. FMC (field-mark count)|A field number or special FMC (see Special Field-mark Counts for more details). A field number refers to the cor-
responding field (or line) in a record.

The special FMC codes are:

0 Refers to the record key - field number 0 (zero).

9998 Ordinal number of record at output (used for numbering or counting).

9999 Size of the record in bytes (excluding the key).

3. Column heading|

l Heading text, null, or a backslash followed by text.


l Entering more characters here than the width in field 10 allows, increases the width to accommodate the heading text (this field wins).
l If the statement uses the COL-HDR-SUPP output modifier or the “C” option it displays no column headings.
l Uses heading text as the column heading. If the text is less than the column width, it will be padded with dots.
l Use spaces to produce a blank heading.
l Use value marks, (ctrl ]), as NEWLINE characters to place the following text on a   new line. If this field is left null, uses the key of the
data definition record as the           column heading.
l Text following a backslash “\” character will be used as the column heading. If        nothing follows the backslash, the column heading
will be null.

4 - 6|Not used.

7. Input/Output conversion codes|Used for processing the data after sort and selection but before output. See Conversion Codes. Multiple con-
version codes, separated by a value marks, will be processed from left to right.

8. Pre-process conversion codes|Used for processing the data before sort and selection and before field 7 codes. See Conversion Codes later.
Multiple conversion codes, separated by a value marks, will be processed from left to right.

9. Format|Specifies the layout of the data within the column. Can be any of the following:

L Left justified If the data exceeds the column width specified in field 10, the data is broken at column
width without respect to blank spaces.

R Right justify If the data exceeds the column width specified in field 10, it truncates the data.

T Text. Word (Left justified) Where possible, lines will be broken at the blank space between words.
wrap - like L

U Unlimited. Data is output on one line ignoring column boundaries.

JBase - User Guide - Release R15.000 - Page 387 of 629


10. Width|Numeric value specifying the column width; If the number of characters in field 3 (the heading) is greater than the number entered
here, the number of characters in field 3 will be used.

JBase - User Guide - Release R15.000 - Page 388 of 629


JBase - User Guide - Release R15.000 - Page 389 of 629
Special Field-mark Counts
Three special FMCs (field-mark counts) are recognized: 0, 9998 and 9999.

FMC 0 - RECORD KEY

Setting field 2 of the data definition record to 0 (zero) causes the system to work with the record key. In this way, you could set up a data defin-
ition record which would allow a the record keys to be output in a column other than the first, and to use any column heading.

Typically, you would also use the ID-SUPP modifier or the “I” Command option to suppress output of the record key in the first column.

FMC 9998 - RECORD COUNT/NI OPERAND

Setting field 2 of the data definition record to 9998 causes the system to return a record (or line) count equal to the number of records output
so far in the report.

You could also use function operators within an A or F conversion code in field 7 or 8 of the data definition record to achieve the same result.
Function code operand NI yields the same value as an FMC of 9998.

FMC 9999 - RECORD SIZE/NL OPERAND

Setting field 2 of the data definition record to 9999 causes the system to return the record size in bytes. The size does not include the key but
does include all field marks within the record.

You could also use function operators within an A or F conversion code in field 7 or 8 of the data definition record to achieve the same result.
Function code operand NL yields the same value as an FMC of 9999.

JBase - User Guide - Release R15.000 - Page 390 of 629


JBase - User Guide - Release R15.000 - Page 391 of 629
Default Output Specification
Default output specifications work in two ways, depending on whether the default definitions are explicit or implicit.

JBase - User Guide - Release R15.000 - Page 392 of 629


JBase - User Guide - Release R15.000 - Page 393 of 629
Explicit Defaults
If you specify and use a data definition record for output, the system will search the implied dictionary first (or the dictionary specified in a
USING clause). If the data definition is not found in the implied dictionary, the system will look for the data definition in the file defined by the
JEDIFILENAME_MD environment variable.

JBase - User Guide - Release R15.000 - Page 394 of 629


JBase - User Guide - Release R15.000 - Page 395 of 629
Implicit Defaults
If you do not explicitly specify or use any data definition records for output, the system will search for a predefined series of records based on
the search criteria outlined in the preceding section.

You can therefore set up a series of data definition records, which the system will use if a jQL Command sentence does not include any explicit
output file, Ids.

You must name these “default” records in a numeric sequence starting at 1 (1, 2, 3, and so on). The fields, which these records define, will be
output in the same sequence as the keys but they do not need to follow the same sequence as the fields in the file.

When a jQL Command sentence with no explicit output fields is issued, the system first looks in the dictionary for a data definition record
named 1, then for a record named 2, then 3, and so on until it fails to find a record with the next number. Will use the record if it has a
D/CODE of A; it ignores the record if it has a D/CODE of X, but it will not break the sequence.

Will skip a record with a D/CODE of X if it was found as the result of a search for defaults; Under normal circumstances it can be used in the
same way as any other data definition record.

This means that when you first set up a series of “default” data definition records, you should put an A in the D/CODE field of each. If you sub-
sequently need to remove one from the sequence, you can simply change the D/CODE field to an X. This way you do not break the sequence or
have to copy the remaining “default” records to new names in order to fill the gap.

You can still use a data definition record with a number for a key in the same way as any other data definition record.

JBase - User Guide - Release R15.000 - Page 396 of 629


JBase - User Guide - Release R15.000 - Page 397 of 629
Predefined Data Definition Records
Some predefined data definition records are automatically available so that, if appropriate data definition records are not included in a files dic-
tionary, you can still generate a report. These records are recognized when used in a jQL Command sentence.

The predefined data definition records are named *A0 to *Annn. The numeric portion of the key corresponds to the position of the field they
report on and the column heading will be the same as the DDR name.

JBase - User Guide - Release R15.000 - Page 398 of 629


EDELETE

Deletes selected records from a file according to record list or selection criteria clauses.

COMMAND SYNTAX
EDELETE file-specifier [record-list | selection-criteria]

Comments: EDELETE requires an implicit or explicit record list, or selection criteria. Preceding the Command with a SELECT, GET-LIST or
other list-providing Command can provide an implicit list. EDELETE will immediately delete the specified records. To clear all the records in a
file, use the CLEAR-FILE Command.

EXAMPLES
EDELETE ORDER “ABC” “DEF”

2 Records deleted

Delete the records ABC and DEF based on the explicit list of records.

EDELETE ORDER IF ORD.AMT < “500”

n Records deleted

Delete all records in the ORDER file in which the ORD.AMT field IS LESS THAN 500.

SELECT ORDER WITH ORD.AMT = “500”

n Records selected

EDELETE ORDER

n Records deleted

Selects all records in the ORDER file in which the ORD.AMT field = 500, and deletes them.

JBase - User Guide - Release R15.000 - Page 399 of 629


ESEARCH

Generates an implicit list of records in a file if they contain (or do not contain) one or more occurrences of specified character strings

COMMAND SYNTAX
ESEARCH file-specifier {record-list} {selection-criteria} {sort-criteria} {USING file-specifier} {(options}

SYNTAX ELEMENTS
Options can be one or more of the following:

Option Description

A ANDs prompted strings together. Records must contain all specified strings

I Displays the keys of selected records..

L Saves the field numbers in which it found the specified strings. The resulting list contains the record
keys followed by multivalued line numbers. Ignores the A and N options if either or both are specified.

N Selects only those records that do not contain the specified string(s).

S Suppresses the list but displays the record keys that would have been selected.

Prompt: At the prompt supply one or more search strings:

String: Enter the required character string and press <ENTER>. This prompt is repeated until only <ENTER> is pressed. You can enter unlim-
ited characters.

Do not enter double quotes unless they are part of the string to search.

Comments: When the Command terminates (unless the “S” option is used), it displays the total number of entries in the generated list. The list
is then available as if generated by a SELECT, GET-LIST or other list-providing Command. If you do not specify a sort criteria clause, the
record list will be unsorted.

EXAMPLE
ESEARCH ORDER (I

STRING: ABC

STRING: DEF

KEY1
KEY2

18 Records selected

>

Generates a list of all records in the ORDER file, which contain the strings ABC or DEF

JBase - User Guide - Release R15.000 - Page 400 of 629


EXPLAIN

EXPLAIN displays information about how the statement will be processed. This lets you decide if you want to rewrite the query more effi-
ciently.

EXPLAIN lists the files, indexes, sorts etc… included in the command,  along with access timings in a report format so hopefully it’s a little
easier to understand what’s going on.

SYNTAX ELEMENTS

EXPLAIN <<Command>>

e.g.

EXPLAIN LIST JCUSTOMERS FIRSTNAME LASTNAME BY LASTNAME BY LASTNAME EXPLAIN SSELECT JCUSTOMERS SAVING
FIRSTNAME LASTNAME

JBase - User Guide - Release R15.000 - Page 401 of 629


JBase - User Guide - Release R15.000 - Page 402 of 629
EXPLAIN Reports
Currently there is only one type of report generated for jQL queries.

The aim of the report is to provide a simple representation of what’s just happened,  along with some information of how long things have
taken and what objects have been used. 

This should allow the user to alter there commands to make them more efficient.

JBase - User Guide - Release R15.000 - Page 403 of 629


JBase - User Guide - Release R15.000 - Page 404 of 629
jQL Report
A text report is generated that breaks the command down into its individual components. 

Internally each operation is grouped and given a description to try and make what the statement does a little easier to understand.  It should
give you a basic understanding why something is taken so long and where an index may help.

The output is broken down into the following groups:

l Command The command you just ran

l File Details of the file used in you query,  file type and access methods used. 

l Indexing Details on what indexes have been used,  and any limiting statements that would affect them.

l Sorting Details of what columns are used for sorting and information on what attributes associated with the column will
affect the output

l Output Columns List of columns returned from query.

l Aggregate List of things that the break processor will process.  These can be operations like totals.  Break on etc…

JBase - User Guide - Release R15.000 - Page 405 of 629


l Timings List of how long each access type has take.

The output looks something like..

Sort Processor

Total Taken: 16 (1...1)

Total Taken is split into total time for all records, followed by minimum and maximum access times in mil-
liseconds.

A good example for access timings is that we can use multiple methods to access data,

1) Simple dictionary

001: D

002: 1

2) Simple dictionary but indexed

3) ITYPE Dictionary

001: I

002: THEFIRSTDICTIONARY;@1

4) EVAL Statement

EVAL “A+B”

5) Subroutine call

001: I

002: SUBR(XXXX)

All of the above would take a different amount of time to return a result, the timings aren’t necessarily how long
it took to read the file, but how long it took to get a single row using the current statement.

So a combination of index access timings, full file source etc… are use to give an overview of what all of the com-
ponents used in the current statement have done.

JBase - User Guide - Release R15.000 - Page 406 of 629


Explicit Item-id list

An explicit item-id lists lists items for processing, which encloses each item-id in double quotes. Spaces between item-ids are optional. An
item-id list cannot include a relational operator and ignores any included logical connectives.

JQL treats the values you place between quotes as item-ids, not as value strings. This treats the left ignore, right ignore and wild card as ordin-
ary characters and not as special characters.

SYNTAX
‘item-id’ {‘item-id’}.. .

JBase - User Guide - Release R15.000 - Page 407 of 629


Extracting Characters

Use the following MC codes to extract characters from a string:

MCA Extract only alphabetic characters.

MC/A Extract only non-alphabetic characters.

MCAB{S} Convert ASCII character codes to binary representation. Use S to suppress spaces.

MCAX or Convert ASCII character codes to hexadecimal representation.


MX

MCB Extract only alphabetic and numeric characters.

MC/B Extract only special characters that are neither alphabetic nor numeric.

MCBA Convert binary representation to ASCII characters.

MCBX Convert a binary value to its hexadecimal equivalent.

MCC;x;y Change all occurrences of character string x to character string y.

MCDR Convert a decimal value to its equivalent Roman numerals. Input conversion  is effective.

MCDX or Convert a decimal value to its hexadecimal equivalent. Input conversion is effective.
MCD

MCL Convert all upper case letters (A-Z) to lower case.

MCN Extract only numeric characters (0-9).

MC/N Extract only non-numeric characters.

MCNP{c} Convert paired hexadecimal digits preceded by a period or character c to ASCII code.

MCP{c} Convert each non-printable character (X”00” - X”IF”, X”80” - X”FE”) to a period (.) or to character c.

MCPN{c} Same as MCP but insert the two-character hexadecimal representation of the character immediately
after the period or character c.
MCRD or Convert Roman numerals to the decimal equivalent. Input conversion is  effective.
MCR

MCT Convert all upper case letters (A-Z) in the text to lower case, starting with the  second character in
each word. Change the first character of each word to upper case if it is a letter.
MCU Convert all lower case letters (a-z) to upper case.

MCXA or Convert hexadecimal representation to ASCII characters.


MY

MCXB{S} Convert a hexadecimal value to its binary equivalent. Use S to suppress  spaces between each block of
8 bytes.
MCXD or Convert a hexadecimal value to its decimal equivalent. Input conversion is effective.
MCX

EXAMPLE 1
MCA

JBase - User Guide - Release R15.000 - Page 408 of 629


Assuming a source value of ABC*123!DEF, MCA will return ABCDEF.

EXAMPLE 2
MC/A

Assuming a source value of ABC*123!DEF, MC/A will return *123!

EXAMPLE 3
MCB

Assuming a source value of ABC*123!DEF, MCB will return ABC123DEF.

EXAMPLE 4
MC/B

Assuming a source value of ABC*123!DEF, MC/B will return *!

EXAMPLE 5
MCN

Assuming a source value of ABC*123!DEF, MCN will return 123.

EXAMPLE 6
MC/N

Assuming a source value of ABC*123!DEF, MC/N will return ABC*!DEF

JBase - User Guide - Release R15.000 - Page 409 of 629


F Conversion

F codes provide many facilities for arithmetic, relational, logical, and concatenation operations. The expression of all operations is in Reverse
Polish notation and involves the use of a “stack” to manipulate the data.

SYNTAX SUMMARY
There are three forms of the F code:

F Uses only the integer parts of stored numbers unless a scaling factor is included. If the      JBCEMULATE environment variable is set to
“ROS” the operands for “-”, “/” and concatenate are used in the reverse order.

FS   Uses only the integer parts of stored numbers (use SMA standard stack operations for all emulations)

FE   Uses both the integer and fraction parts of stored numbers.

COMMAND SYNTAX
F {n};elem {;elem}...
FS;elem {;elem}...
FE;elem{;elem}

SYNTAX ELEMENTS
n     A number from 1 to 9 used to convert a stored value to a scaled integer. The stored value explicit or implied decimal point is moved n
digits to the right with zeros added if necessary. Returns only the integer portion of this operation

elem      Any valid operator

Comments: F codes use the Reverse Polish notation system. Reverse Polish is a postfix notation system where the operator follows the oper-
ands. The expression for adding two Elements is “a b + “. (The usual algebraic system is an infix notation where the operator is placed between
the operands, for Example, “a + b”).

The F code has operators to push operands on the stack. Other operators perform arithmetic, relational, and logical operations on stack Ele-
ments. There are also concatenation and string operators.

Operands pushed on the stack may be constants, field values, system parameters (such as date and time), or counters (such as record coun-
ters).

JBase - User Guide - Release R15.000 - Page 410 of 629


Field Qualifiers

By default, formatting & conversion are defined by a field’s DICTionary entry. If the behaviour defined in the DICTionary needs to be overridden
for any reason, there are a number of different qualifiers that may be used in jQL statements

SYNTAX

jQL Field Qualifier Description

AS Specifies a synonym for a field name or a name for an EVAL expression

ASSOC Associates a field expression with an association of multi-values

ASSOC.WITH Associates a field expression with another multi-value

COL.HDG Defines a column heading

CONV Defines a conversion

DISPLAY.LIKE Copies the display characteristics of another field

MULTI.VALUE Specifies a multi-valued field expression

MULTIVALUED

SINGLE.VALUE Specifies a single-valued field expression

SINGLEVALUED

EXAMPLE
>LIST HAT.TYPE HAT.SIZE DISPLAY.LIKE PRICE COL.HDG “Hat sizes available”

HAT.TYPE Hat sizes available

Trilby 10

Top Hat 13

JBase - User Guide - Release R15.000 - Page 411 of 629


File Modifiers

As described below file modifiers DICT, ONLY=, WITHIN and TAPE modifies the use of the file, and how it is accessed 

SYNTAX ELEMENTS
{DICT} {ONLY} {WITHIN} {TAPE} filename{,data-section-name}

DICT Specifies the dictionary section of the file and contains the data for referencing. You must type the
modifier DICT before the filename. When modifying a filename by the DICT the processor looks in the
MD for attribute and macro definition items.

ONLY Specifies that only item-ids are to be output and suppress any default output contents. You can type
the modifier ONLY before filename or following all clauses, which contain attribute names.

WITHIN Specifies a sublist such as bill of material items. Use WITHIN only with the LIST and COUNT verbs
and must precede filename. Specify one item-id only; if you enter more than one item-id, it displays an
error message.

TAPE Tells the processor to retrieve data from a magnetic tape, which written only in a T-DUMP format.
This modifier cannot be used with the sorting verbs such as SORT and ST-DUMP, nor with tape out-
put verbs, such as T-DUMP, nor with the updating verb EDELETE

filename Specifies a dictionary section and a data section

data- sec- Specifies a data section other than the data section called filename. It must follow filename and use a
tion- comma with no spaces for separation.
name

JBase - User Guide - Release R15.000 - Page 412 of 629


JBase - User Guide - Release R15.000 - Page 413 of 629
Item Lists
An item list specifies the items within the file to be further processed. If no list is given, all items in the file are implied.

JBase - User Guide - Release R15.000 - Page 414 of 629


FMT Connective

The FMT connective allows the query to override the formatting used to display the corresponding data with a different format mask 

EXAMPLE 
LIST CUSTOMER *A1

CUST..... *A1...

1 FRED B

2 TOM JO

LIST CUSTOMER *A1 FMT “25L”

CUST..... Customer name

1 FRED BLOGGS

2 TOM JONES

JBase - User Guide - Release R15.000 - Page 415 of 629


Format Codes

You can format the result of any "A" code operation by following the expression with a value mark, and then the required format code:

An;expression]format

Format codes can also be included within the expression. For more information, see Format codes.

JBase - User Guide - Release R15.000 - Page 416 of 629


Format Codes

There are three ways to use format codes:

I.      One transforms the result of the F code

II.      another transforms the content of a field before it is pushed on the stack

III.      The third transforms the top entry on the stack

COMMAND SYNTAX
f- code {] format- code...}
field- number (format- code {] format- code}...)
(format-code{]format-code}...)

SYNTAX ELEMENTS
F code             A complete F Code expression.

Field number     The field number in the record from which to retrieve the data.

format code  Any valid format codes.

] Represents a must use value mark (ctrl ]) to separate each format code.

Comments: To process a field before it is pushed on the stack, follow the FMC with the format codes enclosed in parentheses. To process the
top entry on the stack, specify the format codes within parentheses as an operation by itself. To specify more than one format code in one oper-
ation, separate the codes with the value mark, (ctrl]). All format codes will convert values from an internal format to an output format.

EXAMPLE
F;2(MD2]G0.1);100;-

Obtain the value of field 2. Apply an MD2 format code. Then apply a group extract to acquire the integer portion of the formatted value, and
push the result onto the stack. Subtract 100 from the field 2 formatted, group extracted value. Return this value. Note that under ROS emu-
lation, the value returned would be the result of subtracting the integer value from the group extract, from 100. In other words:

100 - OCONV(OCONV(Field2, “MD2”), “G0.1” ).

JBase - User Guide - Release R15.000 - Page 417 of 629


Further Examples of item Lists

The following sentence lists ORDER information with numbers that are both greater than or equal to 200 and less than 700:

LIST ORDER >= ‘200’ AND LT ‘700’

The following sentence displays information about orders with numbers less than 200 and with available dates after May 17 2002.

LIST ORDER < ‘200’ WITH AVAILABLE AFTER “MAY 17 2002”

The following sentence displays CUSTOMER information 500 and greater than 199 and with CUSTOMER ADDRESS. The second AND arises
because the sentence includes both item selection and data selection criteria: these operations perform one after the other, giving an effective
AND function. The OR between “ST” and “D” is implicit.

LIST CUSTOMER LT ‘500’ AND GT ‘119’ WITH CUS.ADDR “ST” “D”

The following sentence lists rooms with numbers less than 200 or greater than 399.

LIST orders < ‘200’ OR > ‘399’

JBase - User Guide - Release R15.000 - Page 418 of 629


G Conversion

G codes extract one or more contiguous strings (separated by a specified character), from a field value.

COMMAND SYNTAX
G{m}xn

SYNTAX ELEMENTS
m     the number of strings to skip. If omitted or zero, extraction begins with the first character.

x      the separation character.

n      the number of strings to be extracted.

Comments: The field value can consist of any number of strings, each separated by the specified character. The separator can be any non-
numeric character, except a system delimiter.

If m is zero or null and the separator x is not found, the whole field will be returned. If m is not zero or null and the separator x is not found,
null will be returned.

Input Conversion: does not invert. It simply applies the group extraction to the input data.

EXAMPLE 1
G0.1

If the field contains “123.45”, 123 will be returned. You could also use “G.1” to achieve the same effect.

EXAMPLE 2
G2/1

If the field contains “ABC/DEF/GHI”, returns GHI.

EXAMPLE 3
G0,3

If the field contains “ABC,DEF,GHI,JKL”, returns ABC,DEF,GHI. Note that the field separators are included in the returned string.

JBase - User Guide - Release R15.000 - Page 419 of 629


GRAND-TOTAL

Specifies the text to replace the default asterisks in the cumulative total line at the end of the report; CAPTION is a synonym for GRAND-
TOTAL.

L Line: suppresses the blank line preceding the GRAND-TOTAL line. Overrides the U option if both are
specified and

P Page: outputs the GRAND-TOTAL on a separate page.

U Underline: places underlines on the line above the accumulated totals. Ignored if used with the ‘L’
option.

LPTR Specifies that a report go to the printer queue (spooler) instead of displaying at the terminal. You could
use the ‘P’ option at the end of the sentence in place of this modifier.

Comments: Enter a heading or footing option, which specify a value in the order in which they appear.

Text spaces are not normally required between option codes. However, you can present options that represent values such as pages or dates
without spaces. For example: ’”PD”’ will print on the first page as:

111/11/00

In this case, enter the options with a space between them like this “‘P’ ‘D’”

EXAMPLE
SORT ORDER BY ORD.ID. BREAK-ON ORD.ID ‘BL’ ORD.QTY GRAND-TOTAL “Total “HEADING ORD.QTY : ‘B’ ‘DL’” FOOTING “PAGE
‘CPP’ “LPTR

Control Break on a change in ORD.ID and suppress the LINE FEED before the break. Reserve the break value for use in the heading (‘B’). Main-
tain a running total of the VALUE field and output it at each control break.. Put the word Total on the GRAND-TOTAL line.

Set up a heading for each page, which comprises the words ‘ORD.QTY:’, the ORDER code (from the break), a date and a line feed. Set up a foot-
ing, this contains the text ‘PAGE’, and a page number, centered on the line.

Produce the report on the currently assigned printer.

JBase - User Guide - Release R15.000 - Page 420 of 629


I-DUMP / S-DUMP

Displays the entire contents of items in a file, including the system delimiters

COMMAND SYNTAX
I-DUMP file-specifier {record-list} {selection-criteria} {sort-criteria} {USING file-specifier} {(options}

Comments: Use the S-DUMP Command to produce sorted output.

Denoted as follows are system delimiters:

Attribute mark ^

Value mark ]

Sub value mark \

EXAMPLE 1
I-DUMP CUSTOMER WITH CUS.CITY = “BEAVERTON”

Generates the following output:

13 Records Listed

jsh machinename ~ -->I-DUMP CUSTOMER WITH CUS.CITY ="BEAVERTON"

The following output is generated

40840^Lexus of Portland^8840 Sw Canyon Rd.^Beaverton^OR^^503-297-9017^^^

40848^Kuni Cadillac & BMW^3725 SW Cedar Hills Blvd^Beaverton^OR^^503-643-1543^^

40855^Berg Car Company^10680 SW Canyon Rd.^Beaverton^OR^^503-641-1251^^^

40821^Beaverton Chrysler Plymouth^10760 SW Canyon Rd.^Beaverton^OR^^503-646-051

6^^^

EXAMPLE
jsh machinename ~ -->S-DUMP CUSTOMER BY CUS.ADDR WITH CUS.NAME "A..."

40854^AA Auto Brokers^^^^^503-774-6701^^^

40813^Acura Of Portland^12560 SE Start^Portland^OR^98330^503 544 3032^503 544 3

958^^

40811^All Car Rental^1321 East 78th St, Suite 101^Bloomington^MN^55425^612 854

4045^612 851 9361^mglomb@acrental.com^

JBase - User Guide - Release R15.000 - Page 421 of 629


40873^Andy's Auto Supply & Repair^2150 SE Powell Blvd.^Portland^OR^^503-232-086

8^^^30058493^

40819^Alexander Chrysler-Plymouth^2340 NE Sandy Blvd.^Portland^OR^^503-233-4433

^^^

JBase - User Guide - Release R15.000 - Page 422 of 629


I-TYPES

The jBASE jQL processor supports I-TYPES as imported from PRIME or Universe.

The jBASE query language, jQL, has been enhanced to support D and I type attribute definition records.

Formats

I-TYPE D- TYPE

001 I
001 D
002 Expression
002 AttributeNo
003 Conversion
003 Conversion
004 Header
004 Header
005 Format
005 Format
006 - 016 Reserved
006 - 016 Reserved

Expression
This can be one or more of the following types:

Type Description

Dictionary Id E.g. Attribute definition S/A/D/I/X/V type (Note: V is equivalent to I)

@Variables E.g. @RECORD, @ID, @USERNO, @DATE, @TIME

Functions E.g. TRANS (File, Item, Attr, Code)

User Subroutines E.g. MYSUB (param1, param2, param256)

Conditionals E.g. IF X = Y THEN @RECORD ELSE " "

String Extraction E.g. Expression[6,4]

You can define multiple expressions within the same I-TYPE.

EXAMPLE
Expression ; Expression ;

Expressions can be parenthesized, contain numeric constants, string literals, enclosed in single or double quotes, and extended operators such
as EQ, NE, LE, GT, CAT, AND, OR, MATCHES.

JBase - User Guide - Release R15.000 - Page 423 of 629


ICOMP

Using an I-TYPE for the first time in a query, i.e. jQL Command, the expression attribute will be “compiled”, to produce internal op codes and
parameter definitions. This mechanism provides greater efficiency at run time. However to ensure it compiles all I-TYPE definitions, rather
than on an ad hoc basis, a utility, ICOMP, has been provided.

Called as:
ICOMP {DICT} FileName {RecordList | * }

Where:

FileName The name of the file to convert

RecordList The list of the Record identifiers

NOTE: ICOMP will always attempt to convert the dictionary section of a file. If RecordList is omitted, it compiles all I-TYPE definitions.
ICOMP will also respect a preceding SELECT list.

JBase - User Guide - Release R15.000 - Page 424 of 629


IF STATEMENT

IF Statement: gives the A code conditional capabilities

COMMAND SYNTAX
IF expression THEN statement ELSE statement

SYNTAX ELEMENTS
expression  must evaluate to true or false. If true, executes the THEN statement. If false,                          

executes the ELSE statement.

statement  is a string or numeric value.

Comments: Each IF statement must have a THEN clause and a corresponding ELSE clause. You can nest statements but the result of the state-
ment must evaluate to a single value. The words IF, THEN and ELSE must be followed by at least one space.

EXAMPLE 1
A;IF N(QTY) < 100 THEN N(QTY) ELSE ERROR!

Tests the QTY value to see if it is less than 100. If it is, output the QTY field. Otherwise, output the text “ERROR!”.

EXAMPLE 2
A;IF N(QTY) < 100 AND N(COST) < 1000 THEN N(QTY) ELSE ERROR!

Same as Example 1 except that QTY will only be output if it is less than 100 and the cost value is less than 1000.

EXAMPLE 3
A;IF 1 THEN IF 2 THEN 3 ELSE 4 ELSE 5

If field 1 is zero or null, follow else and use field 5. Else test field 2; if field 2 is zero or null, follow else and use field 4. Else, use field 3. Use
Field 3 only if both fields 1 and 2 contain a value.

JBase - User Guide - Release R15.000 - Page 425 of 629


Implicit Item-id list

To provide an implicit item-id list execute a verb such as SELECT or GET-LIST immediately before executing a jQL command. If you also spe-
cify item-id selection, the jQL processor effectively ANDs its result with the implicit item-id list to limit further the items selected.

If you specify an explicit item-id list, the processor ignores any implicit list.

EXAMPLE
The following sentences will not list anything because the value strings cannot match any item-id in the implicit list. 

SELECT ORDER GT ‘200’


42 RECORDS LISTED
>LIST CUSTOMER = ‘40823’ ‘40825’

The following sentences list information about CUSTOMER 40823 and 40825 because the process ignores an implicit item-id list when an
implicit item-id list is in the sentence.

SELECT ORDER GT ‘200’


23 items selected
> SELECT CUSTOMER ‘40823’ ‘40825’

JBase - User Guide - Release R15.000 - Page 426 of 629


JBase - User Guide - Release R15.000 - Page 427 of 629
Item-id Selection clause
An item-id selection clause expresses limits on the value of item-ids, for selection for processing. It has at least one value string that defines an
item-id or part of an item-id, and an explicit relational operator must precede at least one value string. The relational operator is what makes
jQL treat item-id selection differently from an explicit item list. You can use logical connectives to combine relational operations. If you do not
use an explicit logical connective, jQL defaults to the OR connective. JQL searches the file for each item-id that matches the value strings in the
criteria. If an implicit item-id list has been specified, the processor checks only those item-ids present in the list.

JBase - User Guide - Release R15.000 - Page 428 of 629


JBase - User Guide - Release R15.000 - Page 429 of 629
Selection Criteria Clause
The selection criteria clause allows you to specify data-specific limits on the range of records that will be eligible for processing.

If a record list of any type is outstanding when processing reaches the selection criteria, only those in the list will be submitted to the selection
process; if there are no record lists outstanding the selection process considers all records in the file.

Each selection criterion specifies a field (data or key) for testing to determine selection of a record. The selection criterion begins with the con-
nective (WITH (or IF) and must also include a field name. The field name can be followed by a value selection clause otherwise it defaults to
NE ““(not equal NULL)

SYNTAX
WITH | IF { NOT } { EACH } field {value-selection clause} {{AND | OR}

{ WITH |IF } {NOT} {EACH} field {value-election clause}...}

Value selection clause has the form:

{relational-operator} “value string” {{logical-connective}

{relational operator} “value string”}. . .

SYNTAX ELEMENTS
WITH or IF is the selection connective. It must be the first word of a selection criterion. WITH and IF are synonymous. WITHOUT is a syn-
onym for WITH NOT.

JBase - User Guide - Release R15.000 - Page 430 of 629


jBC Statements for use with jQL

The following statements enable jBASIC programmers to deal directly with jQL statements, thereby eliminating the need to parse the output of
commands such as EXECUTE. EXECUTE.

NOTE: Properties are valid after the compile; this is the main reason for separating the compile and execute into two functions, after compiling,
it is possible examine the properties and set properties before executing.

JBase - User Guide - Release R15.000 - Page 431 of 629


jQL Basic Subroutines

jBASE jQL enables users to call Basic subroutines from within correlatives and conversions. There are two flavors of subroutine and each
requires a different include file. For Advanced Pick subroutines, the developer must include the following header file from the “include” sub-
directory in the jBASE release directory.

qbasiccommonpick

For Sequoia subroutines, the developer must include the following header file from the “include” subdirectory in the jBASE release directory.

qbasiccommonseq

JBase - User Guide - Release R15.000 - Page 432 of 629


jQL Dictionary Conversions and Correlatives

For dates and times, simple date format functions have been applied to use the configured locale to support the standard conversions D and
MTS. Formatting numbers via MR/ML/MD, use locale for Thousands, Decimal Point and Currency notation.

JBase - User Guide - Release R15.000 - Page 433 of 629


jQL Operands

Field Number (FMC) Operand


The field number operand returns the content of a specified field in the data record:

field- number {R {R}}

The first R specifies that any non-existent multivalues should use the previous non-null multivalue. When the second R is specified, any non-
existent subvalues should use the previous non-null subvalue.

JBase - User Guide - Release R15.000 - Page 434 of 629


JBase - User Guide - Release R15.000 - Page 435 of 629
Field Name Operand
The field name operand returns the content of a specified field in the data record:

N(field-name){R{R}}

JBase - User Guide - Release R15.000 - Page 436 of 629


JBase - User Guide - Release R15.000 - Page 437 of 629
Literal Operand
The literal operand supplies a literal text string or numeric value:

“literal”

JBase - User Guide - Release R15.000 - Page 438 of 629


JBase - User Guide - Release R15.000 - Page 439 of 629
System Parameter Operands
Several A code operands return the value of system parameters. They are:

D Returns the system date in internal format.

LPV Returns the previous value transformed by a format code.

NA Returns the number of fields in the record.

NB Returns the current break level counter. 1 is the lowest break level, 255 is the GRAND TOTAL line.

ND Returns the number of records (detail lines) since the last control break.

NI Returns the record counter.

NL Returns the record length in bytes

NS Returns the subvalue counter

NU Returns the date of last update

NV Returns the value counter

T Returns the system time in internal format.

V Returns the previous value transformed by a format code

JBase - User Guide - Release R15.000 - Page 440 of 629


JBase - User Guide - Release R15.000 - Page 441 of 629
Special Operands
Some operands allow you to use special functions. They are:

I(expression) Returns the integer part of expression.

R(exp1, exp2) Returns the remainder of exp1 divided by exp2.

S(expression) Returns the sum of all values generated by expression.

string[start-char-no, len] Returns the substring starting at character start-char-no for length len.

JBase - User Guide - Release R15.000 - Page 442 of 629


JBase - User Guide - Release R15.000 - Page 443 of 629
FIELD NUMBER
Field Number (FMC) Operand specifies a field, which contains the value for use.

COMMAND SYNTAX
field-number{R{R}}

SYNTAX ELEMENTS

field- the number of the field (FMC), which contains the required value.
number

R specifies that the value obtained from this field be applied for each multivalue not present in a cor-
responding part of the calculation.

RR Specifies that the value obtained from this field be applied for each subvalue not present in a cor-
responding part of the calculation.

Comments: The following field numbers have special meanings:

0 Record key

9998 Sequential record count

9999 Record size in bytes

EXAMPLE 1
A;2

Returns the value stored in field 2 of the record.

EXAMPLE 2
A;9999

Returns the size of the record in bytes

EXAMPLE 3
A;2 + 3R

For each multivalue in field 2, the system also obtains the (first) value in field 3 and adds it. If field 2 contains 1]7 and field 3 contains 5 the res-
ult would be two values of 6 and 12 respectively. Where three does not have a corresponding multivalue, will use the last non-null multivalue in
three

EXAMPLE 4
A;2 + 3RR

JBase - User Guide - Release R15.000 - Page 444 of 629


For each subvalue in field 2, the system also obtains the corresponding subvalue in field 3 and adds it. If field 2 contains 1\2\3]7 and field 3
contains 5\4 the result would be four values of 6, 6, 7, 12 and 4 respectively.

JBase - User Guide - Release R15.000 - Page 445 of 629


JBase - User Guide - Release R15.000 - Page 446 of 629
N (Field Name) Operand
References another field defined by a name in the same dictionary or found in one of the default dictionaries.

COMMAND SYNTAX
N(field-name){R{R}}

SYNTAX ELEMENTS
field-name is the name of another field defined in the same dictionary or found in the list of   default dictionaries

R Specifies that the value obtained from this field be applied for each multivalue not                present in a corresponding part of the
calculation.

RR Specifies that the value obtained from this field be applied for each subvalue not present in a corresponding part of the cal-
culation.

Comments: If the data definition record of the specified field contains field eight pre-process conversion codes, it applies these before it returns
the value(s).

Any pre-process conversion codes in the specified field-name including any further N(field-name) constructs are processed as part of the con-
version code.

N(field-name) you can nest constructs up to 30 levels. The number of levels is restricted to prevent infinite processing loops. For Example:

TEST 1
008 A;N(TEST2)

TEST 2
008 A;N(TEST1)

EXAMPLE 1
A;N(S.CODE)

Returns the value stored in the field defined by S.CODE.

EXAMPLE 2
A;N(A.VALUE) + N(B.VALUE)R

For each multivalue in the field defined by A.VALUE, the system also obtains the corresponding value in B.VALUE and adds it. If A.VALUE
returns 1]7 and B.VALUE returns 5, the result would be two values of 6 and 12 respectively.

EXAMPLE 3
A;N(A.VALUE) + N(B.VALUE)RR

For each subvalue in the field defined by A.VALUE, the system also obtains the corresponding value in B.VALUE and adds it. If A.VALUE
returns 1\2\3]7 and B.VALUE returns 5 the result would be four values of 6, 7, 8 and 12 respectively.

JBase - User Guide - Release R15.000 - Page 447 of 629


JBase - User Guide - Release R15.000 - Page 448 of 629
Literal Operand
Specifies a literal string or numeric constant enclosed in double quotes

COMMAND SYNTAX
"literal"

SYNTAX ELEMENTS
literal is a text string or a numeric constant.

NOTES
Assumes a number not enclosed in double quotes to be a field number (FMC).

EXAMPLE 1
A;N(S.CODE) + "100"

Adds 100 to each value (subvalue) in the field defined by S.CODE

EXAMPLE 2
A;N(S.CODE):"SUFFIX"

Concatenates the string "SUFFIX" to each value (subvalue) returned by S.CODE

JBase - User Guide - Release R15.000 - Page 449 of 629


JBase - User Guide - Release R15.000 - Page 450 of 629
Special Operands
Integer Function: I(expression) returns the integer portion of an expression.

EXAMPLE
AE;I(N(COST) * N(QTY))

Returns the integer portion of the result of the calculation

JBase - User Guide - Release R15.000 - Page 451 of 629


jQL Output (Reports)

By default, displays output from a jQL Command on your terminal, in columnar format, with a pause at the end of each page (Full screen).

OUTPUT DEVICE
You can redirect the output to a printer (or the currently-assigned Spooler device) by using the LPTR format specifier or the P option.

REPORT LAYOUT
If the columnar report will not fit in the current page width of the output device, it will be output in “non-columnar” format where each field of
each record occupies one row on the page.

PAGING
If the displayed report extends over more than one screen, press <ENTER> to view the next screen. To exit the report without displaying any
remaining screens, press <Control X> or “q”

JBase - User Guide - Release R15.000 - Page 452 of 629


jQL Verbs

Verb Description

BSELECT Retrieves selected records and generates a list composed of data fields from those records as specified by any explicit or
default output specifications. Each subvalue within a field becomes a separate entry within the list.

COUNT Counts the records in a file

ESEARCH Similar to SEARCH

LIST Displays data from records in a file

LIST-ITEM Displays full listing of selected records

LIST-LABEL Displays records in a format suitable for mailing labels and other block listings

REFORMAT Redirects jQL output to a file or tape.

SEARCH Creates a select list of records that contain an occurrence of one or more specified strings

SELECT Creates a list of records that meet specified selection criteria

SORT Lists selected records in sorted order

SORT-ITEM Displays full listings of selected records in sorted order

SORT-LABEL Displays items in a format suitable or mailing labels and other block listings

SREFORMAT Redirects jQL output to a file or to a tape with records sorted by sort expression

SSELECT Creates a sorted list of records that meet specified selection criteria

STAT Displays numeric statistics for fields in a file

SUM Adds numeric values in fields of records that meet specified selection criteria

T-DUMP Copies records from disk to tape

T-LOAD Copies records from tape to disk

JBase - User Guide - Release R15.000 - Page 453 of 629


JQLCOMPILE

JQLCOMPILE compiles a jQL statement.

COMMAND SYNTAX
JQLCOMPILE(Statement, Command, Options, Messages)

SYNTAX ELEMENTS

Statement is the variable, which will receive the compiled statement (if it compiles); most other functions use this to execute and work on the
result set etc.

Command is the actual jQL query that you want to compile (such as SELECT or something similar). Use RETRIEVE to obtain fetchable data
records, as the verb rather than an existing jQL verb. This will ensure that the right options are set internally. In addition, use any word that is
not a jQL reserved word as the verb and it will work in the same way as RETRIEVE: implement a PLOT command that passes the entire com-
mand line into JQLCOMPILE and the results will be the same as if the first word were replaced with RETRIEVE.

Option: To supply a select list to the JQLEXECUTE function specify JQLOPT_ USE_SELECT specify JQLOPT_USE_ SELECT; the compile
builds a different execution plan if using select lists.

Messages:  If the statement fails to compile, this dynamic array is in the STOP format, and therefore you can program and print STOP mes-
sages, which provides a very useful history of compilation for troubleshooting purposes. It returns -1 if a problem was found in the statement
and zero if there was not.

JBase - User Guide - Release R15.000 - Page 454 of 629


JQLEXECUTE

JQLEXECUTE starts executing a compiled jQL statement.

COMMAND SYNTAX
JQLEXECUTE(Statement, SelectVar)

SYNTAX ELEMENTS
Statement is the valid result of a call to JQLCOMPILE(Statement, …).

SelectVar is a valid select list that used to limit the statement to a predefined set of items. For example:

SELECT PROGRAMMERS WITH IQ_IN_PTS > 250

1 Item Selected

LIST PROGRAMMERS NAME

PROGRAMMERS... NAME

0123 COOPER, F B

This function returns -1 in the event of a problem, such as the statement variable not being correct. It will cause the statement to run against
the database and produce a result set for use with JQLFETCH()

JBase - User Guide - Release R15.000 - Page 455 of 629


JQLFETCH

JQLFETCH fetches the next result in a compiled jQL statement.

COMMAND SYNTAX
JQLFETCH(Statement, ControlVar, DataVar)

SYNTAX ELEMENTS
Statement is the result of a valid call to JQLCOMPILE(), followed by a valid call to JQLEXECUTE().

ControlVar will receive the ‘control break’ elements of any query. For example, if there are BREAK values in the statement, and you want the
totals, they will be described here.
The format of ControlVar is:

Attr 1              Level:

0 means detail line

1 - 255    for the control breaks, the same as the A correlative NB.

Attr2               Item ID  

Attr 3              Break control

Value is 1 if a blank line should be output first.

Attr 4              Pre-break value for 'B' option in header

Attr 5   Post-break value for 'B' option in header

DataVar will receive the actual data sent to the screen on a LIST statement for instance. The format is one attribute per column.

Applies Attribute 7 Conversions (or attribute 3 in Prime-style DICTS) to the data

If setting the property STMT_PROPERTY_ FORMAT then it also formats each attribute according to the width and justification of the attrib-
ute definition and any override caused by the use of FMT, of DISPLY.LIKE on the command line –

NOTE: that column headers may also affect the formatting for that column.

This function is called multiple times until there is no more output.

JBase - User Guide - Release R15.000 - Page 456 of 629


JQLGETPROPERTY

Gets the property of a compiled jQL statement

COMMAND SYNTAX
JQLGETPROPERTY(PropertyValue, Statement, Column, PropertyName)

SYNTAX ELEMENTS

Option Description

PropertyValue Receives the requested property value from the system or “” if the property is not set

Statement The result of a valid JQLCOMPILE(Statement)

Column Specifies that you want the value of the property for a specific column (otherwise 0 for the whole
statement).

PropertyName These are EQUATED values defined by INCLUDE’ing the file JQLINTERFACE.h.
This function returns -1 if there is a problem with the parameters or the programmer. The use of
these properties is to answer questions such as “Was LPTR mode asked for,” and “How many
columns are there?”

Note: Properties are valid after the compile; this is the main reason for separating the compile and execute into two functions. After compiling,
it is possible examine the properties and set properties before executing.

JBase - User Guide - Release R15.000 - Page 457 of 629


JQLPUTPROPERTY

Sets a property in a compiled jQL statement

COMMAND SYNTAX
JQLPUTPROPERTY(PropertyValue, Statement, Column, PropertyName)

SYNTAX ELEMENTS
PropertyValue is the value you want to which to set the specified property, such as 1 or “BLAH”

Statement is the result of a valid JQLCOMPILE() function.

Note: Some properties may require JQLEXECUTE() first.

Column Holds 0 for a general property of the statement, or a column number if it is something that can be set for a specific column.

PropertyName – These are EQUATED values defined by INCLUDE’ing the file JQLINTERFACE.h. There are lots of these and someone is going
to have to document each one.

This function returns -1 if a problem was found in the statement and 0 if there was not.

NOTE: Properties are valid after the compile; this is the main reason for separating the compile and execute into two functions. After com-
piling, it is possible examine the properties and set properties before executing.

JBase - User Guide - Release R15.000 - Page 458 of 629


L Conversion

L codes return the length of a value, or the value if it is within specified criteria.

COMMAND SYNTAX
L{{min,}max}

SYNTAX ELEMENTS
min  Specifies that the process is to return an element if its length is greater than or equal             to the number min.

max  Specifies that the process is to return an element if its length is less than or equal to                            the number max.

Comments: The L code by itself returns the length of an element. When used with max or min and max the L code returns the element if it is
within the length specified by min and/or max.

EXAMPLE 1
L - Assuming a value of ABCDEF, returns the value 6.

EXAMPLE 2
L4

If JBCEMULATE is set to ROS, L4 is translated as return the value if its length is less than or equal to 4 - the equivalent of L0,4. Assuming a
value of ABCDEF, L4 will return null - the value is longer than 4 characters.

If JBCEMULATE is not set to ROS, L4 is translated as return the value if its length is exactly equal to 4 - the equivalent of L4,4. Assuming a
value of ABCDEF, L4 will return null - the value is longer than 4 characters.

EXAMPLE 3
L4,7

L4,7 is translated as return the value if its length is greater than or equal to 4 and less than or equal to 7. Assuming a value of ABCDEF, L4,7
will return ABCDEF.

JBase - User Guide - Release R15.000 - Page 459 of 629


Left Ignore examples

The following sentence lists information about all the CUSTOMER code numbers ending in 00.

LIST CUSTOMER = ‘[00’

The following sentence does not list any rooms because there is no relational operator, the value [23 is treated as an item-id.

LIST CUSTOMER ‘[23’

JBase - User Guide - Release R15.000 - Page 460 of 629


LIST-LABEL

Outputs data in a format suitable for producing labels

COMMAND SYNTAX
LIST-LABEL file-specifier {record-list} {selection-criteria} {sort-criteria} {USING file-specifier}{output-specification} {format-specification}
{(options}

PROMPTS
At the prompt, supply formatting criteria as follows:

COL, ROW, SKIP, INDENT, SIZE, SPACE{C}:

COL                              
The number of columns required to list the data across the page.

ROW                           
Number of lines for each record; Each element of the output specification appears on a separate line, if
more elements exist in the output specification than rows specified it ignores the extra elements. If
you specify more rows than elements, the output specification for these rows will be blank.

SKIP                             
Number of blank lines between each record.

INDENT                       
Number of spaces for left margin.

SIZE                             
Number of spaces required for the data under each column.

SPACE                         
Number of horizontal spaces to skip between columns

C                    
Optional:. Suppresses null or missing data; If absent, outputs null or missing values as blanks. If
present, the C must be upper case and not in quotes

Comments: The total number of columns specified must not exceed the page width, based on the calculation:

COLs * (SIZE + SPACE) + INDENT <= page width

ROW must be a minimum of one for each field, plus one for the record key (if not suppressed). If the record keys are not suppressed, the first
row of each label will contain the record key.

If INDENT is not zero, at the prompt supply a series of HEADERs that will appear in the left margin for each field. If a heading is not required
for a particular line, press <ENTER>.

Multivalued fields appear as separate labels.

If specified, COL-HDR-SUPP or HDR-SUPP, or the C or H options, the page number, date, and time will not be output and generates the
report without page breaks. You must specify a sort criteria clause to sort the records.

See also the SORT-LABEL Command.

EXAMPLE
LIST-LABEL ORDER ORD.ID ORD.CUS.REF ID-SUPP (C

COL,ROW,SKIP,INDENT,SIZE,SPACE(,C): 2,5,2,0,25,4,C

PAGE 1 13:06:26 15 NOV 2004

JBase - User Guide - Release R15.000 - Page 461 of 629


Order 30058475 30058488

Orderid 404343 235

Customer Ref

Order 30058501 30058476

Orderid PO 30232 0500444

Customer Ref

Order 30058489 30058502

Orderid 658 2202FR

Customer Ref

Order 30058490 30058477

Orderid 1254 PO 76876

JBase - User Guide - Release R15.000 - Page 462 of 629


LIST

Generates a formatted report of records and fields from a specified file

COMMAND SYNTAX
LIST file-specifier {record-list} {selection-criteria} {sort-criteria} {USING file-specifier} {output-specification} {format-specification}
{(options}

Comments: If providing no output specification clause the system searches for default data definition records (named 1, 2 and so on) in the file
dictionary and then in the file specified in the JEDIFILENAME_MD environment variable. If no default data definition records are found, it
lists only the record keys. You must specify a sort criteria clause to sort the records.

EXAMPLE 1
LIST ORDER

List all the records in the SALES file and use the default data definition records (if found) to format the output.

EXAMPLE 2
LIST ORDER “ABC” “DEF” “GHI”

List the records from the ORDER file with key values of ABC, DEF or GHI. Use the default data definition records (if found) to format the out-
put.

EXAMPLE 3
GET-LIST ORDER

>LIST ORDER GT “DEF”

Get the previously saved list called ORDER.Q4 and, using the list, report on the records in the ORDER file which have a key greater than DEF.
Use the default data definition records (if found) to format the output.

EXAMPLE 4
LIST ORDER WITH ORD.ID = “ABC]” OR “[DEF”

List the records in the ORDER file in which the ORD.ID field contains values which start with ABC or end with DEF. Use the default data
definition records (if found) to format the output.

EXAMPLE 5
LIST ORDER WITH NO ORD.ID = “ABC]” OR “[DEF” (P

List the records in the ORDER file in which the ORD.ID field does not contain values which start with ABC or end with DEF. Output the
report to the printer. Use the default data definition records (if found) to format the output.

JBase - User Guide - Release R15.000 - Page 463 of 629


EXAMPLE 6
LIST order BY ORD.AMT BREAK-ON ORD.AMT “”BL” ORD.ID ORD.COST GRAND-TOTAL “Total”

HEADING “Sales Code: “B” “DL” FOOTING “Page “CPP” LPTR

Sort the ORDER file by ORD.AMT. Output the ORD.AMT, ORD.ID and ORD.COST fields.

Control break on a change in ORD.AMT and suppress the LINE FEED before the break. Reserve the break value for use in the heading (“B”).

Maintain a running total of the ORD.COST field and output it at each control break.

Put the word “Total” on the grand-total line.

Set up a heading for each page which comprises the words “Sales Code: “, the sales code (from the break), a date and a LINE FEED. Set up a
footing, which contains the text “Page”, and a page number, centered on the line?

Produce the report on the currently assigned printer.

JBase - User Guide - Release R15.000 - Page 464 of 629


LISTDICT

Generates a report of all data definition records in the first MD file found, or the specified file

COMMAND SYNTAX
LISTDICT {file-specifier}

SYNTAX ELEMENTS
file specifier - specifies a dictionary file other than a file named MD in the JEDIFILEPATH.

Comments: If you do not specify a file-name, LISTDICT will work with the first file named MD, it finds in your JEDIFILEPATH.

JBase - User Guide - Release R15.000 - Page 465 of 629


Logical Connectives

The logical connective AND or OR joins two relational expressions. The default connective is OR. If giving two relational expressions without a
logical operator between them, items satisfying either expression are selected (as if the OR connective had been used).

The connective AND yields a truth-value of true if all the truth values it is combining are true. If any truth-value is false, the result of the AND
connective is false. The OR connective yields a truth value of true if at least one of the truth values it is combining is true.

JBase - User Guide - Release R15.000 - Page 466 of 629


Logical Operators

The logical operators test two expressions for true (1) or false (0) and return a value of true or false. Logical operators are:

AND|Returns       True if both expressions are true.

OR|Returns         True if any expressions is true.

The words AND and OR must be followed by at least one space. The AND operator takes precedence over the OR unless you specify a different
order by means of parentheses. OR is the default operation.

JBase - User Guide - Release R15.000 - Page 467 of 629


Logical Operators

Logical operators include a logical AND test and a logical inclusive-OR test.

Logical operators are:

& AND stack entries 1 If both entries contain non-zero, pushes a 1 onto stack entry 1, otherwise, pushes a
and 2. 0.

! OR stack entries 1 and If either of the entries contains non-zero, it pushes a 1 onto stack entry 1; oth-
2. erwise, pushes a 0.

JBase - User Guide - Release R15.000 - Page 468 of 629


Macros

Macros contain predefined or often used elements of a jQL sentence, stored on the system like data definition records and are specified in the
command sentence in a similar way.  When submitting a command containing one or more macros for execution it expands and includes the
macro references in the sentence. You can substitute macros for any element of the command sentence except the command itself and the file-
name.

The search for macro definition records is in the same way as data definition records. Do not use a jQL keyword for a Data Definition record. 
The first field of a macro definition must contain the letter M. The remaining fields are either command elements or comment lines (indicated
by a leading asterisk ‘*’ and a space).

You can nest macros - a macro can refer to another macro - but the resulting command sentence must still follow the same rules as a normal
jQL sentence. When nesting macros, beware of infinite loops where for example, macro A calls macro B that calls macro A that calls macro B.

EXAMPLE
SORT ORDER BY ORD.COST STD.HEADING

In this example, STD.Heading is a macro, which contains a standard heading clause:

STD.HEADING
001 M

002 * Standard heading for sales reports

003 Heading “SALES - COMPANY PRIVATE’LL’PAGE ‘PL’”

004 LPTR

When the sentence expands it will look like this:

SORT SALES BY S.CODE HEADING “SALES - COMPANY PRIVATE’LL’PAGE ‘” LPTR

JBase - User Guide - Release R15.000 - Page 469 of 629


MC Conversion

MC codes include facilities for:

l Changing characters to upper or lower case


l Extracting a class of characters
l Replacing characters
l Converting ASCII character codes to their hexadecimal or binary representations and vice versa
l Converting a hexadecimal values to their decimal or binary equivalents and vice versa
l Converting a decimal value to its equivalent in Roman numerals and vice versa

One source of confusion when using MC codes is that input conversion does not always invert the code. If most MC codes are used in field 7 of
the data definition record, applies the code in its original (un-inverted) form to the input data Therefore, you should always try to place MC
codes into field 8 of the data definition record. The exceptions to this, is where input conversion is effective, are clearly indicated in the fol-
lowing sections.

SUMMARY
MC codes codes are:

MCA Extract only alphabetic characters.

MC/A Extract only non-alphabetic characters.

MCAB{S} Convert ASCII character codes to binary representation. Use S to suppress spaces.

MCAX or Convert ASCII character codes to hexadecimal representation.


MX

MCB Extract only alphabetic and numeric characters.

MC/B Extract only special characters that are neither alphabetic nor numeric.

MCBA Convert binary representation to ASCII characters.

MCBX Convert a binary value to its hexadecimal equivalent.

MCC;x;y Change all occurrences of character string x to character string y.

MCDR Convert a decimal value to its equivalent Roman numerals. Input conversion is effective.

MCDX or Convert a decimal value to its hexadecimal equivalent. Input conversion is effective.
MCD

MCL Convert all upper case letters (A-Z) to lower case.

MCN Extract only numeric characters (0-9).

MC/N Extract only non-numeric characters.

MCNP{c} Convert paired hexadecimal digits preceded by a period or character c to ASCII code.

MCP{c} Convert each non-printable character (X”00” - X”IF”, X”80” - X”FE”) to a period (.) or to character c.

MCPN{c} Same as MCP but insert the two-character hexadecimal representation of the character immediately
after the period or character c.

JBase - User Guide - Release R15.000 - Page 470 of 629


MCRD or Convert Roman numerals to the decimal equivalent. Input conversion is effective.
MCR

MCT Convert all upper case letters (A-Z) in the text to lower case, starting with the second character in each
word. Change the first character of each word to upper case if it is a letter.
MCU Convert all lower case letters (a-z) to upper case.

MCXA or Convert hexadecimal representation to ASCII characters.


MY

MCXB{S} Convert a hexadecimal value to its binary equivalent. Use S to suppress spaces between each block of 8
bytes.
MCXD or Convert a hexadecimal value to its decimal equivalent. Input conversion is effective.
MCX

JBase - User Guide - Release R15.000 - Page 471 of 629


MD Conversion

The MD code transforms integers by scaling them and inserting symbols, such as a currency sign, thousands separators, and a decimal point.
The ML and MR codes are similar to MD but have greater functionality.

COMMAND SYNTAX
MDn{m}{Z}{,}{$}{ix}{c}

SYNTAX ELEMENTS

n a number from 0 to 9 that specifies how many digits are to be output after the decimal point; inserts trail-
ing zeros as necessary. If n is omitted or 0, the decimal point is not output.

n a number from 0 to 9, which represents the number of digits that the source value contains to the right of
the implied decimal point. Uses m as a scaling factor and the source value is descaled (divided) by that
power of 10. For Example, if m=1, the value is divided by 10; if m=2, the value is divided by 100, and so
on. If m is omitted, it is assumed equal to n (the decimal precision). If m is greater than n, the source value
is rounded up or down to n digits. The m option must be present if the ix option is used and both the Z
and $ options are omitted. This to remove ambiguity with the ix option.

z suppresses leading zeros. Note that fractional values, which have no integer, will have a zero before the
decimal point. If the value is zero, a null will be output.

, specifies insertion of the thousands separator symbol every three digits to the left of the decimal point. The
type of separator (comma or period) is specified through the SET THOU Command. (Use the SET DEC
Command to specify the decimal separator.)

$  appends an appropriate currency symbol to the number. The currency symbol is specified through the SET
MONEY Command.

ix aligns the currency symbol by creating a blank field of “i” number of columns. The value to be output over-
writes the blanks. The “x” parameter specifies a filler character that can be any non-numeric character,
including a space.

c appends a credit character or encloses the value in angle brackets ( >). Can be any one of the following:

- Appends a minus sign to negative values; a blank follows positive or zero values.

C Appends the characters CR to negative values. Two blanks follow positive or zero values.

Input Conversion: works with a number that has only thousands separators and a decimal point.

EXAMPLES

MD Code Source Value Returned Value

MD2 1234567 12345.67

MD2, 1234567 12,345.67

MD2,$ 1234567 $12,345.67

JBase - User Guide - Release R15.000 - Page 472 of 629


MD2,$12* 1234567 $**12,345.67

MD2,$12- -1234567 $12,345.67-

MD42Z,$ 001234567 $12,345.6700

MD42Z,$15 < -001234567 <$ 12,345.6700>

JBase - User Guide - Release R15.000 - Page 473 of 629


Miscellaneous Operators

Miscellaneous operators control formatting, exchanging stack entries, popping the top entry, concatenation, and string extraction. They are:

- Exchange the top two entries

^ pop last entry from the stack and discard. Pushes all other entries up.

Format Perform the specified format code on last entry and replace last entry with the result
Code

: Concatenate stack entries:

F - Concatenates Entry 1 to the end of Entry 2

FS, FE - Concatenates Entry 1 to the end of Entry 2

F - Concatenates Entry 2 to the end of Entry 1(ROS emulation)

[ ] Extract a substring from stack entry 3. The starting column is specified in stack entry 2 and the num-
ber of characters is specified in entry 1

JBase - User Guide - Release R15.000 - Page 474 of 629


MK Conversion

The MK code allows you to display large numbers in a minimum of columns by automatically descaling the numbers and appending a letter to
represent the power of 10 used. The letters and their meanings are:

K 10 /3 (Kilo)

 M 10 /6(Mega)

 G 10 /9 (Giga)

COMMAND SYNTAX
MKn

SYNTAX ELEMENTS
n      represents the field width and if present will include the letter and a minus sign.

Comments: will not change if a number will fit into the specified field width.

If the number is too long but includes a decimal fraction, the MK code first attempts to round the fractional part so that the number will fit the
field. If the number is still too long, the code rounds off the three low-order integer digits, replacing them with a K. If the number is still too
long, the code rounds off the next three digits, replacing them with an M. If that is still too long, the code rounds off three more digits, repla-
cing them with a G. If the number still does not fit the specified field, the code displays an asterisk. If the field size is not specified or is zero,
the code outputs null.

Input Conversion: does not invert. It simply applies the metric processing to the input data.

EXAMPLES

Source Data MK3 MK4 MK5 MK7

1234 1K 1234 1234 1234

123456789 * 123M 123M 123457K

123456789012345 * * * 123457G

999.9 1K 1000 999.9 999.9

-12.343567 -12 -12 -12.3 -12.344

-1234.5678 -1K -1K -1235 -1234.6

-0.1234 -.1 -.12 -.123 -0.1234

JBase - User Guide - Release R15.000 - Page 475 of 629


Ml / MR Conversion

ML and MR codes format numbers and justify the result to the left or right respectively. The codes provide the following capabilities:

l Decimal precision and scaling


l Zero suppression
l Thousands separator
l Credit codes
l Currency symbol
l Inclusion of literal character strings

COMMAND SYNTAX
ML {n {m}} {Z} {,} {c} {$} {fm}
MR{n{m}}{Z}{,}{c}{$}{fm}

SYNTAX ELEMENTS

ML Provides left justification of the result.

MR Provides right justification of the result.

n a number from 0 to 9 that defines the decimal precision. It specifies the


number of digits to for output following the decimal point. The processor
inserts trailing zeros if  necessary. If n is omitted or is 0, a decimal point
will not be output.

m a number that defines the scaling factor. The source value is descaled
(divided) by that power of 10. For Example, if m=1, the value is divided by
10; if m=2, the value is divided by 100, and so on. If m is omitted, it is
assumed equal to n (the decimal precision).

z suppresses leading zeros. Note that fractional values, which have no


integer, will have a zero before the decimal point. If the value is zero, a null
will be output.

, The thousands separator symbol. It specifies insertion of thousands


separators   every three digits to the left of the decimal point. You can
change the display separator symbol by invoking the SET THOU Com-
mand. Use the SET DEC Command to specify the decimal separator.

C    Print the literal CR after negative values.

D     Print the literal DB after positive values.

E  Enclose negative values in angle brackets < >

M    Print a minus sign after negative values

N     Suppresses embedded minus sign.

JBase - User Guide - Release R15.000 - Page 476 of 629


If a value is negative and you have not specified one of these indicators, displays the value with a leading minus
sign. If you specify a credit indicator, outputs the data with either the credit characters or an equivalent number
of spaces, depending on its value.

$      Specifies that a currency symbol is to be included. Places a floating cur-


rency symbol in front of the value. The currency symbol is specified through
the SET MONEY Command.

Fm   : Specifies a format mask. A format mask can include literal characters as
well as format  codes. The format codes are as follows

CODE FORMAT

#{n} Spaces. Repeat space n times. Overlays the output value on the spaces created.

*{n} Asterisk. Repeat asterisk n times. Overlays the output value on the asterisks created.

%{n} Zero. Repeat zeros n times. Overlays the output value on the zeros created.

&x   can be any of the above format codes, a currency symbol, a space, or literal text. The first character fol-
Format. lowing ‘&’ is used as the default fill character to replace #n fields  without data. You may enclose
x format strings enclosed in parentheses “( )”.

Comments: The justification specified by the ML or MR code applies at different stages from that specified in field 9 of the data definition
record. The sequence of events begins with the formatting of the data with the symbols, filler characters and justification (left or right) specified
by the ML or MR code. The formatted data is justified according to field 9 of the definition record and overlaid on the output field, which ini-
tially comprises the number of spaces specified in field 10 of the data definition record.

Input Conversion: works with a number that has only thousands separators and a decimal point.

EXAMPLES

Conversion Source Dict Fields Returned Value (columns)


Code Value 9 and 10 12345678901234567890

MR2#10 1234 L 15 12.34

MR2#10 1234 R 15 12.34

ML2%10 1234 L 15 12.3400000

MR2%10 1234 R 15 0000012.34

ML2*10 1234 L 15 12.34*****

MR2*10 1234 R 15 *****12.34

MR2,$#15 12345678 L 20 #123,456.78

MR2,&$#15 12345678 L 20 #####123,456.78

ML2,&*$#15 12345678 L 20 #123,456.78*****

MR2,& $#15 12345678 L 20 # 123,456.78

MR2,C&*$#15 -12345678 L 20 #***123,456.78CR

JBase - User Guide - Release R15.000 - Page 477 of 629


ML& ###-##-### 123456789 L 12 123-45-6789

ML& #3-#2-#4 123456789 L 12 123-45-6789

ML& Text #2-#3 12345 Text 12-345

ML& ((Text#2) #3) 12345 (Text12) 345

In the last Example, it ignores the leading and trailing parenthesis.

JBase - User Guide - Release R15.000 - Page 478 of 629


MP Conversion

MP codes convert packed decimals to unpacked decimal representation for output or decimal values to packed decimals for input.

COMMAND SYNTAX
MP 

Comments: The MP code most often used as an output conversion; on input, the MP processor combines pairs of 8-bit ASCII digits into
single 8-bit digits as follows: 

l Strips off the high order four bits of each ASCII digit.
l Moves the low order four bits into successive halves of the stored byte
l Adds a leading zero (after the minus sign if present) if the result would otherwise yield an uneven number of halves.
l Ignores leading plus signs (+)
l Stores leading minus (-) signs as a four-bit code (D) in the upper half of the first internal digit.

When displaying packed decimal data, you should always use an MP or MX code. Raw packed data is almost certain to contain control codes
that will upset the operation of most terminals and printers.

Input Conversion: is valid. Generally, for selection processing you should specify MP codes in field 7 of the data definition record.

EXAMPLES
OCONV -1234 “MP”

yields 0x D01234

ICONV 0x D01234 “MP”

yields -01234

JBase - User Guide - Release R15.000 - Page 479 of 629


MS Conversion

The MS code allows an alternate defined sort sequence for sort fields.

COMMAND SYNTAX
MS

Comments: Use of the MS code is only relevant when applying in field 8 pre-process codes to a specified field in a sort clause. In all other
cases, it will be ignored.

Use the sort sequence defined in a special record named SEQ that you must create in the ERRMSG file. Field 1 of this record contains a
sequence of ASCII characters that define the order for sorting.

EXAMPLE
SEQ (defined in ERRMSG file)
001 aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyY
zZ9876543210 ,.?!””;:+-*/^=()[]{}<>@#$%&”~\|

INV.CODE (data definition record)


001 A
008 MS

SORT SALES BY INV.CODE ID-SUPP

SALES....

AbC789
ABC789
ABC788
dEF123

JBase - User Guide - Release R15.000 - Page 480 of 629


MT Conversion

Use the MT code to convert time notations such as 01:40:30 or 1:30 AM between internal and external format.

COMMAND SYNTAX
MT{H}{S}

SYNTAX ELEMENTS
H specifies 12-hour format. Uses 24-hour format if omitted

S specifies that seconds are to be included.

Comments: Time is stored internally as the number of seconds since midnight. Outputs the stored value in 12 hour or 24 hour (international)
format

Defines 12:00PM as noon and 12:00AM as midnight

Automatically displays AM and PM designators. For Example: 09:40AM and 06:30PM.

Input Conversion: is valid. Generally, for selection processing you should specify MT codes in field 7 of the data definition record.

Considers AM or PM designators; affects the result of the input conversion for certain values by the time_is_hours emulation setting.

EXAMPLES

Input Conversion

Code Input Result

MT 00:00 0

MTH 12:00AM 0

MT 01:00AM 3600

MT 01:00 3600

MTH 01:00 3600

MTH 01:00AM 3600

MT 01:00PM 46800

MTH 01:00PM 46800

MTS 01:00:30 3630

JBase - User Guide - Release R15.000 - Page 481 of 629


Operators and conversions

Operators used in A code expressions include arithmetic, relational and logical operators, the concatenation operator, and the IF statement.

JBase - User Guide - Release R15.000 - Page 482 of 629


Order of Operation

F code operations are typically expressed as “F;stack2;stack1;operation” and evaluated under most emulation, as “stack2 operation stack1”.

If JBCEMULATE is set to “ROS”, this example is evaluated as “stack1 operation stack2”, effectively reversing the order of operations.

NOTE: that the FE and FS codes are evaluated in the same way for all emulations.

No Input conversion allowed.

EXAMPLE 1
F;C3;C5;-

Push a value of three onto the stack. Push a value of five onto the stack.

Take entry 1 from entry 2 (3 - 5) and push the result (-2) back onto the stack as entry 1. ROS emulations will subtract 3 from 5 and return a
result of two.

EXAMPLE 2
FS;C3;C5;-

Push a value of three onto the stack. Push a value of five onto the stack. Take entry 2 from entry 1 (3 - 5) and push the result (-2) back onto
the stack. This works in the same way for all emulations.

EXAMPLE 3
F;C2;C11;C3;-;/

Push a value of two onto the stack. Push a value of 11 onto the stack. Push a value of three onto the stack. Subtract entry 1 from entry 2 (11 -
3) and push the result (8) back onto the stack. Now divide entry 2 by entry 1 (2 divided by 8) and push the result (0) back onto the stack.

Under ROS emulation, this would evaluate as 3 - 11 = -8, followed by -8 / 2 = -4.

JBase - User Guide - Release R15.000 - Page 483 of 629


Output Conversion

Code Source Value Result

MTS 0 00:00:00

MTHS 0 12:00:00AM

MT 3600 01:00

MTH 3600 01:00AM

MT 46800 13:00

MTS 46800 13:00:00

MTH 46800 01:00PM

MTHS 46800 01:00:00PM

JBase - User Guide - Release R15.000 - Page 484 of 629


Output Specification Clause

The output specification clause names the fields that are to be included in the report.

SYNTAX
field {print limiter}

TOTAL field {print-limiter}

BREAK-ON field “{text}{2option{option}...’}{text}

Print limiter has the form:

{NOT} {relational operator} “value string” {{logical-connective} {NOT} {relational-operator} “value string”}...

SYNTAX ELEMENTS
TOTAL specifies that a running total of a numeric field be maintained

field identifies the name of a data definition record

Print limiter suppresses output of values (to subvalue level) that do not match the clause, which replaces suppressed values with blanks. Any
detail lines that would as a result, be blank, are suppressed. Any totals produced include just the values that match the limiting clause.

BREAK-ON specifies that control break be performed and a break line displayed, each time the value of a field changes

Text comprises any printable characters except RETURN, LINE FEED, double quotes, single quotes or system delimiters.

Options is one OR more of the following options:

B Break: works in conjunction with the B option of the Heading and FOOTING modifiers to insert the break
value in the heading or footing.

D Data: suppresses the break if only one detail line has been output since the last break.

L Line: suppresses the blankline preceding the break data line. Overrides the U option if both are specified.

P Page: throws a new page after each new break value until all the data associated with the current break has
been output.

R Rollover: Inhibits a page break until all the data associated with the current break has been output.

U Underlines: if specified places underlines on the line above the accumulated totals. Ignored if used with the
L option.

V Value: inserts the value of the control break field at this point in the BREAK-ON option.

Comments: If the sentence contains an output specification clause, it ignores any default definition records in the dictionary.

JBase - User Guide - Release R15.000 - Page 485 of 629


P Conversion

The P code returns a value if it matches one of the specified patterns, which can be combinations of numeric and alphabetic characters and lit-
eral strings.

COMMAND SYNTAX
P{#}(element){;(element)}...

SYNTAX ELEMENTS
Comments: Returns a null value if the value does not match any of the patterns.

Input Conversion: does not invert. It simply applies the pattern matching to the input data.

EXAMPLE 1
P(2A”*”3N”/”2A)

Will match and return AA*123/BB or xy*999/zz. Will fail to match AAA*123/BB or A1*123/BB, and will return null.

EXAMPLE 2
P(2A”*”3N”/”2A);(2N”-“2A)

Will match and return AA*123/BB, xy*999/zz, 99-AA or 10-xx. Will fail to match AA&123/BB, A1*123/BB, 9A-AA or 101-xx, and will return
null.

JBase - User Guide - Release R15.000 - Page 486 of 629


Pre processor Conversion

Field 8 codes are valid but, generally, it is easier to specify the D code in field 7 for input conversion. Dates in output format are difficult to use
in selection processing.

If you are going to use selection processing and you want to use a code which reduces the date to one of its parts, such as DD (day of month),
the D code must be specified in field 8.

Field 7 input and output conversions are both valid.

Generally, for selection processing, you should specify D codes in field 7 except when you use a formatting code, such as DM, that reduces the
date to one of its parts. If you specify no year in the sentence, the system assumes the current year on input conversion. If specifying only the
last two digits of the year the system assumes the following:

00-29       2000-2029

30-99       1930-1999

EXAMPLES

D Code Internal Value Value Returned

D 9904 11 FEB 1995

D2/ 9904 11/02/95

D- 9904 11-02-1995

D0 9904 11 FEB

DD 9904 11

DI 11 FEB 1995 9904

DJ 9904 41

DM 9904 2

DMA 9904 FEB

DQ 9904 1

DW 9904 6

DWA 9904 SATURDAY

DY 9904 1995

DY2 9904 95

JBase - User Guide - Release R15.000 - Page 487 of 629


Push Operator

A push operator always pushes a single entry onto the stack. Existing entries are moved one position down. Push operators are: “literal” Lit-
eral. Any text string enclosed in double or single quotes.

field-number{R{R}}{(format-code)}

Field The value of the field from the current record.


number

R Specifies that the last non-null value obtained from this field be applied for each multivalue that does
not exist in a corresponding part of the calculation.

RR Specifies that the last non-null value obtained from this field be applied for each  subvalue that does
not exist in a corresponding part of the calculation.

(format code). One or more format codes (separated by value marks) enclosed in

parentheses and applied to the value before it is pushed onto the stack.

Cn Constant - where n is a constant (text or number) of any length up to the next semicolon or system
delimiter.

D Current system date.

NA Number of fields in the record.

NB Current break level number: -1 = during SORT or SELECT processing 0 = detail

line 1 = lowest break level 255 = GRAND-TOTAL line

ND Number of records since the last BREAK on a BREAK data line. Equal to the record counter on a
GRAND-TOTAL line. Used to compute averages.

NI Record counter. The ordinal position of the current record in the report.

NL Length of the record, in bytes. Includes all field marks but not the key.

NS Subvalue counter. The ordinal position of the current subvalue within the field.

NV Value Counter. The ordinal position of the current multivalue within the field.

P Alternatively, it pushes duplicate of entry 1 onto the stack.

T System time in internal format.

V or Previous Value. Use the value from the previous format code.
LPV

JBase - User Guide - Release R15.000 - Page 488 of 629


R Conversion

The R code returns a value that falls within one or more specified ranges.

COMMAND SYNTAX
Rn,m{;n,m}...

SYNTAX ELEMENTS
n             the starting integer of the range. Can be positive or negative.

m            the ending integer of the range. Can be positive or negative, but must be equal to or greater than n.

Comments: Returns a null value if the value does not fall within the range(s).

Input Conversion: does not invert. It simply applies the range check to the input data.

EXAMPLE 1
R1,10

Will return any value that is greater than or equal to one and less than or equal to 10

EXAMPLE 2
R-10,10

Will return any value that is greater than or equal to -10 and less than or equal to 10

EXAMPLE 3
R-100,-10

Will return any value that is greater than or equal to -100 and less than or equal to -10

JBase - User Guide - Release R15.000 - Page 489 of 629


Record Structure

The fields of a file definition record that affect jQL reports are:

Field 7 Conversion code for key if required. For date, time, etc.,

Field 8 V code to notify a multivalued (sublist) field if required. See sublists - V code.

Field 9 Justification for key. Can be one of the following (see data definition records)

L Left justified

R Right justified

T Text

U unlimited

Field 10 Column width for Key. Default is 14 characters.

JBase - User Guide - Release R15.000 - Page 490 of 629


REFORMAT

REFORMAT is similar to the LIST Command in that it generates a formatted list of fields, but its output is directed to another file or the mag-
netic tape rather than to the terminal or printer.

COMMAND SYNTAX
REFORMAT file-specifier {record-list} {selection-criteria} {USING file-specifier} {output-specification} {format-specification} {(options}

PROMPT
At the prompt, supply the destination file:

File: Enter a file name, or the word “TAPE” for output to a magnetic tape.

Comments: Overwrites records that already exist in the destination file; when you reformat one file into another, each selected record becomes
a record in the new file. It uses the first value specified in the output specification clause as the key for the new records. The remaining values
in the output specification clause become fields in the new records.

When you reformat a file to tape, it concatenates the values specified in the output specification clause to form one tape record for each selec-
ted record. The record output is truncated or padded at the end with nulls (X”00”) to obtain a record the same length as specified when the
tape was assigned by the T-ATT Command.

Unless you specify HDR-SUPP or COL-HDR-SUPP, or a C or H option, a tape label containing the file name, tape record length (in hexa-
decimal), it will write the time, and date to the tape. If specifying a HEADING clause, this will form the data for the tape label.

Unless the ID-SUPP modifier or the 'I' option is specified record keys are displayed as the records are written to tape.

Two EOF marks terminate the file on tape.

See also the SREFORMAT Command.

EXAMPLE
REFORMAT ORDER ORD.ADDR

FILE: ADDRESS

Creates new records in the ADDRESS file, keyed on C.CODE from the SALES file. Each record contains two fields, one with the values from the
NAME field and one with the values from the ADDRESS field.

JBase - User Guide - Release R15.000 - Page 491 of 629


Relational Operators

Relational operators specify relational operations so that any two expressions can treated as operands and evaluated as returning true (1)

or false (0). Relational operators are:

= or EQ           Equal to

< or LT                 Less than

> or GT                          Greater than

<= or LE        Less than or equal to

>= or GE         greater than or equal to

# or LTNE                      Not equal

JBase - User Guide - Release R15.000 - Page 492 of 629


Relational Operators

Relational operators compare stack entries and push the result onto stack entry 1; is either 1 (true) or 0 (false). Relational operators are:

= equal to

< less than:

F entry 2 < entry 1

FS,FE

entry2 < entry 1

F entry 1 < entry 2 (ROS emulation)

> Greater than:

Fentry 2 > entry 1

FS,FE

entry2 > entry 1

F entry 1 > entry 2 (ROS emulation)

[ Less than or equal to:

F entry 2 [ entry 1

FS,FE

entry2 [ entry 1

F entry 1 [ entry 2 (ROS emulation)

] Great than or equal to:

F entry 2 [ entry 1

FS,FE

entry 2 [ entry 1

F entry 1 [ entry 2 (ROS emulation)

# Not equal.

JBase - User Guide - Release R15.000 - Page 493 of 629


Remainder Function

The Remainder Function R(exp1, exp2) takes two expressions as operands and returns the remainder when dividing the first expression by the
second.

Example: A;R(N(HOURS) / “24”) - Returns the remainders when 24 divide HOURS.

Summation Function: S(expression) evaluates an expression and then adds together all the values.

EXAMPLE
A;S(N(HOURS) * N(RATE)R)

Multiplies each value in the HOURS field by the value of RATE; the multivalued list of results is then totalled.

JBase - User Guide - Release R15.000 - Page 494 of 629


Repeat Operators

To repeat a value for combination with multivalues, follow the field number with the R operator. To repeat a value for combination with mul-
tiple subvalues, follow the FMC with the RR operator.

JBase - User Guide - Release R15.000 - Page 495 of 629


Replacing Characters

Some MC codes replace one set of characters with other characters. These codes can:

l Exchange one character string for another


l Replace non-printable characters with a marker character
l Replace non-printable characters with a marker character and the character’s hexadecimal representation
l Replace the marker and hexadecimal representation with the ASCII code

MCC;x;y Change all occurrences of character string x to character string y.

MCP{c} Convert each non-printable character (X”00” - X”IF”, X”80” - X”FE”) to character c, or period (.) if c is
not specified.

MCPN Same as MCP but insert the two-character hexadecimal representation of the character immediately
{c} after character c, or tilde (~) if c is not specified.

MCNP Convert paired hexadecimal digits preceded by a tilde or character c to ASCII code. The opposite of the
{c} MCPN code.

Input conversion does not invert. The original code will be applied to input data.

EXAMPLE 1
MCC;X5X;YYY

Assuming a source value of ABC*X5X!DEF, MCC will return ABC*YYY!DEF.

EXAMPLE 2
MCPN

Assuming a source value of ABC]]DEF where ] represents a value mark, MCPN will return ABC.FC.FCDEF.

JBase - User Guide - Release R15.000 - Page 496 of 629


S Conversion

The S code substitutes one value for another.

COMMAND SYNTAX
S;Var1;Var2

SYNTAX ELEMENTS
Var1 specifies the value to be substituted if the referenced value is not null or zero. Can be a quoted string, an FMC (field number), or an aster-
isk. An asterisk indicates that you should use the value of the referenced field.

Var2 specifies the value for substitution if the referenced value is null or zero. Can be a quoted string, an FMC (field number), or an asterisk.

EXAMPLE 1
S;*;”NULL VALUE!”

If the referenced field is null, this Example will return the string “NULL VALUE!”. Else, it will return the referenced value.

EXAMPLE 2
S;*;3

If the referenced field is null, this Example will return the content of field 3 of the data record. Else, it will return the referenced value.

EXAMPLE 3
S;4;5

If the referenced field is null, this Example will return the content of field 5 of the data record. Else, it will return the content of field 4.

JBase - User Guide - Release R15.000 - Page 497 of 629


SELECT

Generates an implicit list of record keys or specified fields based on the specified selection criteria

COMMAND SYNTAX
SELECT file-specifier {record-list} {selection-criteria} {sort-criteria} {output-criteria} {USING file-specifier} {(options}

SYNTAX ELEMENTS
The options are:

C{n} Display running counters of the number of records selected and records processed. Unless modified by n, the counter increments after
every 500 records processed or the total number of records if less than 500.

n n Specifies a number other than 500 by which to increment. For Example, C25 increments the counter after every 25 records processed.

Comments: You must specify a sort criteria clause to sort records.

See also the SSELECT Command.

If you specify an output-criteria clause, the generated list will comprise the data (field) values defined by the clause, rather than the selected
record keys.

If you are in jSHELL when the Command terminates, it displays the total number of entries in the generated list and the list is made available
to the next Command, as indicated by the > prompt.

If you use the BY-EXP or BY-EXP-DSND connectives on a multivalued field, the list will have the format:

record-key]multivalue#

where multivalue# is the position of the multivalue within the field specified by BY-EXP or BY-EXP-DSND. multivalue# can be accessed by a
READNEXT Var,n statement in a jBC program.

EXAMPLE 1
SELECT ORDER WITH ORD.AMT = “ABC]”

23 Records selected

>LIST ORDER WITH VALUE > “1000”

Select all the records in ORDER file with an ORD.AMT value that starts with ABC. Then, using the list, report on the records in the ORDER
file which have a VALUE field greater than 1000.

EXAMPLE 2
SELECT ORDER WITH ORD.AMT = “ABC]”

23 Records selected

>SAVE-LIST ORDER.ABC

Select all the records in ORDER file with an ORD.AMT value that starts with ABC. Then save the list as ORDER.ABC.

JBase - User Guide - Release R15.000 - Page 498 of 629


Single and Double Quotes

Values string delimiters are single quote (‘) and double quote (“). You can enclose an item-id value string in double quotes, but only if it is
entered immediately after the file name. Use single quotes within item-id selection clauses and doubles quotes within ordinary selection criteria
except when you are searching for an item-id that includes single quotes.

JBase - User Guide - Release R15.000 - Page 499 of 629


SORT - LABEL

Outputs data in a format suitable for producing labels

COMMAND SYNTAX
SORT-LABEL file-specifier {record-list} {selection-criteria} {sort-criteria} {USING file-specifier}{output-specification} {format-specification}
{(options}

PROMPTS
At the prompt, supply formatting criteria as follows:

COL, ROW, SKIP, INDENT, SIZE, SPACE(,C):

COL Number of columns required to list the data across the page.

ROW Number of lines for each record; the output of each element of the output specification is on a sep-
arate line, if more elements exist in the output specification than there are rows specified it ignores
the extra elements. If specifying more rows than elements, the output specification for these rows
will be blank.

SKIP Number of blank lines between each record.

INDENT Number of spaces for left margin.

SIZE Number of spaces required for the data under each column

SPACE Number of horizontal spaces to skip between columns.

C Optional. Suppresses null or missing data. If absent, null or missing values are output as blanks. If
present, the C must be upper case and not in quotes.

COL Number of columns required to list the data across the page.

ROW Number of lines for each record; the output of each element of the output specification is on a sep-
arate line, if more elements exist in the output specification than there are rows specified it ignores
the extra elements. If specifying more rows  than elements, the output specification for these rows
will be blank.

SKIP Number of blank lines between each record.

INDENT Number of spaces for left margin.

SIZE Number of spaces required for the data under each column

SPACE Number of horizontal spaces to skip between columns

C Optional: Suppresses null or missing data. If absent, null or missing values are output as blanks. If
present, the C must be upper case and not in quotes.

Comments: The total number of columns specified must not exceed the page width, based on the calculation:

COLs * (SIZE + SPACE) + INDENT <= page width

JBase - User Guide - Release R15.000 - Page 500 of 629


ROW must be a minimum of one for each field, plus one for the record key (if not suppressed). If record keys are not suppressed, the first row
of each label will contain the record key. If you specify a sort criteria clause, it sorts the records in key order.

If INDENT is not zero, at the prompt supply a series of HEADERs that will appear in the left margin for each field. If a heading is not required
for a particular line, press RETURN.

Multivalued fields appear on separate lines.

If specified, COL-HDR-SUPP or HDR-SUPP, or the C or H options, the page number, date, and time will not be output and the generated
report will be without page breaks.

See also the LIST-LABEL Command.

JBase - User Guide - Release R15.000 - Page 501 of 629


Sort Criteria Clause

The sort criteria clause allows you to specify the presentation order of the records in the report.

SYNTAX
BY field

BY-DSND field

BY-EXP field {print-limiter}

BY-EXP-DSND field {print limiter}

Print limiter has the form:

{relational operator} “value string” {{logical connective} {relational operator} “value string”}...

field is the name of a data definition records.

BY Specifies a single value sort that will order the records according to an

ascending sequence based on the first value in the specified field

BY-DSND Specifies a single value sort the which will order the records according to a

descending sequence based on the first value in the specified field

BY-EXP Specifies a multivalue sort that will order the multivalues of the specified

field according to an ascending sequence based on the first subvalue in each

multivalues element

BY-EXP-DSND Specifies a multivalues sort that will order the multivalues of the specified

field according to a descending sequence based on the first subvalue in each

multivalued element

Comments: Each sort clause comprises a sort connective followed by a field name. The sort connective can specify an ascending or descending
sort sequence of single or multivalued fields. If you include more than one sort of criteria clause, the processor ranks the clauses in a left to
right, most to least important hierarchical sequence. Always used as the least important sort value, unless explicitly included in the SORT cri-
teria is the record key.

The precise sorting sequence depends on whether a field is left - right justified.

JBase - User Guide - Release R15.000 - Page 502 of 629


JBase - User Guide - Release R15.000 - Page 503 of 629
Default sort order
If you do not specify a sort criteria clause for a sorting command, the report is output in ascending order by record key. Field 9 of the file defin-
ition (pointer) record specifies Left or right justification of the key. The default is a left justified sort.

JBase - User Guide - Release R15.000 - Page 504 of 629


JBase - User Guide - Release R15.000 - Page 505 of 629
Sort Order of Left justified Data
When sorting a left justified field the data is compared one character at a time, left to right. For this reason number two will follow number 11
in an ascending sequence. The number 02 would appear before 11 in an ascending sequence.

The sort connectives for single valued fields sort the record orders according to the value of a field.

The two sort connectives for single value fields are:

BY for an ascending sort

BY-DSND for a descending sort 

If using a single value sort connective with a field that contains multivalues or subvalues, it only uses the first value in the field as the sort key.

JBase - User Guide - Release R15.000 - Page 506 of 629


JBase - User Guide - Release R15.000 - Page 507 of 629
Sorting Multivalued Fields
The sort connectives for multivalued fields sort values within a field.

The two sort connectives for multivalues are: 

BY-EXP for ascending order

BY-EXP-DSND for descending order 

If using a multiple value sort connective with a file, which contains subvalues, it only uses the first subvalue in each multivalue as the sort key.
The treatment of each value is as if it were the only value so that each value occupies a line of output in the report. This effectively “explodes” a
record into multiple records. You can limit the values for sorting and output by including a print limiter with the multivalue sort connectives.

When using a SELECT-type command with BY-EXP the formatting of the records list appears:

record-key]multi value#

Where: multi-value-# is the position of the multivalue within the field. The READNEXT statement in a jBASIC program can use this value.

EXAMPLE 1
SORT SALESORDER WITH S.CODE = “ABC]”ORD.COST => ‘500’ BY S.CODE

ORD.COST

Selects the records in the ORDER file in which the ORD.COST file contains the values of the order and must sort the orders greater than or
equal to 500. The output in the records is in ORD.COST order.

EXAMPLE 2
SORT ORDER WITH ORD.COST = ‘500’ BY ORD.COST BY-DSND ORD.ID

EXAMPLE 3
SORT ORDER BY-EXP ORD.ID

Selects all the records in the Order file and outputs the detail lines in key order within P.CODE order.

JBase - User Guide - Release R15.000 - Page 508 of 629


SORT

Generates a sorted and formatted report of records and fields from a specified file

COMMAND SYNTAX
SORT file-specifier {record-list} {selection-criteria} {sort-criteria} {USING file-specifier} {output-specification} {format-specification}
{(options}

Comments: Unless a different sort order is specified in the sort criteria, the presentation of the records will be in an ascending order based on
the record key.

The data definition records (or the file definition records in the case of keys) determine whether to apply a left or right sort to the data.

If the field is left justified, it compares the data on a character-by-character basis from left to right, using ASCII values.

EXAMPLE:
01
100
21
A
ABC
BA

If the field is right justified and the data is numeric, it performs a numeric comparison and the values ordered by magnitude.

If the field is right justified and the data is alphanumeric, it collates the data into an alphanumeric sequence.

EXAMPLE:
A
01
123
ABCD

If a descending sequence is required, use the BY-DSND modifier in the sort criteria. Use the BY-DSND modifier with a data definition record to
obtain a descending sequence of record keys, which points to field 0 (the key). See “Sort Criteria Clause” earlier for a full explanation of the sort-
ing process.

EXAMPLE 1
SORT ORDER

Sort all the records in the SALES file into key order and use the default data definition records (if found) to format the output.

EXAMPLE 2
SORT ORDER WITH ORD.AMT = “ABC” “DEF” “GHI”

Select the records in the ORDER file in which the ORD.AMT field contains the values ABC, DEF or GHI. Sort the records into key order.

JBase - User Guide - Release R15.000 - Page 509 of 629


EXAMPLE 3
GET-LIST SALES.Q4

SORT ORDER GT “DEF” BY ORD.AMT

Get the implicit list called SALES.Q4 and, using the list, report on the records in the SALES file, which have a key greater than DEF. Sort does
the report by S.CODE.

EXAMPLE 4
SORT ORDER WITH ORD.AMT = “ABC]” OR “[DEF” BY-DSND S.KEY LPTR

Select the records in the SALES file in which the S.CODE field contains values which start with ABC or end with DEF. Sort the report in des-
cending order of S.KEY (a data definition record which points to field 0 - the key) and output the report to the printer

EXAMPLE 5
SORT ORDER BY ORD.ID BREAK-ON ORD.ID “”BL” ORD.AMT TOTAL ORD.COS GRAND-TOTAL “Total” HEADING “Sales Code: “B”
“DL” FOOTING “Page “CPP” LPTR

Sort the ORDER file by ORD.ID. Output the ORD.ID, ORD.AMT and VALUE fields.

Control break on a change in S.CODE and suppress the LINE FEED before the break. Reserve the break value for use in the heading (“B”). Main-
tain a running total of the VALUE field and output it at each control break. Put the word “Total” on the grand-total line.

Set up a heading for each page which comprises the words “Sales Code: “, the sales code (from the break), a date and a LINE FEED. Set up a
footing, which contains the text “Page”, and a page number, centered on the line?

Produce the report on the currently assigned printer.

JBase - User Guide - Release R15.000 - Page 510 of 629


SREFORMAT

SREFORMAT is similar to the SORT Command in that it generates a formatted list of fields, but directs its output to another file or the mag-
netic tape rather than to the terminal or printer.

COMMAND SYNTAX
SREFORMAT file-specifier {record-list} {selection-criteria} {USING file-specifier} {output-specification} {format-specification} {(options}

Prompt: At the prompt supply the destination file: 

File: Enter a file name, or the word “TAPE” for output to a magnetic tape. 

COMMENTS:
Overwrites records that already exist in the destination file; when you reformat one file into another, each record selected becomes a record in
the new file. It uses the first value specified in the output specification clause as the key for the new records. The remaining values in the out-
put specification clause become fields in the new records.

When you reformat a file to tape, it concatenates the values specified in the output specification clause to form one tape record for each selec-
ted record. The record output is either truncated or padded at the end with nulls (X”00”) to obtain a record the same length as specified when
the tape was assigned by the T-ATT Command.

Unless you specify HDR-SUPP or COL-HDR-SUPP, or a C or H option, a tape label containing the file name, tape record length (in hexa-
decimal), it first writes the time, and date to the tape. If specifying a HEADING clause, this will form the data for the tape label.

Record keys are displayed as the records are written to tape unless the ID-SUPP modifier or the “I” option is specified.

Two EOF marks terminate the file on tape.

See the REFORMAT Command for Examples.

JBase - User Guide - Release R15.000 - Page 511 of 629


SSELECT

Generates an implicit list of record keys or specified fields, based on the selection criteria specified

COMMAND SYNTAX
SSELECT file-specifier {record-list} {selection-criteria} {sort-criteria} {output-criteria}

{USING file-specifier} {(options}

SYNTAX ELEMENTS
Options are:

C Display running counters of the number of records selected and records processed. Unless modified by n,
{n} the counter increments after every 500 records processed or the total number of records if less than 500.

N Specifies a number other than 500 by which to increment. For Example, C25 increments the counter after
every 25 records processed.

Comments: Unless you specify a sort criteria clause it sorts the records in key order.

See also the SELECT Command.

If you specify an output-criteria clause, the generated list will comprise the data (field) values defined by the clause, rather than the selected
record keys.

When the Command terminates, it displays the total number of entries in the generated list; the list is  available to the next Command. This is
indicated by the “>” prompt if you are in jSHELL.

If you use the BY-EXP or BY-EXP-DSND connectives on a multivalued field, the list will have the format:

record-key]multivalue#

where multivalue# is the position of the multivalue within the field specified by BY-EXP or BY-EXP-DSND. multivalue# can be accessed by a
READNEXT Var,n statement in a jBASIC program.

EXAMPLE 1
SSELECT ORDER WITH ORD.AMT = ‘100’

23 Records selected

LIST ORDER WITH ORD.QTY > ‘1000’

Select all the records in SALES file with an S.CODE value that starts with ABC. Sort the list into key order. Then, using the list, report on the
records in the SALES file which have a VALUE field greater than 1000.

EXAMPLE 2
SSELECT ORDER WITH ORD.AMT = “ABC]” BY P.CODE

23 Records selected

>SAVE-LIST SALES.ABC

JBase - User Guide - Release R15.000 - Page 512 of 629


Select all the records in ORDER file with an ORD.AMT value that starts with ABC. Sort the list into ORD.AMT order and then save the list as
SALES.ABC.

JBase - User Guide - Release R15.000 - Page 513 of 629


Sublist – V Code

Use the COUNT and LIST commands to access file records which contain sublists, with the COUNT and LIST Commands.. For the commands
and the modifier to function correctly, you must include the V processing code in field 8 of the file definition record. See File Specifiers topic in
the jQL Sentence Construction Chapter for more details.

COMMAND SYNTAX
V;field-no

SYNTAX ELEMENTS
Field No. The number of the field, which contains the sublist

EXAMPLE
Consider the stock file used by a camera factory where each data record can represent either an assembly or a component part. Take as an
Example the record set that defines a simple camera assembly. The data records contain the following data.

Key A1 Key A21

001 CAMERA ASSY 001 LENS ASSY

002 A21]A22]A23 002 A210]A211

003 10 003 15

Key A22 Key A23

001 BODY 001 SHUT ASSY

002 002 A230]A231

003 10 003 11

Key A210 Key A211

001 OPTICS 001 BARREL

002 002

003 19 003 21

Key A230 Key A231

001 IRIS MECH 001 IRIS HOUSNG

002 002

003 13 003 14

JBase - User Guide - Release R15.000 - Page 514 of 629


The key is the part number, field 1 contains the description, field 2 is a multivalued list of components that go to make up the part, and field 3
is the current stock level.

Record A1 represents assembled cameras. It points to the used sub-assemblies (A21, A22 and A23) to make each camera. The sub-assemblies
in turn point to their component parts; A21 points to A210 and A211, A22 does not have any components, and A23 points to A230.

Having established the logical data relationships, we now need to ensure that the system understands that field 2 is a multivalued sublist. We
do this by updating field 8 in the file definition record to read “V;;2”,
like this:

STOCK
001 D
002
003
004
005
006
007
008 V2
009 L
010 10

To create three data definition records in the dictionary of STOCK - one for each field, use the following titles DESC, COMPONENTS, and
QTY.

The final step is to issue a COUNT or LIST Command which uses the WITHIN modifier:

LIST WITHIN STOCK “A1” DESC COMPONENTS QTY

PAGE 1 Time Date

LEVEL STOCK Description.... Components Qty

1 A1 CAMERA ASSY A21 10


A22
A23
2 A21 LENS ASSY A210 15
A211
3 A210 OPTICS 19
3 A211 BARREL 21
2 A22 BODY 10
2 A23 SHUTTER ASSY A230 11
A231
3 A230 IRIS MECH 13
3 A231 FILM MECH 14

8 RECORDS LISTED

JBase - User Guide - Release R15.000 - Page 515 of 629


Substring Function

The substring function [start-char-no, len] extracts the specified number of characters from a string, starting at a specified character.

SYNTAX ELEMENTS
Start-char no   An expression that evaluates to the position of the first character of the substring.

Len                 An expression that evaluates to the number of characters required in the substring.           

Use - len (minus prefix) to specify the end of the substring. For Example, [1, -2] will return all but the last character and [-3, 3] will return the
last three characters.

EXAMPLE 1
A;N(S.CODE)[“2”, “3”]

Extracts a sub-string from the S.CODE field, starting at character position 2 and continuing for 3 characters

EXAMPLE 2
A;N(S.CODE)[2, N(SUB.CODE.LEN)]

Extracts a sub-string from the S.CODE field, starting at the character position defined by field 2 and continuing for the number of characters
defined by SUB.CODE.LEN

Format Codes: Specifies a format code to be applied to the result of the A code or an operand.

COMMAND SYNTAX
a- code {] format- code...}
a-operand(format-code{]format-code}...)

SYNTAX ELEMENTS
A code         A complete A Code expression.

A operand     One of the A Code operands.

format code   is one of the codes described later G(roup), D(ate) or M(ask).

] represents a must use value mark to separate each format code.

Comments: You can format the result of the complete "A" code operation by following the expression with a value mark and then the required
format code(s). (This is a standard feature of the data definition records.)

Format codes can also be included within "A" code expressions; enclosed in parentheses, using a value mark for separation if using more than
one format code. All format codes will convert values from an internal format to an output format.

EXAMPLE 1
A;N(COST)(MD2]G0.1) * ...

JBase - User Guide - Release R15.000 - Page 516 of 629


Shows two format codes applied within an expression. Obtains the COST value and applies an MD2 format code. Then applies a group extract
to acquire the integer portion of the formatted value. You can now use the integer portion in the rest of the calculation. Could also have been
achieved like this:

A;I(N(COST)(MD2)) * ...

EXAMPLE 2
A;N(COST) * N(QTY)]MD2

Shows the MD2 format code applied outside the A code expression. Multiplies COST by QTY and the result formatted by the MD2 format
code.

JBase - User Guide - Release R15.000 - Page 517 of 629


Summary of Operands

Operands, which you can use in "A" code expressions include:

l FMCs (field numbers)


l field names
l literals
l operands that return system parameters,

Special Functions
You can format any operand by following it with one or more format codes enclosed in parentheses, and separated by value marks, (ctrl ]):

operand(format-code{]format-code}...)

For more information, see Format Codes.

JBase - User Guide - Release R15.000 - Page 518 of 629


Synonyms

Ampersand (&) is a synonym for AND

Exclamation point is a synonym for OR

Value String

JBase - User Guide - Release R15.000 - Page 519 of 629


T Conversion

The T code extracts a character substring from a field value.

COMMAND SYNTAX
T{m,}n

SYNTAX ELEMENTS
m             specifies the starting column number.

n              The number of characters for extraction.

Comments: If specifying m, the content of field 9 of the data definition record has no effect - it counts and extracts characters from left to right,
for n characters.

If m is not specified, the content of field 9 of the data definition record will control whether n characters are extracted from the left or the right-
hand end of the value. If field 9 does not contain an R, extracts the first n characters from the value. If field 9 does contain an R (right justify),
extracts the last n characters from the value.

Input Conversion: does not invert. It simply applies the text extraction to the input data.

EXAMPLES

CODE Source Value Field9 Result

T3,4 ABCDEFG L CDEF

T3,4 ABCDEFG R CDEF

T2 ABCDEFG L AB

T3 ABCDEFG R EFG

T3 ABCDEFG T ABC

JBase - User Guide - Release R15.000 - Page 520 of 629


T File Conversion

Tfile codes provide a method for retrieving data fields from any other file to which the user has access.

COMMAND SYNTAX
T[*|DICT]file-specifier;c{n};{i-fmc};{o-fmc}

SYNTAX ELEMENTS

* or DICT Indicates the use of the dictionary of the specified file, rather than the data section.

file- spe- identifies the reference file by name in the format file-name{,data-section-name}.
cifier

c- specifies a translation code, which can be any one of the following:

C If reference record does not exist or the specified FMC is null, output the value unchanged.

I Inputs verify: Functions as a C code for output and as a V code for input.

O Outputs verify: Functions as a C code for input and as a V code for output.

V Reference record must exist and the specified FMC must contain a translatable value. If the

record does not exist or the FMC contains a null, an error message will be output.

X If reference record does not exist or the specified FMC is null, return a null

n specifies a value mark count to return one specific value from a multivalued field.

Returns all values if omitted.

i fmc the field number for input translation. which if omitted or contains a null value, no input trans-
lation takes place.

o fmc is the field number for output translation. If the value is null, no output translation takes place.

Comments: Uses the current data value as the record key for searching the specified reference file.

Returns a data field or a single value from a data field, from the record

Use Tfile codes in fields 7 or 8 of the data definition record. Use field 8 if translation of a multivalued field or comparisons and sorts are
required.

If you apply selection criteria, you can either use field 8, or field 7 and set up special records in the reference file to perform any input trans-
lation you require.

The special records in the reference file have as record keys values that the field subject to translation may be compared with in a jQL sentence.
Field i-fmc within these records contains the translate value that will be compared to values on file. Typically, values in a jQL sentence are out-
put values, so that the special input translation records are effectively the inverse of the output translation records.

Tfile codes can be “embedded” in other conversion codes but you must still follow the syntactical conventions of the “host” code. For Example,
if you include a Tfile code in an F code conversion, enclose the Tfile code in parentheses.

Output conversion is valid. The Tfile code has a parameter (o-fmc) that specifies the field in the translation record to use for output con-
version.

JBase - User Guide - Release R15.000 - Page 521 of 629


Input conversion is valid. The Tfile code has a parameter (i-fmc) that specifies the field in the translation record to use for input conversion.

EXAMPLE 1
TSALES;X;;2

Using this Tfile code in field 8 of a data definition record, which also has a 0 in field 2, will cause the key of the current record to be used as the
key when accessing the reference file SALES; returns null if the record cannot be found; returns the value of field 2 if the record is found.

EXAMPLE 2
TSALES;C;;2

Using this Tfile code in field 8 of a data definition record, which also has a 6 in field 2, will cause the content of field 6 from the current record
to be used as the key when accessing the reference file SALES. If the record cannot be found, or if found, field two is null, returns the content
of field 6 of the current record. If the record is found, and field 2 contains a value, it returns that value.

EXAMPLE 3
A;3(TSALES;X;;2)

Using this embedded Tfile code in field 8 of a data definition record will cause the use of field 3 of the current record as the key when accessing
field 2 of the reference file SALES. Returns null if the record cannot be found; returns the value of field 2 if the record is found.

JBase - User Guide - Release R15.000 - Page 522 of 629


The Stack

F codes work with a pushdown stack.

NOTE: All possible F correlative operators push values onto the stack, perform arithmetic and other operations on the stack entries, and pop
values off the stack.

The term “push” is used to indicate the placing of an entry (a value) onto the top of the stack so that existing entries are pushed down one
level. “Pop” means to remove an entry from the top of the stack so that existing entries pop up by one level. Arithmetic functions typically
begin by pushing two or more entries onto the stack. Each operation then pops the top two entries, and pushes the result back onto the top of
the stack. After any operation is complete, the result will always be contained in entry 1.

JBase - User Guide - Release R15.000 - Page 523 of 629


Throwaway Connectives

Throwaway connectives are keywords, which make queries more readable. You can use in any query to make the sentence read more like Eng-
lish and can be used anywhere in a sentence as throwaway connectives do not affect the query.

The following query uses the words THE, FOR, and FILE without affecting the meaning of the command: 

LIST THE ORDER BY ORD.UNIT.PRICE FOR THE ORD.STATUS

The throwaway keywords are:

Throwaway

A ARE FILE

AFOR AREINVISIBLE FILEOF

FORPRINT INIVISIBLETHAN OF THE

PRINT THAN THE

JBase - User Guide - Release R15.000 - Page 524 of 629


TimeStamp “W{Dx}{Tx}”

In addition, to provide for timestamp functionality included is a suite of conversions including A, F and I types. This is to generate a
timestamp, displayed for date and/or time in short, long, and full formats. These conversions also support non-Gregorian locales. The meaning
of the components of the conversion is as follows:

W Is a new conversion code so not to clash with existing conversions

D  Date

T- Time

x Format option: S = Short, M = Medium, L = Long, F = Full

“WDS” or “WTS” SHORT is completely numeric.12/13/52 or 3:30pm

“WDM” MEDIUM is longer. Jan 12, 1952

“WDL” or “WTL” LONG is longer.

January 12, 1952 or 3:30:32pm

“WDF” or “WTF” FULL is specified completely.

JBase - User Guide - Release R15.000 - Page 525 of 629


Total Connectives

The TOTAL connective specifies that a running total of the field be maintained and to output the total at each control break and at the end of
the report. Also, use TOTAL in conjunction with the BREAK-ON connective to display intermediate totals at the control breaks.

Use the GRAND-TOTAL modifier in the format specification clause to display any specified text on the last total line.

JBase - User Guide - Release R15.000 - Page 526 of 629


Types of Item List

An item list takes one of three forms:

1. An explicit item-id list


2. An implicit item-id list
3. An item-id selection clause

You can combine Item-id selection with implicit but not with explicit item-id lists. You can combine every type of list with selection criteria
based on attribute values.

JBase - User Guide - Release R15.000 - Page 527 of 629


U Conversion

Use the U code to execute a system subroutine to process values.

COMMAND SYNTAX
Uxxxx

SYNTAX ELEMENTS
XXXX    The hexadecimal identity of the routine

Comments: jBASE user exits are customized routines specially produced to perform extraordinary

processing.

Input Conversion: Routine dependent

JBase - User Guide - Release R15.000 - Page 528 of 629


Unicode

Unicode is a single-coded character set providing a repertoire for all the languages of the world. Its first version used 16-bit numbers, which
allowed encoding for 65,536 characters; further development allowed a repertoire of more than one million characters, requiring 21 bits. Higher
bits have been declared unusable to ensure interoperability between UTF encoding schemes; UTF16 cannot encode any code points above this
limit. The handling of values above 16 bits is by two 16-bit codes.

l The first Unicode version used 16 bits, which allowed for encoding 65,536 characters.
l Further extended to 32 bits, although restricted to 21 bits to ensure interoperability between UTF encoding schemes.
l Unicode provides a repertoire of more than one million characters.

The 16-bit subset of UCS (Universe Character Set) is known as the Basic Multilingual Plan (BMP) or Plane 0.

Unicode provides a unique number for every character, on every platform, for every program, no matter what the language. Standards such as
XML, Java, ECMAScript (JavaScript), LDAP, CORBA 3.0, WML, etc., requires Unicode and is the official way to implement ISO/IEC 10646;
supported in many operating systems, all modern browsers, and many other products.

Incorporating Unicode into client-server or multi-tiered applications and websites can offer significant cost savings over the use of legacy char-
acter sets. Unicode enables a single software product or a single website to be targeted across multiple platforms, languages and countries
without re-engineering, and allows data to be transported through many different systems without corruption.

Unicode Combining/Composite Characters


Some code points have been assigned to combining characters. A combining character is not a full character by itself; rather, it is an accent or
other diacritical mark added to the previous character. This makes it possible to add an accent or other on any character. This capability is par-
ticularly important for scientific notation in mathematics.

Unicode Expanding and Contracting Characters


Some languages treat certain single characters as two separate characters for collating purposes (expanding), whereas some languages also treat
two characters as a single character when collating (contracting).

Contracting In Spanish sort order, ‘ch’ is considered a single letter. All words that begin with ‘ch’ sort after all other words beginning with ‘c’

Expanding In German, ä is equivalent to ‘ae,’ such that words beginning with ä sort between words starting with ‘ad’ and ‘af’.

Unicode Normalization
Normalization is the removal of ambiguities caused by precomposed and compatibility characters. There are four different forms of nor-
malization.

Form D................................. Split up (decompose) precomposed characters into combining sequences where possible.

Form C................................. Use precomposed instead of combining sequences where possible.

Form NFKD ........................ Like D but avoid use of compatibility characters (e.g., use ‘fi’ instead of U+FB01 LATIN SMALL LIGATURE FI).

Form NFKC......................... Like C but avoid use of compatibility characters.

Below is an example of Precomposed vs. Decomposed characters.

Precomposed     ü = U+00FC

Decomposed ü  = U+0075 + U+0308

Note: that UTF-8 encoding requires the use of precomposed characters wherever possible.

JBase - User Guide - Release R15.000 - Page 529 of 629


Unicode Universal Character Set and UTF-8
The Universal Character Set, UCS assigns each character not only a code number, but also an official name. A U+ precedes a hexadecimal num-
ber representing a Unicode Code Point or (e.g., U+0041 ‘Latin Capital Letter A’).

UTF-8 can represent all possible Unicode code points by byte sequences, which in turn represent different code points. The sequence used for
any given character depends on the Unicode number, which represents that particular character. The Universal Character Set has the following
properties:

l UCS U+0000 to U+007F is identical to US-ASCII (IISO 646 IRV).


l UCS U+0000 to U+00FF are identical to ISO-8859-1 (Latin-1)
l UCS U+E000 to U+F8FF is reserved for private use.

UTF-8 encoding is a Unicode Translation Format of Unicode. Before UTF-8 emerged, users all over the world had to use various language-spe-
cific extensions of ASCII. This made the exchange of files difficult, and application software had to consider small differences between these
encodings. Support for these encodings was usually incomplete and unsatisfactory, because the application developers rarely used all these
encodings themselves.

Unicode UTF-8 Properties


UTF-8 encoding avoids several problems inherent in other encoding systems:

l Files and strings that contain only 7-bit ASCII characters have identical encoding under ASCII and UTF-8.
l ASCII bytes 0x00-0x7F cannot appear as part of any other character.
l Allows easy resynchronization and makes the encoding stateless and guards against the possibility of missing bytes.
l Can encode all possible 231 UCS codes.
l UTF-8 encoded characters may theoretically be up to six bytes long, however 16-bit BMP characters are only up to three bytes long.
l The sorting order of Bigendian UCS-4 byte strings is preserved.
l It never uses the byte 0xFE and 0xFF in the UTF-8 encoding.
l UTF-8 is also much more compact than other encoding options, because characters in the range 0x00-0x7f still only use one byte.
l Use only the shortest possible multi byte sequence that can represent the code point of the character.
l In multi byte sequences, the number of leading one bit in the first byte is identical to the number of bytes in the entire sequence.
l Unicode represents a unique character by a unique 32-bit integer. Hence using UTF-8 encoding avoids problems, which would arise if
using 16 or 32 bit character byte streams, as the normal C string termination byte is a zero, thus byte streams could become pre-
maturely truncated.

JBase - User Guide - Release R15.000 - Page 530 of 629


User Subroutines

You can add additional functionality by calling user written basic subroutines, which you should compile and catalog and add the library loc-
ation to the library path in the JBCOBECTLIST environment variables.

The first parameter of the called routine is the result parameter; used as the evaluated value of the subroutine e.g.

FRED
001 SUBROUTINE FRED (Result, Param1)
002 IF Param1 > 100 THEN Result = 1 ELSE Result = 0
003 RETURN

One or other of the following formats can call subroutines from an I-TYPE.

FRED(param1 {,param2_}) or SUBR(“FRED”,param1 {,param2_})

Conversion
The Conversion attribute provides support for normal queries output conversions. E.g. D2, MT, F;, TFile etc

Header
This attribute specifies the column heading text for display.

Format
The format attribute can be specified as follows:

Length {Padding} Justification { Conversion } { Mask }

Where:

Length The display column length

Padding Any character except L,R,U or T. default space

Justification  L Left, R Right, T Text, U Unlimited

n      Number of digits after decimal point.

$      Precede with current currency sign.

,       Insert thousandths separator every third digit.

Z      Suppress leading zeroes.

Mask Output pattern. e.g. ##-###-##

NOTE: Spurious trailing spaces can give invalid conversion errors.

JBase - User Guide - Release R15.000 - Page 531 of 629


Using Clause

The using clause specifies a dictionary file, which is the source of data definition records.

SYNTAX
USING {DICT} filename {,data-section-name}

SYNTAX ELEMENTS
USING specifies the use of the named file as the dictionary for the data file.

DICT specifies that the dictionary of filenames be used

filename names a file. If the DICT modifier is not specified, it will use the data section of the file.
data-section-name specifies a secondary data section of the file with a name different from the dictionary; it must follow filename, separated by
a comma but no space.

Comments: There can be only one USING clause in a jQL sentence.

One main advantage of the using clause is that you can share a dictionary between several files where for example there are common data defin-
ition records.

EXAMPLE
SORT ORDER USING DICT ORDER

The data definition records in the dictionary of the file ORDER (DICT ORDER) assess File ORDER

JBase - User Guide - Release R15.000 - Page 532 of 629


Using Report Qualifier Keywords

Report qualifiers provide a variety of ways to control and refine the overall format of a report. COL-HDG, ID-SUP, DET-SUP, LPTR, SAMPLE,
and SAMPLED are report qualifiers you saw in previous examples. The following list summarizes the most commonly used report qualifiers:

Keyword Synonym Description

COL-HDR-SUPP COL.HDR.SUPP Suppresses the default report and column headings.

COL-SPCS COL.SPCS Changes the default spacing between columns.

COL-SPACES COL.SPACES Specifies the spacing between the columns of a report

COL-SUP COL.SUP Suppresses the column heading.

COUNT-SUPP  COUNT.SUPP Suppresses the count displayed at the bottom of a report.

DBL-SPC  DBL.SPC Double-spaces the report.

DET-SUPP DET.SUP Displays only the breakpoint lines.

DET-SUPP  DET.SUPP Use with BREAK.ON.

FOOTING FOOTER Sets the report footing.

GRAND-TOTAL GRAND.TOTAL Sets the text for a grand total line.

HDR-SUP  HDR-SUPP, Suppresses the default report heading.


SUPP

HEADING HEADER Uses the report header you specify in the query rather than the
default heading.

HEADING HEADER Displays the default heading.


DEFAULT DEFAULT

ONLY ID-ONLY Displays record IDs only.

ID-SUP ID.SUPP Suppresses the display of record

LPTR (P Sends the output to the printer.

NOPAGE (N Specifies that the report is automatically scrolled on the terminal

SAMPLE FIRST Displays the first n records

SAMPLED DISPLAYS even nth record

VERTICALLY VERT Displays the report in vertical format with one field on each line.

B Functions only if a BREAK-ON modifier with a B option is also included in the sentence. You can use the
B option in either the header or footer. When the B Option is in the HEADING the value of the first
BREAK-ON field on the page replaces the B in the header. When the B is in the FOOTING, the last
BREAK-ON value on the page replaces the B in the footer.

C Centralizes the heading or footing text and centres the text according to the predefined number of the
{n} columns specified for the printer or terminal. To change the centering of the text specify the number of
columns (n) for the heading line on which to base the center. For example: ‘C80’ positions the text
centered at character position 40. You should allow the printer or terminal set-up to determine the cen-
tering.

JBase - User Guide - Release R15.000 - Page 533 of 629


D Inserts the current date using the format: dd mmm yyyy.

F Inserts the file name

I Inserts the current record key. The last record key listed on the page is inserted in the footing; the first
key on the page is inserted in the heading

L Specifies that a new line is to start where the L appears

N Specifies suppression of automatic paging.

P Inserts the current page number right justified, expanding to the right as the number increases.

PP Inserts the current page number right justified in a field of four spaces

T Inserts the current system time and date in the format: hh:mm:ss dd mmm yyyy

JBase - User Guide - Release R15.000 - Page 534 of 629


Value Strings

Value strings are character strings enclosed in delimiters (usually single quotes within item-id-selection criteria and double quotes within ordin-
ary selection criteria); also used to compare against character strings in the file. The value string cannot contain the character by which it is
delimited. For example: if the value string is enclosed in single quotes, it may contain double quotes, but not single quotes. Otherwise, the
value string can contain any printable character, excluding RETURN, LINE FEED, and system delimiters. The simplest value string is a char-
acter string that has precisely those characters for testing (for example. ‘Johansen’) however a value string can also include the following special
characters:

Left ignore ([) at the beginning of the string to indicate that the item-id may start with any characters (for example,’[son’)

Right ignore (]) at the end to indicate that the item-id may end with any characters (for example, Johan]’)

Wild cards(^) anywhere within the string, each wild card matching one character of any value (for example, ‘Joh^ns^n).

EXAMPLE
The following sentence lists CUSTOMER information with CUSTOMER numbers  “40823” or “40825”. Note: the equal sign makes these val-
ues strings rather than item-ids. Hence, without an implicit item list, the processor must search the entire file, comparing all items-ids against
these two value strings; thus it would be better to omit the equal sign as shown in the previous example, to avoid this; 

LIST CUSTOMER = ‘40823’ ‘40825’

JBase - User Guide - Release R15.000 - Page 535 of 629


Wild Card Examples

The following sentence list information about all the rooms with numbers that begin with three, end with five, and have an intervening char-
acter of any value

LIST CUSTOMER = ‘3^5’

The following sentence does not list any CUSTOMER because there is no relational operator, the string 3^5 is treated as an item-id.

LIST CUSTOMER ‘3^5’

JBase - User Guide - Release R15.000 - Page 536 of 629


Appendix

JBase - User Guide - Release R15.000 - Page 537 of 629


SQL / jQL constants

Constant Value Used Notes

JQLOPT_USE_SELECT 1 Yes Used to set _useSelectList, 


this as a switch for various internal functions

JQLOPT_FETCH_ALL_VALUES 2 No

JQLOPT_USE_SQLSELECT 4 Yes Used to say that this is the SELECT function…

JQLOPT_LIMIT_WHERE 8 Yes Sets limitDisplayWithWhere, also assocated


with
env var JQL_LIMIT_WHERE

JQLOPT_DONT_LIMIT 16 Yes Sets dontLimit, oppisite of above, (


Assocated with env var JQL_DONT_LIMMIT
)

JQLOPT_DONT_MAKE_ROWS 32 Yes Sets dontMakeRows,


( see env var JQL_DONT_MAKE_ROWS ),
should force SQL to not split up all MV's

JQLOPT_TRANSLATE_DB2 64 Yes Sets translateDecode, Different syntax

JQLOPT_TRANSLATE_SQL_SERVER 128 Yes See TRANSLATE_DB"

JQLOPT_SYSTEM_QUERY 256 Yes // Must be used with JQLOPT_USE_


SQLSELECT and refers
to a prop. Below

JQLOPT_FORCE_SELECT 512 Yes // switch on trigers in no active select list (if file
has triggers)

JQLOPT_USE_SQLDELETE 1024 Yes // Delete,  supports clear file, where but no sub
queries

JQLOPT_USE_SQLINSERT 2048 Yes // Insert,  add new data

JQLOPT_USE_SQLUPDATE 4096 Yes // Update, change existing data

JQLOPT_USE_SQLCREATETABLE 8192 Yes // Simple create table command

JQLOPT_USE_SQLDROPTABLE 16384 Yes // drop table command

JQLOPT_USE_SQLBEGINTRANS 32768 Yes // BEGIN TRANSACTION

JQLOPT_USE_SQLCOMMITTRANS 65536 Yes // COMMIT TRANSACTION

JQLOPT_USE_SQLROLLBACKTRANS 131072 Yes // ROLLBACK TRANSACTION

JQLOPT_USE_SQLSAVETRANS 262144 Yes // SAVE TRANSACTION

JQLOPT_USE_SQLPREPARE 524288 Yes // Ran via SQL PREPARE/BIND,

JQLOPT_USE_SQL 1047556 Yes // We are running a command as jSQL

FIRST_STMT_PROPERTY 1000 Yes Location in the array of the first item,

STMT_PROPERTY_HEADING 1000 Yes Location in property array of JQL Display items

STMT_PROPERTY_FOOTING 1001 Yes Location in property array of JQL Display items

JBase - User Guide - Release R15.000 - Page 538 of 629


STMT_PROPERTY_GRAND_TOTAL 1003 Yes Location in property array of JQL Display items

STMT_PROPERTY_LPTR 1004 Yes Location in property array of JQL Display items

STMT_PROPERTY_COL_HDR_SUPP 1005 Yes Location in property array of JQL Display items

STMT_PROPERTY_COL_SPACES 1006 Yes Location in property array of JQL Display items

STMT_PROPERTY_COL_SUPP 1007 Yes Location in property array of JQL Display items

STMT_PROPERTY_COUNT_SUPP 1008 Yes Location in property array of JQL Display items

STMT_PROPERTY_EXECUTE_COUNT 1009 Yes Location in property array of JQL Display items

STMT_PROPERTY_DBL_SPACE 1010 Yes Location in property array of JQL Display items

STMT_PROPERTY_DET_SUPP 1011 Yes Location in property array of JQL Display items

STMT_PROPERTY_HDR_SUPP 1012 Yes Location in property array of JQL Display items

STMT_PROPERTY_ID_SUPP 1013 Yes Location in property array of JQL Display items

STMT_PROPERTY_MARGIN 1014 Yes Location in property array of JQL Display items

STMT_PROPERTY_NOPAGE 1015 Yes Location in property array of JQL Display items

STMT_PROPERTY_NOSPLIT 1016 Yes Location in property array of JQL Display items

STMT_PROPERTY_ONLY 1017 Yes Location in property array of JQL Display items

STMT_PROPERTY_OUTCOLS 1018 Yes Location in property array of JQL Display items

STMT_PROPERTY_VERT 1019 Yes Location in property array of JQL Display items

STMT_PROPERTY_TOTAL_WIDTH 1020 Yes Location in property array of JQL Display items

STMT_PROPERTY_FILE_NAME 1021 Yes Location in property array of JQL Display items

STMT_PROPERTY_BINARY_MODE 1022 Yes Location in property array of JQL Display items

STMT_PROPERTY_ASCII 1023 Yes Location in property array of JQL Display items

STMT_PROPERTY_EBCDIC 1024 Yes Location in property array of JQL Display items

STMT_PROPERTY_TAPELABEL 1025 Yes Location in property array of JQL Display items

STMT_PROPERTY_WITHIN 1026 Yes Location in property array of JQL Display items

STMT_PROPERTY_UNIQUE 1027 Yes Location in property array of JQL Display items

STMT_PROPERTY_NONULLS 1028 Yes Location in property array of JQL Display items

STMT_PROPERTY_APPLY_OCONV 1029 Yes Location in property array of JQL Display items

STMT_PROPERTY_APPLY_FORMAT 1030 Yes Location in property array of JQL Display items

STMT_PROPERTY_SYSTEM_QUERY_ 1031 Yes Location in property array of JQL Display items


TABLE_TYPES

STMT_PROPERTY_SYSTEM_QUERY_ 1032 Yes Location in property array of JQL Display items


SCHEMAS

STMT_PROPERTY_SYSTEM_QUERY_ 1033 Yes Location in property array of JQL Display items


TABLES

JBase - User Guide - Release R15.000 - Page 539 of 629


STMT_PROPERTY_SYSTEM_QUERY_ 1034 Yes Location in property array of JQL Display items
COLUMNS

LAST_STMT_PROPERTY 1034 Yes Used to check we don’t overflow passed the


last lement in the properties array….

FIRST_COL_PROPERTY 100 No Equivalent to first statement prop…

COL_PROPERTY_HEADING 100 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_FORMATTED_ 101 Yes Used to say what this element is in out-


HEADING column.cpp

COL_PROPERTY_WIDTH 102 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_HEADING_WIDTH 103 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_VALUETYPE 104 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_MVGROUPNAME 105 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_SVGROUPNAME 106 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_DICT_IID 107 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_UPDATEABLE 108 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_AGGREGATE 109 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_AGGREGATE_ 110 Yes Used to say what this element is in out-


SEPARATOR column.cpp

COL_PROPERTY_VISIBLE 111 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_JUSTIFATION 112 Yes Used to say what this element is in out-


column.cpp

LAST_COL_PROPERTY 111 Yes Used to check we don’t overflow passed the


last element in the properties array….

BREAK_OPTIONS_B 1 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_D 2 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_L 4 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_N 8 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

JBase - User Guide - Release R15.000 - Page 540 of 629


BREAK_OPTIONS_O 16 Yes Used with breakDefnArray, sets break on types,
( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_P 32 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_R 64 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_T 128 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_U 256 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_V 1024 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_LR 2048 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

JBase - User Guide - Release R15.000 - Page 541 of 629


Appendix

JBase - User Guide - Release R15.000 - Page 542 of 629


SQL / jQL constants

Constant Value Used Notes

JQLOPT_USE_SELECT 1 Yes Used to set _useSelectList, 


this as a switch for various internal functions

JQLOPT_FETCH_ALL_VALUES 2 No

JQLOPT_USE_SQLSELECT 4 Yes Used to say that this is the SELECT function…

JQLOPT_LIMIT_WHERE 8 Yes Sets limitDisplayWithWhere, also assocated


with
env var JQL_LIMIT_WHERE

JQLOPT_DONT_LIMIT 16 Yes Sets dontLimit, oppisite of above, (


Assocated with env var JQL_DONT_LIMMIT
)

JQLOPT_DONT_MAKE_ROWS 32 Yes Sets dontMakeRows,


( see env var JQL_DONT_MAKE_ROWS ),
should force SQL to not split up all MV's

JQLOPT_TRANSLATE_DB2 64 Yes Sets translateDecode, Different syntax

JQLOPT_TRANSLATE_SQL_SERVER 128 Yes See TRANSLATE_DB"

JQLOPT_SYSTEM_QUERY 256 Yes // Must be used with JQLOPT_USE_


SQLSELECT and refers
to a prop. Below

JQLOPT_FORCE_SELECT 512 Yes // switch on trigers in no active select list (if file
has triggers)

JQLOPT_USE_SQLDELETE 1024 Yes // Delete,  supports clear file, where but no sub
queries

JQLOPT_USE_SQLINSERT 2048 Yes // Insert,  add new data

JQLOPT_USE_SQLUPDATE 4096 Yes // Update, change existing data

JQLOPT_USE_SQLCREATETABLE 8192 Yes // Simple create table command

JQLOPT_USE_SQLDROPTABLE 16384 Yes // drop table command

JQLOPT_USE_SQLBEGINTRANS 32768 Yes // BEGIN TRANSACTION

JQLOPT_USE_SQLCOMMITTRANS 65536 Yes // COMMIT TRANSACTION

JQLOPT_USE_SQLROLLBACKTRANS 131072 Yes // ROLLBACK TRANSACTION

JQLOPT_USE_SQLSAVETRANS 262144 Yes // SAVE TRANSACTION

JQLOPT_USE_SQLPREPARE 524288 Yes // Ran via SQL PREPARE/BIND,

JQLOPT_USE_SQL 1047556 Yes // We are running a command as jSQL

FIRST_STMT_PROPERTY 1000 Yes Location in the array of the first item,

STMT_PROPERTY_HEADING 1000 Yes Location in property array of JQL Display items

STMT_PROPERTY_FOOTING 1001 Yes Location in property array of JQL Display items

JBase - User Guide - Release R15.000 - Page 543 of 629


STMT_PROPERTY_GRAND_TOTAL 1003 Yes Location in property array of JQL Display items

STMT_PROPERTY_LPTR 1004 Yes Location in property array of JQL Display items

STMT_PROPERTY_COL_HDR_SUPP 1005 Yes Location in property array of JQL Display items

STMT_PROPERTY_COL_SPACES 1006 Yes Location in property array of JQL Display items

STMT_PROPERTY_COL_SUPP 1007 Yes Location in property array of JQL Display items

STMT_PROPERTY_COUNT_SUPP 1008 Yes Location in property array of JQL Display items

STMT_PROPERTY_EXECUTE_COUNT 1009 Yes Location in property array of JQL Display items

STMT_PROPERTY_DBL_SPACE 1010 Yes Location in property array of JQL Display items

STMT_PROPERTY_DET_SUPP 1011 Yes Location in property array of JQL Display items

STMT_PROPERTY_HDR_SUPP 1012 Yes Location in property array of JQL Display items

STMT_PROPERTY_ID_SUPP 1013 Yes Location in property array of JQL Display items

STMT_PROPERTY_MARGIN 1014 Yes Location in property array of JQL Display items

STMT_PROPERTY_NOPAGE 1015 Yes Location in property array of JQL Display items

STMT_PROPERTY_NOSPLIT 1016 Yes Location in property array of JQL Display items

STMT_PROPERTY_ONLY 1017 Yes Location in property array of JQL Display items

STMT_PROPERTY_OUTCOLS 1018 Yes Location in property array of JQL Display items

STMT_PROPERTY_VERT 1019 Yes Location in property array of JQL Display items

STMT_PROPERTY_TOTAL_WIDTH 1020 Yes Location in property array of JQL Display items

STMT_PROPERTY_FILE_NAME 1021 Yes Location in property array of JQL Display items

STMT_PROPERTY_BINARY_MODE 1022 Yes Location in property array of JQL Display items

STMT_PROPERTY_ASCII 1023 Yes Location in property array of JQL Display items

STMT_PROPERTY_EBCDIC 1024 Yes Location in property array of JQL Display items

STMT_PROPERTY_TAPELABEL 1025 Yes Location in property array of JQL Display items

STMT_PROPERTY_WITHIN 1026 Yes Location in property array of JQL Display items

STMT_PROPERTY_UNIQUE 1027 Yes Location in property array of JQL Display items

STMT_PROPERTY_NONULLS 1028 Yes Location in property array of JQL Display items

STMT_PROPERTY_APPLY_OCONV 1029 Yes Location in property array of JQL Display items

STMT_PROPERTY_APPLY_FORMAT 1030 Yes Location in property array of JQL Display items

STMT_PROPERTY_SYSTEM_QUERY_ 1031 Yes Location in property array of JQL Display items


TABLE_TYPES

STMT_PROPERTY_SYSTEM_QUERY_ 1032 Yes Location in property array of JQL Display items


SCHEMAS

STMT_PROPERTY_SYSTEM_QUERY_ 1033 Yes Location in property array of JQL Display items


TABLES

JBase - User Guide - Release R15.000 - Page 544 of 629


STMT_PROPERTY_SYSTEM_QUERY_ 1034 Yes Location in property array of JQL Display items
COLUMNS

LAST_STMT_PROPERTY 1034 Yes Used to check we don’t overflow passed the


last lement in the properties array….

FIRST_COL_PROPERTY 100 No Equivalent to first statement prop…

COL_PROPERTY_HEADING 100 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_FORMATTED_ 101 Yes Used to say what this element is in out-


HEADING column.cpp

COL_PROPERTY_WIDTH 102 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_HEADING_WIDTH 103 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_VALUETYPE 104 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_MVGROUPNAME 105 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_SVGROUPNAME 106 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_DICT_IID 107 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_UPDATEABLE 108 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_AGGREGATE 109 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_AGGREGATE_ 110 Yes Used to say what this element is in out-


SEPARATOR column.cpp

COL_PROPERTY_VISIBLE 111 Yes Used to say what this element is in out-


column.cpp

COL_PROPERTY_JUSTIFATION 112 Yes Used to say what this element is in out-


column.cpp

LAST_COL_PROPERTY 111 Yes Used to check we don’t overflow passed the


last element in the properties array….

BREAK_OPTIONS_B 1 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_D 2 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_L 4 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_N 8 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

JBase - User Guide - Release R15.000 - Page 545 of 629


BREAK_OPTIONS_O 16 Yes Used with breakDefnArray, sets break on types,
( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_P 32 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_R 64 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_T 128 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_U 256 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_V 1024 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

BREAK_OPTIONS_LR 2048 Yes Used with breakDefnArray, sets break on types,


( MIN/MAX/TOTAL etc… )

JBase - User Guide - Release R15.000 - Page 546 of 629


Associations

A common question is how data is associated if one column or more columns are multi-valued and the rest are not. Take this example where
both NUMBEERSPERBRAND and NUMCALSPERBRAND are multi-valued:

jsh -->SQLSELECT a.LASTNAME, a.NUMBEERSPERBRAND, a.NUMCALSPERBRAND FROM CUSTOMERS a WHERE a.FIRSTNAME = 'JIM'

LASTNAME NUMBEERSPERBRAND NUMCALSPERBRAND

-------------------- ------------------------------ ------------------------------

STALLED 10 105

STALLED 12 100

JAMES 6 150

JAMES 12 100

SUE 4 200

SUE 12 100

Selected 6 rows.

The data on disk for JIM STALLED is shown below. Attribute 5 (NUMBEERSPERBRAND) and Attribute 6 (NUMCALSPERBRAND) are both
multi-valued. Yet, only two rows are returned from the SQL query above.  Why?  Attribute 5 and Attribute 6 are associated in the dictionary.

0001 JIM

0002 STALLED

0003 41

0004 2

0005 10]12

0006 105]100

0007 OLY]BUD

0008 35 JIM IDLE RD.

0009 PORTLAND

0010 97210

0011 US

0012 FIDO\JACK

Attribute 7 (BRANDS) in the dictionary (CUSTOMERS]D) is the controlling attribute for NUMBEERSPERBRAND (Attribute 5) and
NUMCALSPERBRAND (Attribute 6).  This is defined in bold in attribute 4 below.

BRANDS

001 A

JBase - User Guide - Release R15.000 - Page 547 of 629


002 7

003 BRANDS

004 C;5;6

005

006

007

008

009 L

010 30

NUMBEERSPERBRAND

001 A

002 5

003 NUMBEERSPERBRAND

004 D;7

005

006

007

008

009 R

010 30

NUMCALSPERBRAND

001 A

002 6

003 NUMCALSPERBRAND

004 D;7

005

006

007

008

009 L

010 30

The dependant attributes (NUMBEERSPERBRAND and NUMCALSPERBRAND) define their controlling attribute in attribute 4 as well.

Without this relationship defined, the same query would yield vastly different results.

jsh -->SQLSELECT a.LASTNAME, a.NUMBEERSPERBRAND, a.NUMCALSPERBRAND FROM CUSTOMERS a WHERE a.FIRSTNAME = 'JIM'

STALLED^10^105

JBase - User Guide - Release R15.000 - Page 548 of 629


STALLED^10^100

STALLED^12^105

STALLED^12^100

JAMES^6^150

JAMES^6^100

JAMES^12^150

JAMES^12^100

SUE^4^200

SUE^4^100

SUE^12^200

SUE^12^100

Selected 12 rows.

Now we see that there is a JOIN taking place, so please take note that multi-valued attributes (tables within a table) need to be related to one
another in the dictionary, otherwise a JOIN will occur.

JBase - User Guide - Release R15.000 - Page 549 of 629


Assumptions

While it is not entirely necessary that the reader understand jQL syntax, it is assumed that the reader is familiar with SQL syntax. It is also
assumed that the user understand that jBASE is a hierarchical database and not a relational database (meaning that data is not necessarily nor-
malized to 3rd normal form as in relational databases). Other assumptions follow:

Filename and tablename are used synonymously in this document.

$JBCRELEASEDIR refers to the directory where jBASE was installed.

$JEDIFILEPATH refers to the search path jBASE uses to find files or tables.

JBase - User Guide - Release R15.000 - Page 550 of 629


Current limitations

Unsupported SQL Features


Correlated subqueries are not yet supported, as well as outer joins. Joins on multi-valued attributes are not supported when these attributes
are coming from different tables.

JBase - User Guide - Release R15.000 - Page 551 of 629


JBase - User Guide - Release R15.000 - Page 552 of 629
Unsupported SQL Functions
TRUNC

TRANSLATE

STDDEV

VARIANCE

CONVERT

CHARTOROWID

HEXTORAW

RAWTOHEX

ROWIDTOCHAR

TO_CHAR – Not needed by jBASE handled by dictionary Conversions.

TO_DATE – Not needed by jBASE handled by dictionary Conversions.

TO_NUMBER – Not needed by jBASE handled by dictionary Conversions.

DUMP

GREATEST

LEAST

UID

USERENV

INITCAP

LPAD

JBase - User Guide - Release R15.000 - Page 553 of 629


JBase - User Guide - Release R15.000 - Page 554 of 629
SELECT * AND SELECT COUNT(*)
Select * might not work as expected if some of the data is multi-valued.  This is because multi-valued data is really a table within a table.  There-
fore, the multi-valued data (or inner table) is joined to the outer.  This might not be what is intended.  It is important to know the structure of
the underlying data before using the * syntax of SQL.  By contrast, SELECT COUNT(*) FROM fileName , returns the amount of items in file-
name, which is more likely what the user expects. For example, if there is a file CUSTOMER with no multi-values (tables within a table), then
the following query would produce the expected results;

Jbase - - >SQLSELECT * FROM CUSTOMERS WHERE FIRSTNAME = ‘DONNAYA’

@ID FIRSTNAME LASTNAME AGE


- - - -- - - -- - -- - - - -- - - -- - - -- - - - -- - - - - - -- - - - -- - - -- - - -- - - -- - - -- - - -- - - -
3 DONNAYA HUNT 31

Selected 1 rows.

However, if you query the file CUSTOMERS in the samples directory (which does contain tables within tables) with the exact same query, you
retrieve back 3888 rows(because there are multiple tables within tables in this file)! You can, however, retrieve the tables within tables in one
column which can then be parsed programmatically. To do this, set the environment variable JQL_DONT_MAKE_ROWS as shown below;

>set JQL_ DONT_ MAKE_ ROWS=1


>jsh
jsh - - >SQLSELECT * FROM CUSTOMERS WHERE FIRSTNAME = 'DONNAYA'
@ID FIRSTNAME LASTNAME AGE STAR NUMBEERSPERBRAND
NUMCALSPERBRAND
BRANDS
ADDR1
CITY
POSTCODE COUNTRY PETS
-------------- ------------------------ -------------------- ------- ---- ------------------------------ ------
- - - - - - - - -
--------------- ------------------------------ ------------------------------ -------------------- ---------- -
- - - - - - - - -
- - - - - - - - - - - - - - - - - - - -
3 DONNAYA HUNT 31 11 4]6 200]
150
KRONENBURG]COORS 105 DONNYA HUNT RD.]106 MARCUS SAN FRAN.]SAN FRAN.] 91654]9165
US] US] US
MADDOX\GLAVINE] CONE\

Selected 1 rows.

As well, the * syntax is now only supported for one and only one table in the FROM clause. Queries such as SELECT a.*, b.* FROM table1 a,
table2 b WHERE a.id = b.id will not work. This is a limitation that will be fixed in a future release.

JBase - User Guide - Release R15.000 - Page 555 of 629


Dictionaries

jBASE has different mechanisms to represent dictionary items or meta data. These are documented in the jQL documentation and the following
section assumes a cursory knowledge of dictionary definitions. The main thing to keep in mind is that there are Dictionary files which hold the
meta-data, and data files which hold the application data.

To view the MYCUCSTS dictionary, issue the following command.

jsh -->LIST-ITEM MYCUSTS]D

You will see records like this:

FIRSTNAME

001 A

002 1

003 FIRSTNAME

004

005

006

007

008

009 L

010 24

LASTNAME

001 A

002 2

003 Last Name

004

005

006

007

008

009 L

010 20

etc.

FIRSTNAME maps to Attribute 1  in the datafile and LASTNAME maps to Attribute 2 in the data file.  Now let’s look at the raw data for an
item (jed is a jBASE editor similar to ED. 0000011 below is the record key of the shown record.)

jsh -->jed MYCUSTS 0000011

File MYCUSTS , Record '0000011' Inser

JBase - User Guide - Release R15.000 - Page 556 of 629


Command->

001 JIM

002 HARRISON

003 1 SUN AVENUE

004

005 SAN JOSE

006 IN

007 09324

008 (125) 555-1337

009 (124) 555-1337

010 JIMH@compe.com

011 SPARC]INTEL PII]ALPHA AXP]DIGITAL]DIGITAL]DELL]ALPHA AXP

012 HPUX]SOLARIS]DGUX]TRU64]DGUX]TRU64]SOLARIS

013 UNI*]ROS]Another Pick]Another Pick]ROS]UNI*]jBASE

014 1980]1315]1475]1016]843]1436]879

One can see the FIRSTNAME “JIM” in Attribute 1 and the LASTNAME “HARRISON” in Attribute2.  Attribute13 is SYSTEMTYPE and is
multi-valued.

Dictionary Considerations

1) For numeric comparisons, the item must be defined as right justified as shown below in attribute 9.

NUMBEERSPERBRAND
001 A
002 5
003 NUMBEERSPERBRAND004 D;7
005
006
007
008
009 R
010 30

This allows one to do queries such as the following;

jsh-->SQLSELECT LASTNAME, NUMBEERSPERBRAND FROM CUSTOMERS2 WHERE FIRSTNAME = 'JIM' AND LASTNAME = 'JAMES' AND
NUMBEERSPERBRAND > 5 AND NUMBEERSPERBRAND < 10

2) Columns that belong to the same relation have to be associated, otherwise a JOIN will occur if it appears in the SELECT clause (See the
Chapter on Associations)

Dictionary Descriptors
(not inclusive)

A-descriptor
The 10-line attribute definition which is used on generic MultiValue systems including jBASE and on UniVerse

JBase - User Guide - Release R15.000 - Page 557 of 629


BIRTH.DATE AGE dataname

001 A A D/CODE

002 1 0 A/AMC

003 Date of birth Age TAG

004 V/STRUCT

005

006

007 D MD02 V/CONV

008 F;D;1;-;'100';'365.25';/ V/CORR

009 R R V/TYPE

010 11 3 V/MAX

D-descriptor

001 D TYPE

002 7 LOC

003 D2/ CONV

004 Date of Birth NAME

005 8R FORMAT

006 M SM

007 DETS4 ASSOC

I-descriptor

001 I TYPE

002 @RECORD<1,2>*@RECORD<1,3> LOC = the I-expression to be evaluated

003 MD2 CONV

004 Value NAME

005 10R FORMAT

006 S SM

007 DETS5 ASSOC

JBase - User Guide - Release R15.000 - Page 558 of 629


Examples of SQL

The example files


These examples are located in the $JBCRELEASEDIR/samples/SQL directory and can be run in or outside a jsh by simply adding this dir-
ectory to the $JEDIFILEPATH. The MYCUSTS and MYCUSTS2 files are indexed and these indexes are utilized.

JBase - User Guide - Release R15.000 - Page 559 of 629


JBase - User Guide - Release R15.000 - Page 560 of 629
On the jsh
Attribute Marks (a character to delimit database fields) are represented with the character ‘^’.

1) Example of a join between two files.


jsh-- >SQLSELECT a.FIRSTNAME, b.AGE, a.LASTNAME,b.LASTNAME FROM MYCUSTS a, CUSTOMERS b WHERE a.FIRSTNAME =
b.FIRSTNAME AND a.FIRSTNAME = 'JIM' AND a.LASTNAME = 'FLETCHER'

FIRSTNAME AGE LASTNAME LASTNAME

------------------------ ------- -------------------- --------------------

JIM 41 FLETCHER STALLED

JIM 50 FLETCHER JAMES

JIM 58 FLETCHER SUE

Selected 3 rows.

2) Multivalued example of a join between two files


(SYSTEMTYPE is a multivalued field and hence one can see the implied JOIN (as SYSTEMTYPE is a table within a table) as well as the JOIN
beween the two tables. Note that we can thwart the implied JOIN by creating an ASSOCIATION.  See ASSOCIATIONS).

jsh -->SQLSELECT a.FIRSTNAME, a.SYSTEMTYPE, b.AGE, b.LASTNAME FROM MYCUSTS a, CUSTOMERS b WHERE a.FIRSTNAME =
b.FIRSTNAME AND a.FIRSTNAME = 'JIM' AND a.LASTNAME = 'FLETCHER'

FIRSTNAME SYSTEMTYPE AGE LASTNAME

------------------------ ------------------------ ------- --------------------

JIM ROS 41 STALLED

JIM Boo! Not jBASE 41 STALLED

JIM ROS 50 JAMES

JIM Boo! Not jBASE 50 JAMES

JIM ROS 58 SUE

JIM Boo! Not jBASE 58 SUE

Selected 6 rows.

3) Example of a subquery
jsh-->SQLSELECT DISTINCT a.FIRSTNAME, a.LASTNAME FROM MYCUSTS a WHERE a.FIRSTNAME IN ( SELECT b.FIRSTNAME FROM
CUSTOMERS b WHERE b.AGE = 50)

FIRSTNAME LASTNAME

JBase - User Guide - Release R15.000 - Page 561 of 629


------------------------ --------------------

JIM FLETCHER

CLIVE PIPENSLIPPERS

JIM FREEMAN

CLIVE DELL

CLIVE COOPER

CLIVE JACKSON

JIM HARRISON

JIM SUE

JIM LAMBERT

JIM COOPER

JIM FENCES

CLIVE GATES

FIRSTNAME LASTNAME

------------------------ --------------------

CLIVE FLETCHER

CLIVE WALKER

CLIVE BOYCOTT

Selected 15 rows.

4) Example of the LIKE keyword


( results not shown )

jsh-->SQLSELECT a.FIRSTNAME, a.LASTNAME FROM MYCUSTS a WHERE a.FIRSTNAME LIKE 'JIM%'

5) Example of the BETWEEN keyword


( results not shown )

jsh-->SQLSELECT a.FIRSTNAME, a.LASTNAME FROM CUSTOMERS a WHERE a.FIRSTNAME BETWEEN 'JIM' AND 'JOHNO'

6) Example of the EXISTS keyword


( results not shown)

jsh-->SQLSELECT a.FIRSTNAME, a.LASTNAME FROM CUSTOMERS a WHERE EXISTS ( SELECT FIRSTNAME FROM MYCUSTS WHERE
FIRSTNAME = 'DONNA' )

JBase - User Guide - Release R15.000 - Page 562 of 629


JBase - User Guide - Release R15.000 - Page 563 of 629
In a BASIC Program
Retrieving raw data is not difficult to do programmatically using the jQL API. 

The following code below is taken directly from;

$JBCRELEASEDIR/samples/SQL/MYSQLLIST.b.

It is meant to show how rows are returned with user given selection criteria.  Example of output follows the code.  (To compile: the commands
are (1) BASIC . MYSQLLIST.b (2) CATALOG . MYSQLLIST.b)

* This program is an example program that shows how to fetch data

* with SQL Syntax.

PROGRAM MYSQLLIST

INCLUDE JQLINTERFACE.h

ResultCode = 0

* Get Selection Criteria

CRT "Enter Selection Criteria :":

INPUT SelCriteria

IF SelCriteria = "" THEN STOP

* Compile the statement

Options = JQLOPT_USE_SQLSELECT

SelCriteria = "SELECT ":SelCriteria

ResultCode = JQLCOMPILE(Statement, SelCriteria,Options,ErrorString)

IF ResultCode < 0 THEN STOP ErrorString

* Start execution

sel = ""

Status = JQLEXECUTE(Statement,sel)

* Main Output Loop

ProcessedItems = 0

LOOP

Status = JQLFETCH(Statement,Control,Data)

WHILE Status >= 0 DO

IF Control<1> >= 0 THEN

JBase - User Guide - Release R15.000 - Page 564 of 629


* Detail Line

ProcessedItems++

CRT "Data :": CHANGE(CHANGE(Data, @VM, "]"),@AM,"^")

END

REPEAT

CRT "Processed ":ProcessedItems

Example run

jsh -->MYSQLLIST

Enter Selection Criteria :?a.FIRSTNAME FROM CUSTOMERS a

Data :JIM

Data :JIM

Data :DONNAYA

Data :JOHNO

Data :^

Data :CLIVE

Data :JIM

Processed 7

JBase - User Guide - Release R15.000 - Page 565 of 629


Limiting multi-values in display

When a multi-valued attribute is presented in the SQLSELECT clause, and that same attribute is also present in the WHERE clause, a question
arises as to how the data is to be displayed. Let’s take an easy example. Below is the data as it is stored on disk.  Attribute1 is the FIRSTNAME
column, Attribute2 is the LASTNAME column and Attribute13 is the SYSTEMTYPE multi-valued column (different values are separated with a
] character...)

MYCUSTS2.. 0000162

FIRSTNAME. JIM

Last Name. FREEMAN

SYSTEMTYPE... Another Pick ] Boo! Not jBASE  ] jBASE  ] ROS ] UNI* ] Another Pick

First, let’s look at a jQL listing of the file. (Note that the bolded words at the end of the query are the output specification).

jsh-->LIST MYCUSTS2 WITH FIRSTNAME = "JIM" AND LASTNAME = "FREEMAN" AND SYSTEMTYPE >= 'ROS' AND SYSTEMTYPE !=
'Boo! Not jBASE' FIRSTNAME LASTNAME SYSTEMTYPE

PAGE 1 09:33:43 17 OCT 2003

MYCUSTS2.. 0000162

FIRSTNAME. JIM

Last Name. FREEMAN

SYSTEMTYPE... Another Pick Boo! Not jBASE jBASE ROS UNI* Another Pick

1 Records Listed

You can see that the whole item is returned and every attribute in SYSTEMTYPE is returned even though we’ve attempted to narrow
SYSTEMTYPE in the query with two conditions.  Why does this happen?  Because we are selecting on the item and not the multi-
values in the jQL language.  In other words, each ITEM meets the criteria of SYSTEMTYPE >= 'ROS' AND SYSTEMTYPE != 'Boo! Not
jBASE', not each multi-value.  (There is an ITEM that has at least one multi-value that meets the condition, hence the AND clauses can be
thought of as OR clauses).

In jQL there is a way to “limit” the display of multi-values.  This is shown underlined below where the output specification of SYSTEMTYPE is
met with added conditions.

jsh-->LIST MYCUSTS2 WITH FIRSTNAME = "JIM" AND LASTNAME = "FREEMAN" AND SYSTEMTYPE >= 'ROS' AND SYSTEMTYPE !=
'Boo! Not jBASE' FIRSTNAME LASTNAME SYSTEMTYPE GE "ROS" AND NE "Boo! Not jBASE"

PAGE 1 09:44:29 17 OCT 2003

MYCUSTS2.. 0000162

FIRSTNAME. JIM

Last Name. FREEMAN

SYSTEMTYPE... jBASE ROS UNI*

JBase - User Guide - Release R15.000 - Page 566 of 629


1 Records Listed

The effect is that there are only 3 values now displayed for SYSTEMTYPE.  Now let’s look at a query that is returning results for SQL.  This is
what jBASE will return by default:

jsh -->SQLSELECT FIRSTNAME, LASTNAME, SYSTEMTYPE FROM MYCUSTS2 WHERE FIRSTNAME = 'JIM' AND LASTNAME = 'FREEMAN'
AND SYSTEMTYPE >= 'ROS' AND SYSTEMTYPE != 'Boo! Not jBASE'

FIRSTNAME LASTNAME SYSTEMTYPE

------------------------ -------------------- ------------------------

JIM FREEMAN jBASE

JIM FREEMAN ROS

JIM FREEMAN UNI*

Selected 3 rows.

Here the WHERE clause itself limits what is returned. 

So here is the dichotomy of limiting. Are we selecting on the ITEM or are we selecting on the MULTI-VALUES being displayed on the item?
Which one does the WHERE clause refer to? By default, the SQL engine selects on the multi-values and the AND clauses are treated as AND
clauses when limiting the display. Such that the query in SQL will produce no results as shown below where it will display the item with the
LIST command.

jsh-->SQLSELECT FIRSTNAME, LASTNAME, SYSTEMTYPE FROM MYCUSTS2 WHERE FIRSTNAME = 'JIM' AND LASTNAME = 'FREEMAN'
AND SYSTEMTYPE = 'UNI*' AND SYSTEMTYPE = 'jBASE'

Selected 0 rows.

But what if you really want to select on the ITEM in SQL and in effect have the AND clauses be treated as OR clauses? This behaviour can be
changed by setting the environment variable JQL_LIMIT_WHERE to any value or setting the option programmatically as shown below.

Options = JQLOPT_LIMIT_WHERE

ResultCode = JQLCOMPILE(Statement, SelCriteria,Options,ErrorString)

With this variable set, the following query would produce the results shown below.

jsh-->SQLSELECT FIRSTNAME, LASTNAME,SYSTEMTYPE FROM MYCUSTS2 WHERE FIRSTNAME = 'JIM' AND LASTNAME = 'FREEMAN'
AND SYSTEMTYPE = 'UNI*' AND SYSTEMTYPE = 'jBASE'

FIRSTNAME LASTNAME SYSTEMTYPE

------------------------ -------------------- ------------------------

JIM FREEMAN jBASE

JIM FREEMAN UNI*

Selected 2 rows.

In addition, the user can choose to ignore limiting the display all together by setting the environment variable JQL_ DONT_LIMIT or setting
the Option JQLOPT_DONT_LIMIT.

JBase - User Guide - Release R15.000 - Page 567 of 629


Overview

One of the main benefits of providing a SQL engine for jBASE is such that the database can be used with external tools and APIs. This doc-
ument is meant to be used with the jDBC Driver manual which gives a description of how the JAVA API for jDBC can be used with jBASE.  In
addition, there is an API for jBASE BASIC that is covered in this manual.

SQL has many benefits that can be applied to the multi-valued, hierarchical, database jBASE. In particular with jBASE, SQL allows users to
query data where there might be tables within tables and no primary-key/foreign key relationship (these relationships are defined in the dic-
tionary). This is an extreme advantage not available in most other RDBMS systems. Some of the advantages of using SQL over the traditional
query language of jQL are discussed below:

1. SQL allows sub-queries, UNION/INTERSECT/MINUS statements, and allows joins.  jQL does not.  jQL might take 2 or 3 queries to
do the work of one SQL statement. jQL may programmatically require more lines of code to accomplish the same task.
2. To call user defined functions in jQL, there needs to be a dictionary item representing this, usually expressed as an Itype. This clutters
the dictionary. SQL allows use of functions directly in the language (ex. SELECT MYFUNC(a.FIRSTNAME,a.AGE) FROM MYCUSTS
a). One can build complex virtual columns without having to modify the dictionary to do it.
3. SQL has support for grouping records with GROUP BY and further selecting on those grouped records with the HAVING keyword.
While jQL has group functionality with some verbs (grouping is not supported with the most commonly used jQL verbs that return
select lists), it doesn’t have the HAVING functionality.
4. SQL is a more structured language that has no implications in it. Therefore, it is more readable and more easily understood. For
example,

SELECT MYCUSTS WITH FIRSTNAME = “JIM” OR WITH FIRSTNAME = “JOHN”

SELECT MYCUSTS WITH FIRSTNAME = “JIM” OR FIRSTNAME = “JOHN”

SELECT MYCUSTS WITH FIRSTNAME = “JIM” OR “JOHN”

are all valid jQL statements that return the exact same results. In addition, jQL allows one to put the ordering clause before the selection cri-
teria clause and vice versa.

JBase - User Guide - Release R15.000 - Page 568 of 629


SQL Engine

Contents:

l Overview
l Assumptions
l SQLSELECT PROGRAM
l Examples of SQL
l Limiting multi-values in display
l Associations
l Dictionaries
l Current limitations
l SQL Programatic Options
l Appendix

JBase - User Guide - Release R15.000 - Page 569 of 629


SQL Programatic Options

Some options need to be known such that the statement can be compiled. These options are passed to JQLCOMPILE like below.

Options = JQLOPT_USE_SQLSELECT + JQLOPT_DONT_MAKE_ROWS

SelCriteria = "SELECT ":SelCriteria

ResultCode = JQLCOMPILE(Statement, SelCriteria,Options,ErrorString)

Available Description
options

JQLOPT_ Use the SQL engine instead of the jQL engine


USE_
SQLSELECT

JQLOPT_ Treat ANDs LIKE Ors when limiting (see section on limiting)
LIMIT_
WHERE

JQLOPT_ Don’t do any limiting at all


DONT_LIMIT

JQLOPT_ Keep multi-values and subvalues as is without splitting them up into rows (most useful for
DONT_ PICK developers who want to handle processing multi-values and sub-values themselves)
MAKE_ROWS

JBase - User Guide - Release R15.000 - Page 570 of 629


SQLSELECT PROGRAM

The SQLSELECT program is the program that runs SQL statements on the jsh.  It displays headers that are supplied by the dictionary. Some
important notes:

1.    By default, data is truncated according to the size of the display length.  For example, if the dictionary item looks like this,

jsh -->jed MYCUSTS]D ADDR1

File MYCUSTS]D , Record 'ADDR1'

Command->

0001 A

0002 3

0003 Address Line 1

0004

0005

0006

0007

0008

0009 L

0010 6

then any data beyond 6 characters will be truncated as shown below. 

jsh -->SQLSELECT ADDR1 FROM MYCUSTS WHERE FIRSTNAME = 'JIM'

ADDR1

------

1 SUN

1 SUN

64 HAD

121 EL

1 SUN

10260

10260

Selected 7 rows.

jBASE is different than Oracle and other relational databases in that the size of the variable is not declared (it can be any size up to the max size
of the file). If the user wishes to display all data, one can do so by setting the environment variable JSQLSHOWRAWDATA as shown below.

jsh -->set JSQLSHOWRAWDATA=1

jsh -->SQLSELECT LASTNAME, ADDR1 FROM MYCUSTS WHERE FIRSTNAME = 'JIM'

HARRISON^1 SUN AVENUE

SUE^1 SUN AVENUE

JBase - User Guide - Release R15.000 - Page 571 of 629


LAMBERT^64 HADDOCKEN PLACE

FLETCHER^121 ELEVEN SQUARE

COOPER^1 SUN AVENUE

FENCES^10260 SW GREENBURG RD

FREEMAN^10260 SW GREENBURG RD

Selected 7 rows.

Running in the mode JSQLSHOWRAWDATA will ignore header processing. You will also find that the addr1 field above is no longer truncated.
Note as well, that attribute marks are displayed as the ‘^’ character in this reporting mode.

2) Headers can be turned off as well by setting the environment variable JSQLHEADER=OFF. Formatting will be preserved in this mode, but
JSQLSHOWRAWDATA overrides any setting of JSQLHEADER.

jsh -->set JSQLHEADER=off

jsh -->SQLSELECT LASTNAME, ADDR1 FROM MYCUSTS WHERE FIRSTNAME = 'JIM'

HARRISON 1 SUN

SUE 1 SUN

LAMBERT 64 HAD

FLETCHER 121 EL

COOPER 1 SUN

FENCES 10260

FREEMAN 10260

Selected 7 rows.

JBase - User Guide - Release R15.000 - Page 572 of 629


Transaction Journaling

Transaction Journaling
Transaction journaling provides the capability to log updates which are made to a jBASE database. The order in which the updates are logged
will reflect the actual updates made by a particular user/program facility in a sequential manner. Updates made system-wide will be appended
to the log as and when they occur on the database; i.e. the transaction log will reflect all updates in sequential order over time. The intention of
the transaction log is that it provides a log of updates available for database recovery in the event the system uncontrollably fails.

These are the main transaction journaling administration utilities provided within jBASE:

jlogadmin This command is provided to configure and start/stop/suspend transaction journaling.

jlogstatus This command allows the administrator to monitor the activity of transaction journaling.

jlogdup This command enables the recovery or replication of data.

Additional Administration Utilities


Jlogsync synchronizes and flushes log files

Jlogmonitor monitors the current state of transaction journaling

Transaction Journaling Strategy


This is the minimum setup for Transaction Journaling. The strategy to be employed will be as follows:

There will be 2 sets of transaction log files on each machine, logset1 and logset2. Logset1 will contain all the updates applied on Monday or
Wednesday or Friday and logset2 will contain all the updates applied on Tuesday, Thursday or Saturday/Sunday.

The definitions of these files are maintained by the ‘jlogadmin’ command. The transaction log files should be switched by use of cron at mid-
night (or 1 minute past midnight) using the command ‘jlogadmin –l N’ command where N is 1 for Monday , Wednesday or Friday and N is 2 for
Tuesday , Thursday and Saturday.

The administrator must ensure that all users are logged off the system prior to a system backup.

Transaction journaling is stopped by stop_tj command.

The backup script ‘backup_jbase’ should run to backup the system. This scenario allows for the backup failing and being restarted. Note the
creation of a statistics file. This is used effectively to timestamp the transaction log with the start time of the backup. Thus if the save was
restarted then the creation time of the statistics file will reflect the start of the last good backup. The operation is thus:

Stop the transaction log file to tape jlogdup process: database updates for the duration of the backup will be prevented by the administrator.

Remove and label the tape – this contains all database updates since just prior to the last backup.

Mount a tape in the tape deck to hold the backup.

Once this has been done, the operator responds to the prompt and the backup commences.

Upon completion of the backup and verify, the tape is removed and labeled appropriately.

A new tape to hold the transaction log file is then mounted in the tape deck.

The operator now responds to the prompt and the jlogdup process, dumping updates from the disk-based transaction log file to tape re-com-
mences.

There is no need to switch the transaction log files after the completion of the backup, as this is performed automatically.

JBase - User Guide - Release R15.000 - Page 573 of 629


See start_tj and backup_jbase scripts.

JBase - User Guide - Release R15.000 - Page 574 of 629


Logging Strategy
When journaling is running the basic order of operations for updates is as follows:

• The database item is updated in memory


• The transaction log is updated in memory.
• The transaction log is flushed every 10 seconds by default. However this time period can
be configured via an option on the administration command, jlogadmin. It is also possible to
configure an independent process to execute the jlogsync command, to ensure the trans-
action log is continuously flushed from memory at the specified interval, thus alleviating the
flush procedure from all of the update processes.
• The database updates are flushed to disk by the operating system.
• The database update to disk and the log update to disk can be forced to be an atomic oper-
ation.
• Corruption of the transaction log can occur during a system failure while flushing the trans-
action log; this is impossible to circumvent. However, corruption occurs only at the end of
the transaction log file, therefore it is possible to recover right up to the point of the system
failure.
• There is still the possibility that when the system crashes, the disks containing the data
AND the disks with the transaction log data will be lost. By running, a continuous jlogdup to
a secondary machine or tape device you can protect against this highly improbable scenario.
• To use jBASE Transaction Journaling, you must install an additional license key.

Transaction Log
Access to the transaction log is via a special file. Use the CREATE-FILE command to create the file stub:

CREATE-FILE TJ1 TYPE=TJLOG


[ 417 ] File TJ1]D created , type = J4
[ 417 ] File TJ1 created , type = TJLOG

This creates an entry in the current directory

TJ1

JBC__SOB jBASE_TJ_INIT SET: set=current terminate=eos

When a file of type TJLOG is created, it generates a set of dictionary records in the dictionary section of the TJLOG file, which is a normal j4
hash file. The data section of a TJLOG file is handled by a special JEDI driver which accesses the current log set. The log set can be changed by
additional parameters when creating the TJLOG file after the TYPE specification.

EXAMPLE

JBase - User Guide - Release R15.000 - Page 575 of 629


CREATE-FILE TJ2 TYPE=TJLOG set=eldest

Transaction Log File Layout

The transaction log files contain the following information

Attribute Name Description

1 SET Log Set

2 FILENO File Number

3 OFFSET File Offset

4 LOGSIZE Total Log Record Size

5 TYPE Log Record Type

6 TIME-UTC UTC Time

6 TIME Update Time

6 DATE Update Date

7 TRANS Trans

8 TYPENUM Log Record Type

9 PID Update Process

10 PORT Update Port

11 ERR Error Description

12 TRANSID Transaction Identifier

21 PATH Full file path name

22 RECKEY Update Record Key

23 JBNAME jBASE Login Name

24 OSNAME Platform Login Name

25 TTY Terminal Name

26 APPID Application Identifier

1 Default Macro will list TYPE JBNAME PATH TIME DATE

ALL Macro will list all fields

ERRORS Macro will list TYPE JBNAME PATH ERR

TRANSACTION LOG FILE LAYOUT

The following record types are used in the transaction log (see dictionary item TYPE).

Type Description

JBase - User Guide - Release R15.000 - Page 576 of 629


EOF end of file

WRITE record Written

DELETE record Deleted

CLEARFILE file Cleared

DELETEFILE file Deleted

CREATEFILE file Created

TRANSTART transaction Started

TRANSEND transaction Committed

TRANSABORT transaction Aborted

The jlogdup command enables selective restores to be performed by preceding the jlogdup command with a select list. The select list can be
generated from the log set by generating a special file type, which uses the current log set as the data file.

EXAMPLE

CREATE-FILE TJFILE TYPE=TJLOG


[ 417 ] File TJFILE]D created , type = J4
[ 417 ] File TJFILE created , type = TJLOG
:SELECT TJFILE WITH PATH EQ "/home/jdata/CUSTOMER" AND WITH TYPE NE "CLEARFILE"
167 Records selected
>jlogdup INPUT set=current OUTPUT set=database

In this example, all updates to the CUSTOMER file, which have been logged, except for any CLEARFILEs, are re-applied to the CUSTOMER
file.

The jlogmonitor command can be used to monitor potential problems with the jlogdup process. It will report errors when specific trigger
events occur. jlogmonitor can be run in the foreground but will usually be run as a background process (using the standard –Jb option).

Switching Logsets
A logset consists of 1 to 16 files. Each file has a capacity of 2GB, so the maximum capacity of a logset is 32GB. Before the logset reaches its
capacity, a switch must be made to another logset using the jlogadmin command. Failure to do so will render journaling inoperable and may res-
ult in database updates from jBASE programs failing.

Using 16 files in a logset does not consume more space than using just 1 file. This is because updates to the logset are striped across all the
files in the logset. When journaling is active on a live system, the recommendation is to define 16 files for each logset.

At least 2 logsets must be configured (with jlogadmin) so that when the active logset nears capacity, a switch can be made to another logset.
Switching to a logset causes that logset to be initialized, i.e. all files in that logset are cleared. The logset that is switched from remains intact.
The usual command to switch logsets is jlogadmin -l next. If there are 4 logsets defined, this command works as follows:

Active logset before switch Active logset after switch

1 2

JBase - User Guide - Release R15.000 - Page 577 of 629


2 3

3 4

4 1

If a jlogdup process is running in real time to replicate to another machine, it should automatically start reading the next logset when it reaches
the end of the current logset. To effect this behavior, use the parameter terminate=wait in the input specification of the jlogdup command.

JBase - User Guide - Release R15.000 - Page 578 of 629


Reduce Log Record Size

Disabling Record Path Storage in Transend


The details of modified records in a transaction, and their corresponding file paths are stored in TRANSEND record of the log set. In real-time,
the volume of such record updates are large, which leads to an increase in size of TRANSEND record in TJ log set. Disabling the file path stor-
age in the TRANSEND record(using jlogadmin), reduces the Log record size. This helps avoid frequent switching of Log sets.

EXAMPLE

jlogadmin –XON

Compression of TJ Log Records

The larger WRITE’s which are captured in TJ can be compressed and stored to reduce the size of log sets. The jlogadmin utility allows the user
to switch ON/OFF compression, and also to set the threshold for larger TJ WRITE’s.

EXAMPLE

jlogadmin –Z500

Activates TJ log compression, setting the TJ WRITE threshold to be 500 bytes. Any TJ WRITE above 500 bytes will be compressed and
stored.

jlogadmin –Z0

Disables TJ log compression in the system.

JBase - User Guide - Release R15.000 - Page 579 of 629


Selective Journaling
The jBASE journaler does not record every update that occurs on the system. It is important to understand what is and is not automatically
recorded in the transaction log.

What is journaled? Unless a file is designated unloggable, everything is updated through the jEDI interface (i.e. use of the jchmod –L filename
command). This includes non-jBASE hash files such as directories.

What is NOT journaled? The opposite of above, in particular:

• Operations using non-jBASE commands such as the ‘rm’ and ‘cp’ commands, the ‘vi’ editor.

• The UNIX spooler files.

• Index definitions.

• Trigger definitions.

• Remote files using jRFS via remote Q-pointers or stub files

• When a SUBROUTINE is cataloged, the resulting shared library is not logged.

• When a PROGRAM is cataloged the resulting binary executable file is not logged.

• Internal files used by jBASE such as jPMLWorkFile, jBASEWORK, jutil_ ctrl will be set to non-logged only when they are
automatically created by jBASE. If you create any of these files yourself, you should specify that they be not logged (see note
on CREATE-FILE below). You may also choose to not log specific application files.

It is recommended that most application files be enabled for transaction journaling. Exceptions to this may include temporary scratch files and
work files used by an application. Files can be disabled from journaling by specifying LOG=FALSE with the CREATE-FILE command or by
using the -L option with the jchmod command. Journaling on a directory can also be disabled with the jchmod command. When this is done, a
file called .jbase_header is created in the directory to hold the information.

Remote files are disabled for journaling by default. Individual remote files can be enabled for journaling by using QL instead of Q in attribute 1
of the Q pointer, e.g.

<1>QL

<2>REMOTEDATA

<3>CUSTOMERS

Adding L to attribute 2 of the file stub

EXAMPLE
JBC_SOB JediInitREMOTE CUSTOMERS darthv.jbaseintl.com

In general, journaling on specific files should not be disabled for "efficiency" reasons as such measures will backfire when you can least afford it.

JBase - User Guide - Release R15.000 - Page 580 of 629


Selective Restores
There may be times when a selective restore is preferable to a full restore. This cannot be automated and must be judged on its merits.

For example, assume you accidentally deleted it a file called CUSTOMERS. In this case you would probably want to log users off while it is
restored, while certain other files may not require this measure. The mechanism to restore the CUSTOMERS file would be to selectively restore
the image taken by a jbackup and then restore the updates to the file from the logger journal. For example:

# jrestore –h ‘/JBASEDATA/PROD/CUSTOMERS*’ < /dev/rmt/0


# cd /tmp
# create-file TEMPFILE TYPE=TJLOG set=current terminate=eos
[ 417 ] File TEMPFILE]D created , type = J4
[ 417 ] File TEMPFILE created , type = TJLOG
# SELECT TEMPFILE WITH PATH EQ \/JBASE_ACCOUNTS/PROD/CUSTOMERS]\
21 Records Selected

# jlogdup input set=current output set=database

If required, use the jlogdup rename and renamefile options to restore the data to another file.

NOTE: In order to preserve the chronological ordering of the records do not use a SSELECT command on the time field. This may not produce
the correct ordering (multiple entries can occur during the same time period – the granularity being one second).

JBase - User Guide - Release R15.000 - Page 581 of 629


Failure Conditions and Recovery Remedies
Failures may occur in operations at the following stages:

• Normal live running:

• Database updates to the disk-based transaction log file

jlogadmin running, dumping from this transaction log file to tape

What is the nature of the failure?


• System corrupted – rebuild necessary. This failure could be a disk failure; nothing on disk can be relied upon. In this case a full system
restore is required, using the last successful back set. Following this the transaction log file needs to be rolled forward from the saved trans-
action log tape.

• Tape device/tape failure. In the event of a tape device failure – the device has to be repaired/replaced. The tape should be replaced. For this
case and the tape failure, the disk-based transaction log file is still valid. The start time of the last execution of the jlogdup to tape operation
was saved automatically by either the start_tj or backup_jbase script.

• The recover_jbase should be run in either of the cases above.

During the backup/verify procedure


• In this instance, the backup can be restarted. The act of restarting will update the transaction log file with a new start time (i.e. stat-file).

• During the dump of transaction log file information created during the backup/verify

• Problem with the tape: run recover_jbase after replacing the tape.

System/disk problem
The backup verified, so this is the backup set to be used for recovery by the recover_jbase script.

NOTE: that the jlogdup process to tape is still valid. Those transactions which have been dumped to tape can still be recovered.

JBase - User Guide - Release R15.000 - Page 582 of 629


Transaction Journaling on a single system

The diagram above represents the use of Transaction Journaling on a stand-alone system. Why would we use this kind of setup? In the event of
system failure, the vast majority of processing which has taken place since the last system backup can be recovered and replayed. This is vital
for those situations where the transaction cannot physically be repeated. The majority of these transactions can be replayed during system
recovery when TJ is utilized.

Journal Configuration
The Transaction Journal will be configured with two logsets; logset1 and logset2. Each of these logsets will occupy a separate volume partition
on disk; this will allow for correct size monitoring of the logsets. The statistics of the logset usage indicated by the jlogstatus command is not
at obvious at first glance. What is displayed is the proportion of the volume that has been used. Naturally, if the volume is shared by one or
more logsets and/or other data files, then the percentage full will not necessarily reflect the percentage of the volume used by the transaction
log. If the logset is contained within its own volume, then the figures are a fairer reflection of the TJ logset usage (albeit with certain storage
overhead being present). Correct automatic invocation of the Log Nofity program relies on the accuracy of the percentages obtained.

Also if the logsets share a volume with other data, there is the possibility that the writing to the transaction log file may abort due to lack of
space within the volume. The logset volumes should be created large enough for the expected population of updates between logset switches:
i.e. if the logsets are switched every night at midnight, then the logset volume should be large enough to contain all the updates for a whole day
(plus contingency).

Thus the logsets are created as below:

JBase - User Guide - Release R15.000 - Page 583 of 629


JBase - User Guide - Release R15.000 - Page 584 of 629
Transaction Journaling on a single system with two tape desks

The schematic shows the same system, except this time equipped with two tape decks. The advantages of this configuration over the previous
are as follows:

• For the majority of the time during the day, there is a tape deck free for other uses; either for system or development usage.

• This configuration allows for tape deck redundancy. If the event of a deck failure, the previous scenario can still be maintained while the tape
deck is repaired or replaced.

• The jlogdup process can be left running during the backup/verify. This is the most important advantage over the previous scenario. Any data-
base updates which are performed during backup/verify are likely not only be logged to the disk-based transaction log file, but also to the tape.
This eliminates the lag between backing up the system and ensuring that database updates are logged to an external medium.

• The disadvantage of employing this configuration is that in the event of a system (or disk) failure, the machine has to be taken offline for the
duration of the system restore process as well as the Transaction Log restore from tape. As time is money, this approach may be prohibitively
costly to the organisation.

JBase - User Guide - Release R15.000 - Page 585 of 629


Failsafe/Hot Standby

The architecture depicted above shows the use of a Failsafe or Hot Standby machine. This allows for a failure of the live main machine (Nodej
in this case). Unlike the previous configuration where the disk-based transaction logs are written to an external medium (tape), this con-
figuration will enable database updates to be replayed to a standby machine, and indeed to the database on that standby machine, shortly after
the update has been made (and logged) to the live machine.

Purpose of the Hot Standby configuration


Before describing how this configuration is set up and is managed, the role of the standby machine needs to be determined.

It is assumed that for the case of a full system reload, there is some external medium available for the operating system reload and con-
figuration. This could also be contained on the standby machine as a system image. In the latter case, enough disk space should be available to
hold this system image.

The database is to be replicated on the standby machine, so space must be available.

The processor/disk configuration should be fast enough on the standby machine, so as not to lag too far behind database updates on the live
machine. The implication of the standby machine’s unable to cope with the database update rate, may cause the live and standby machines’
database to be unacceptably out-of-sync. – There may be too many disk-based transaction log entries on the live machine which have not been
transferred via jlogup to the standby machine.

HOT STANDBY MACHINE AS A FAST RECOVERY MACHINE

If the Hot Standby machine is to be used within a fast recovery mechanism, then the following is required:

The network between the two machines should be fast and reliable.

The database on the standby machine must be sufficiently up-to-date, with reference to the live machine, as to be acceptable.

HOT STANDBY MACHINE TO BE USED BY ESSENTIAL STAFF DURING SYSTEM RECOVERY

JBase - User Guide - Release R15.000 - Page 586 of 629


The standby machine must have sufficient bandwidth to cope with the assigned tasks, within acceptable time frames. An example of this would
be that if an assigned task were be to run End of Day processing, then the machine must be able to complete this task prior to the normal start
of business the following day.

During the period when the live machine is unavailable, then the standby machine should be able to handle failures. A minimum configuration
should be that Transaction Journaling should be initiated on the standby machine and the transaction log file produced should be backed up to
an external medium (tape?).

Provision should be made to allow for disk-based transaction logs to be held.

Provision should be made for licensing of users on the standby machine.

HOT STANDBY MACHINE TO BE USED AS A LIVE MACHINE REPLACEMENT DURING SYSTEM RECOVERY

If the intent is that the standby machine becomes a temporary replacement for the live machine, then ideally the standby machine should be of
similar configuration to the live machine.

Introducing a Hot Standby machine into the configuration


Assuming that the database on Nodej is of a consistent state, we may introduce a Hot Standby machine by means of the following procedure.
The following describes how transactions are logged from system Nodej (the live machine) to a standby system Nodek, (the Failsafe/Hot
Standby machine).

Transaction Journaling is started on Nodej; thus producing a transaction log file of updated records.

A jbackup/jrestore sequence is initiated from Nodej, by means of the script Backup_ Restore. This will take a snapshot of the database on
Nodej and reproduce it on Nodek. The jbackup option '-s /tmp/jbstart' is used to create a time-stamp file for later use.

find /JBASE_APPS /JBASE_SYSFILES /JBASE_ACCOUNTS –print | jbackup –s /tmp/jbstart –v –c | rsh Nodek –l jbasesu jrestore –N

Once this sequence completes, the updates which have occurred on Nodej since the start of the sequence, need to be updated onto the data-
base on Nodej. This could be achieved with:

jlogdup -u10 input set=eldest start=/tmp/backup.logset0 terminate=wait output set=stdout | rsh Nodek /GLOBALS/JSCRIPTS/logrestore

This will start the updates from the oldest logset (set=eldest); the first database update will be at the time the backup stats file was written
(start=/tmp/backup.logset0), i.e. the start of the backup; the transfer procedure will wait for further updates (terminate=wait). The method
employed to effect the transfer is by means of a pipe. Data from the transaction log is put into the pipe (output set=stdout); this data is taken
from the pipe by means of the logrestore command, initiated on Nodek by means of the rsh command (remote shell). The logrestore command
sets up a jBASE environment and then initiates a jlogdup command, taking its input from the pipe (input set=stdin) and updating the database
on Nodek (output set=database).

/GLOBALS/JSCRIPTS/logrestore Script
JBCRELEASEDIR=/usr/jbc
JBCGLOBALDIR=/usr/jbc PATH=$PATH:$JBCRELEASEDIR/bin
LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:/usr/ccs/lib
JBCOBJECTLIST=/JBASE_APPS/lib: (or whatever it is for your usual users)
export JBCRELEASEDIR JBCGLOBALDIR JBCOBJECTLIST
jlogdup input set=stdin output set=database

The status of the jlogdup process can be monitored by running jlogstatus from a dedicated window:

jlogstatus -r5 –a

JBase - User Guide - Release R15.000 - Page 587 of 629


Optionally, jlogstatus can be run on Nodek to ensure the log is being restored correctly.

It is usual to configure more than one set of transaction log files. Initially logging will start to, say, set 1; and at some point logging to logset 2
will be initiated. This will usually be done daily just before each jbackup to tape. Then, typically, on the next day, logging will be switched back
to logset 1 (and overwriting the previous transaction log) and the daily jbackup started.

Database update metrics should be established to determine the correct size of the logsets. The jlogstatus display should be monitored to
ensure that the logsets don't fill the disk! Transaction Journaling can be configured to perform certain actions when the transaction log disks
begin to fill past a configurable watershed.

Data Validity after a Failure Condition


In the event of a failure on Nodej, the standby machine, Nodek will contain an up-to-date database on which to continue operations. This is
not necessarily strictly accurate because of several factors outside the control of this mechanism:

There is a configurable flush rate parameter which may be adjusted for Transaction Journaling. This parameter governs how often transaction
log file updates, held in memory are flushed to disk. The minimum period between transaction log file flushes is 5 seconds. This will limit lost
transaction log file updates to at maximum the last 5 seconds.

In the event of failure of the disk holding the transaction log file as well as the disk holding the database, the lost data is limited to those trans-
actions which have been logged to disk, but not transferred to the standby machine, plus the logging of those transactions which have still to
be flushed to disk. This situation is less quantifiable, but as the transaction log file reflects a sequential record of database updates over time,
manual investigation would be required to determine the latest updates which were actually updated on the standby machine. Obviously, the
database update transaction rate on the live machine governs the magnitude of this investigation.

Although the majority of database updates can be preserved after a system failure, what is not necessarily preserved is database integrity. The
use of and management of transaction boundaries within application code ensures that only complete (multi-file) updates make it to the data-
base. During system recovery (rebuild) only complete database transactions are rolled forward; those transactions which were not complete at
the time of system failure are not written to disk. When initiating a transaction through the jBC command TRANSTART, the use of the option
SYNC ensures that a memory flush will take place upon a transaction end or abort. This also ensures that the transaction log file is also flushed
to disk, thus eliminating any delay in writing to disk. Subsequent to system failure, manual investigation is now targeted at complete applic-
ation transactions rather than individual database updates, albeit at the possible expense of system performance.

System Recovery in a Hot Standby Configuration


If the standby machine (Nodek) is to be used as a temporary application machine, while the cause of the failure of Nodej is determined and
resolved, then those users who are to continue, require to be “replugged” to Nodek. This could be automatic, whereby those users’ PCs are
automatically re-routed to Nodek on the unavailability of Nodej; otherwise a script could be run to re-assign Nodej’s IP address to Nodek. The
users in this case, would be requested to log on again to continue their work. This reassignment should only take place when the state of the
database is established. The checks required are specific to each installation so cannot be predetermined here.

RECOVERY PROCEDURE

Wait for the TJ restore process on the standby system (Nodek) to finish. This will be known when the statistics on the number of records read
remains constant.

Establish the validity of the database on Nodek and the transactions to be re-entered (if necessary).

Shut down the standby machine.

Shut down the Nodej machine if it isn’t already completely down.

Restart Nodek in level 1. This is before the communications daemons are started. Create scripts to switch the IP addresses of the network and
VTC cards to become those that Nodej formerly were. Continue the booting of Nodek.

Disable jBASE logons on Nodek.

Re-start the logger to a fresh set of transaction log files using the jlogadmin command.

JBase - User Guide - Release R15.000 - Page 588 of 629


When Nodej is repaired and first booted, you will need to boot it into level 1 so you can ensure the network and VTC addresses become those
previously taken by Nodek.

Reload the operating system and jBASE on Nodek (if necessary). This can be contained in a system backup tape, held securely. This system
backup should contain a skeleton system, including a valid jBASE installation, C++ compiler, peripheral and user logon definitions. Any
upgrades the system should be reflected in this system backup.

Start a backup/restore sequence between Nodek and Nodej; thus

find /JBASE_APPS /JBASE_SYSFILES /JBASE_ACCOUNTS –print | jbackup –s /tmp/jbstart –v –c | rsh Nodej –l jbasesu jrestore –N

where :

The filesystems /JBASE_APPS etc. identified are examples for a jBASE system

/tmp/jbstart is the stats file to be dumped (used to timestamp start of save)

rsh Nodej will run a command on the Nodej machine

-l jbasesu identifies a jBASE user to be used for restores. This is important if indexes are to be rebuilt on restore (the user should have access
to files and subroutines).

-N indicates that indexes should be rebuilt on-the-fly

Ensure the jBASE demons are started.

Enable jBASE logons. At this point it is safe for users to start using the system. Any updates since the start of the backup will be logged in the
TJ log.

Once the backup/restore process has fully completed, the updates which have accrued on Nodek since is start can now be replayed thus:

jlogdup input set=current output set=stdout terminate=wait start=/tmp/jbstart | rsh Nodej –l jbasesu /JBASE_SYSFILES/logrestore

Once the two machines are in sync again both machines can be brought down, the network and VTC card addresses swapped, and users can be
allowed to re-logon to the Nodej machine.

Other Considerations when running a Hot Standby Configuration


Password files must be kept in synchronization on both machines.

Spooler configurations need to be kept in sync.

Once the /JBASE_APPS have the developer sources in normal Unix files, the use of a nightly backup and a RAID configuration will be suf-
ficient.

When developers BASIC and CATALOG their programs, they will go into their own directories rather than into /JBASE_ APPS. At certain
points in time, when no users are active, the programs and subroutine libraries will be copied en-bloc to both the Nodej and Nodek machines
in /JBASE_APPS. This is the correct way to release new software and it needs to be done on both machines to ensure consistency of applic-
ations in the event of failure.

When an application developer changes an index or trigger definition, it should be done on files in their own environment. At some point you
will want to release them into the live community. This again is best done when no users are active. To do this you will need to release the
changed application and subroutine libraries (as shown above) and then release the new trigger and/or index definitions and apply the same
changes to both the Nodej and Nodek machines. The indexes will need to be rebuilt on both machines.

All changes to jBASE scripts kept in the /JBASE_SYSFILES will need to be manually duplicated.

Many of the synchronization requirements should be checked nightly in a cron script and errors reported. Such a script could be made to verify
the password file, the jBASE spooler configuration, the Unix spooler configuration., the scripts in the /JBASE_SYSFILES file system, check
that the programs and subroutine libraries are identical on both Nodek and Nodej, and could check the index and trigger definitions are
identical on both Nodek and Nodej, check the cron jobs are the same and the scripts they invoke are the same.

This verification of the two machines could also be run following a rebuild.

JBase - User Guide - Release R15.000 - Page 589 of 629


Refinement to Hot Standby Configuration

The configuration above shows a small, but significant refinement to the previous configuration. Essentially, the transaction log file is being rep-
licated to Nodek, with the logrestore script showing the following change:

jlogdup input set=stdin output set=logset

Thus, all updates transferred from the transaction log file on Nodej are updated to the transaction log file on Nodek. Another jlogdup process is
initiated thus:

jlogdup input set=current output set=database

this takes these updates and applies them to the database. The reason for this becomes apparent when a recovery is required. Because there is
now a copy of the transaction log file on the standby machine, by interrogation of the transaction log file, it is clear which updates have been
transferred from the live machine. If the jlogdup is allowed to continue until all updates in the transaction log file have been applied to the data-
base, then the recovery position can be established far more easily than by interrogating the database.

JBase - User Guide - Release R15.000 - Page 590 of 629


Resilient T24 Configurations
Each configuration which will be described adheres to those goals as identified in the Temenos Technology and Research White Paper - T24
Resilience High Availability in Failover Scenarios and the proposed new Close of Business Procedures as described in the Functional Spe-
cification Changes to Batch Operation for Global Processing Environments

Stand-Alone System – application server and database server on one machine

This should be the minimum standard configuration utilizing Transaction Journaling. The assumptions made here are that jBASE will be the
database (native) server.

Transaction handling will be achieved by the use of the programming commands:

• TRANSTART

• TRANSEND

• TRANSABORT

Transactions which are not completed in their entirety will be completely “rolled back” by jBASE, when commanded to so do by the
TRANSABORT command. Upon execution of the TRANSEND command all or none of the constituent database updates will be actioned, ensur-
ing database consistency. Any transactional recovery will be achieved through the use of jBASE facilities.

jBASE transaction journaling will be used to record all database updates.

Transaction Journaling has been configured for example, with two logsets:

1. /bnk/bnk.jnl/logset1

2. /bnk/bnk.jnl/logset2

where: logset1 and logset2 are links to two mounted filesystems each containing the corresponding transaction log file definitions.

TJ is then activated by a script similar to start_ tj, which activates transaction logging and also the backup of the transaction logs to tape
(/dev/rmt/0 in this case).

JBase - User Guide - Release R15.000 - Page 591 of 629


The Transaction journal is copied to tape (or other external medium) on a continuous basis by means of the jlogdup facility.

A backup of the database (using the backup_ jbase script) is initiated prior to the execution of Close of Business procedures. Logsets are
“switched” following the successful completion of backups.

When a backup is required, a script, based on “backup_jbase” is run.

Actions performed by this script are:

• Disk-based transaction log file entries are still allowed to be dumped to tape. When there is no Transaction Logging activity, then all out-
standing transactions have either been logged to tape or rolled back. NOTE: The time allowed for transactions to complete is dependent on
application design. The end of dump activity can be checked by use of the jlogstatus command

• The transaction log file duplication process to tape is stopped.

• The logging tape is replaced by a new tape for the backup.

The command:

find /bnk -print | jbackup -v -f –c /dev/rmt/0 -s /tmp/jbstart

will dump all data to tape below /bnk; As all the transaction log data (bnk.jnl) data has already been dumped to tape prior to the backup, the
exclusion of this directory would seem appropriate, by configuring the data thus:

Directory Description

bnk Main directory, object code etc.

bnk.run Initial logon point

bnk.data Data files

bnk.dict File dictionaries

bnk.help On-line help files

bnk.jnl Transaction Journal

where bnk.jnl is not under the bnk directory structure.

NOTE

The use of the “-c” option will allow for the dumping of index files to avoid having to rebuild indexes on a restore process.

NOTE 2

Alternative backup mechanisms may be employed.

Once the backup has completed and verified, a new tape for tape logging replaces the last backup tape.

The logsets are switched, ready for any database updates.

Transaction logging to disk is re-enabled.

Database updates are enabled.

SYSTEM PROTECTION AND BENEFITS

The use of Transaction Journaling in this configuration allows for the recovery of transactions up to the point of failure. This configuration
provides assistance to the administrator in identifying those transactions which have not been written to tape prior to system failure. The tape
(set) contains a sequential history of database updates since the last backup.

SYSTEM RECOVERY PREPARATIONS

JBase - User Guide - Release R15.000 - Page 592 of 629


The administrator must ensure that a skeleton system save is made available. This skeleton system should contain:

• The operating system and configuration (device assignments, user login information, etc).

• A licensed copy of jBASE (configured as ready-to-run)

• This skeleton system must be kept up to date. Any changes to the operating system or jBASE configurations must be reflected in this skel-
eton system as a standard procedure; any such changes triggering the production of a new skeleton system.

SYSTEM RECOVERY AFTER FAILURE

If the operating system and/or jBASE is deemed corrupt or there has been a catastrophic disk failure, resulting in the loss of a disk, then the
system should be reconstructed as a skeleton system as discussed above. The details of this recovery are out of the scope of this document.

Once the system has been brought to an operational state, the database needs to be brought back to a known state. The last backup set pro-
duced is recovered by the recover_jbase script. This not only restores the jBASE database including saved indexes, but also replays all com-
pleted transactions which have been transferred to tape and initiates transaction logging to tape.

If there has been an application/database error which has resulted in the decision to perform a complete restore of the system, it is clear that if
the error can be identified to have taken place at a particular time, (whether precisely or approximately), then the whole of the transaction log
should not be replayed. Using the “end=timespec” option of jlogdup will cause the transaction log replay to terminate at the specified time
rather than the end of the logset. (See jlogdup section for valid format of timespec). The recover_jbase script will prompt for a time or assume
EOS (i.e. all the transaction log is to be replayed). As the

Warning: If an “end=timespec” parameter has been specified, then the time chosen may cause transactions which began before this time not to
be rolled back. Additional database updates pertaining to such transactions and bounded by the corresponding TRANSEND commands may
exist on the transaction log file, but will not be executed.

CLOSE OF BUSINESS PROCEDURES

This configuration, being a jBASE-only solution will allow for on-line backups to be taken prior to Close of Business procedures.

JBase - User Guide - Release R15.000 - Page 593 of 629


Cluster System – multiple application servers and a single database server

When clustering T24, two (at least) configurations can be utilised:

MULTIPLE APPLICATION SERVERS WITH A JBASE DATABASE SERVER

With this configuration, jBASE will be the sole database server. Communication between the application server(s) and the database server will
be by using jRFS within jBASE. This allows multiple application servers to have pointers/stubs as file definitions. These pointers/stubs ref-
erence files exist on the database server. jRFS mechanisms allow for the updating of the database through jRFS server processes from requests
made on the application servers. The implication of this is that each application server has no direct, individual database storage but shares
access to a central (jBASE) database. As there is only one database server, Transaction Journaling facilities will be available, using the same
mechanisms as the Stand-Alone system above.

MULTIPLE APPLICATION SERVERS WITH A NON-JBASE DATABASE SERVER

This configuration uses jBASE as a gateway to another DBMS (such as Oracle or DB2).

jBASE will handle any supported relational database connectivity (such as Oracle/DB2 etc.) through the appropriate jEDI driver. Data mapping
will be achieved through the corresponding RDBMS stub file definitions. The jBASE/RDBMS stub file definitions can exist on one of various
locations:

• On the Application Servers – this could (would) potentially create a locking minefield – how to communicate between the Application Servers
the locked state of the database entities.

• On the Database Server (1) – Application Servers communicate over NFS mounts to RDBMS stub files defined on the Database Server. The
downside of this approach is that RDBMS client components (at least) have to exist on each of the Application Servers. Also there is a problem
with managing database locks. This can be achieved by inefficient application-level lock mechanisms whereby the locks are held within a central
filesystem and are accessed by all Applications Servers, utilizing OS locks to manage access to the lock table.

JBase - User Guide - Release R15.000 - Page 594 of 629


• On the Database Server (2) – Application servers communicate using a jRFS driver to jRFS servers on the Database Server. The Database
Server contains the RDBMS stub file mappings to the RDBMS, also residing on the Database server. As jRFS operates in a client-server rela-
tionship, there are no locks taken directly by any process within the Application Servers, but are taken by the jRFS server processes, on their
behalf, running on the Database Server. As all the jRFS server processes run under control (for locking purposes) of a single jBASE server, there
is no issue with locking between these processes. There is also likely to be a cost advantage over Database Server (1) approach, because no
RDBMS components need to exist on the Application Servers.

• Transaction management (i.e. the use of TRANSTART, TRANSEND and TRANSABORT programming commands) within the Application Serv-
ers is handled within jBASE as for the Stand-Alone system.

Hot Standby database server


HOT STANDBY WITH A JBASE DATABASE SERVER

The Hot Standby configuration using jBASE as the database server has the same attributes as previously described in the Cluster Systems with
the exception that all database updates to jBASE are duplicated to a separate server (or remote in the case of disaster recovery). The database
duplication process, achieved by the jlogdup facility, would normally be an operation in addition to dumping the transaction log data to a local
tape device.

Operation of the Hot Standby Configuration


Transaction handling will be achieved by the use of TRANSTART, TRANSEND and TRANSABORT programming commands.

• jBASE transaction journaling will be used to record all database updates.

• The Transaction journal is copied to tape (or other external medium) on a continuous basis by means of the jlogdup facility.

• A backup of the database (using jbackup) is initiated each night at 12:01 am (for example) to the tape deck /dev/rmt/0 (for example).

• Logsets should be switched automatically following the backup.

• A jlogdup process will be initiated on the database server which will, in tandem with a corresponding jlogdup server process on the standby
server, transfer all transaction updates from the transaction log on the live cluster to the transaction log on the standby server.

JBase - User Guide - Release R15.000 - Page 595 of 629


Another jlogdup process on the standby server will take the updates from the previously transferred log files and update the database on the
standby server.

HOT STANDBY WITH A NON-JBASE DATABASE SERVER

If a backend RDBMS is configured then Hot Standby/disaster recovery is handled by the RDBMS; jBASE Transaction Logging is not used as
the recovery mechanisms are handled by the RDBMS. The RDBMS recovery mechanisms are outside of the scope of this document.

The updates contained within a transaction are cached until a TRANSABORT or TRANSEND command is executed for that transaction. No
RDBMS activity takes place when the TRANSABORT command is executed, whereas the TRANSEND can result in many RDBMS interactions
before success or failure is detected. The application code within T24 is unaware of the underlying backend database.

JBase - User Guide - Release R15.000 - Page 596 of 629


Scripts

setup_tj
#! /bin/ksh

export JBCRELEASEDIR=/data/colins/5.0_rels/jbcdevelopment

export JBCGLOBALDIR=/data/colins/5.0_rels/jbcdevelopment

export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH

jlogadmin -cf1,1,[logset1 directory]/logfile1

jlogadmin -cf1,2,[logset1 directory]/logfile2

jlogadmin -cf2,1,[logset2 directory]/logfile1

jlogadmin -cf2,2,[logset2 directory]/logfile2

jlogadmin -cf3,1,[logset3 directory]/logfile3

jlogadmin -cf3,2,[logset3 directory]/logfile3

start_tj
#! /bin/ksh

export JBCRELEASEDIR=/data/colins/5.0_rels/jbcdevelopment

export JBCGLOBALDIR=/data/colins/5.0_rels/jbcdevelopment

export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH

jlogadmin -l 1 -a Active

echo `date` > $JBCRELEASEDIR/logs/jlogdup_to_tape_start

jlogdup input set=current terminate=wait output set=serial device=[Device Spec] &

stop_tj
#! /bin/bash

export JBCRELEASEDIR=/data/colins/5.0_rels/jbcdevelopment

export JBCGLOBALDIR=/data/colins/5.0_rels/jbcdevelopment

export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH

jlogadmin –a Off

start_jlogdup

#! /bin/ksh

export JBCRELEASEDIR=/data/colins/5.0_rels/jbcdevelopment

export JBCGLOBALDIR=/data/colins/5.0_rels/jbcdevelopment

export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH

echo `date` > $JBCRELEASEDIR/logs/jlogdup_to_tape_start

jlogdup input set=current terminate=wait output set=serial device=[Device Spec]&

stop_jlogdup

#! /bin/ksh

export JBCRELEASEDIR=/data/colins/5.0_rels/jbcdevelopment

JBase - User Guide - Release R15.000 - Page 597 of 629


export JBCGLOBALDIR=/data/colins/5.0_rels/jbcdevelopment

export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH

jlogadmin -k* > discard

backup_jbase
#! /bin/ksh

export JBCRELEASEDIR=/data/colins/5.0_rels/jbcdevelopment

export JBCGLOBALDIR=/data/colins/5.0_rels/jbcdevelopment

export LD_LIBRARY_PATH=$JBCRELEASEDIR/lib:$LD_LIBRARY_PATH

typeset -u TAPEOUT

typeset -u REPLY

typeset -u BACKUPOK

set TAPEOUT = N

print -n "Are you backing up the logfiles to tape? (Y/N) "

while [ "$TAPEOUT" != Y -a "$TAPEOUT" != N ]

do

read TAPEOUT

done

if [ "$TAPEOUT" != N ]

then

print -n Has all logging to tape finished - press any key when it has

read REPLY

jlogadmin -k* >discard

print Logging to tape terminated

fi

if [ "$TAPEOUT" = Y ]

then

print Please remove the tape for logging and replace with the backup tape

set REPLY = N

while [ "$REPLY" != Y ]

do

print -n Enter Y to continue

read REPLY

done

fi

set BACKUPOK = N

while [ "$BACKUPOK" != Y ]

do

JBase - User Guide - Release R15.000 - Page 598 of 629


print Backup Started `date`

find /data/globus/jbbase13207/mbdemo.data -print | jbackup -v -c -f [Device Spec] -s /tmp/jbstart

print Waiting for tape to rewind

sleep 5

print Verify Started `date`:

jrestore -f [Device Spec] -P

print Verify Finished `date`

print -n "Backup successful <Y/N>"

read BACKUPOK

done

jlogadmin -l next -a Active

print logsets switched and logging to disk restarted

if [ "$TAPEOUT" = Y ]

then

print Mount a new tape for logging

print Enter any key to resume logging to tape

read INPUT

print `date` > $JBCRELEASEDIR/logs/jlogdup_to_tape_start

jlogdup input set=current terminate=wait output set=serial device=[Device Spec] &

print Logging to tape restarted

fi

recover_jbase
#!/bin/ksh

if [ -z "$1" ]

then

echo "\nWhat is the nature of the recovery :-\n"

PS3="Option :"

select Sel in "Full Restore Required" "Tape Logging Failure"

do break; done

if [ -z "$REPLY" ]

then

exit

fi

else

REPLY=$1

fi

if [ $REPLY = 1 ]

JBase - User Guide - Release R15.000 - Page 599 of 629


then

echo Put the first backup tape in the tape drive

echo -n Enter any key when ready

read DONE

jrestore -f [Device Spec] -N

echo -n Is a Transaction Log tape available ?

read REPLY

if [ $REPLY = "y" ]

then

echo Put the first log tape in the tape drive

echo -n Enter any key when ready

read DONE

echo -n "Enter a time to terminate the duplication process (or RETURN for all logs)"

read ENDTIME

if [-z $ENDTIME ]

then

jlogdup input set=serial device=[Device Spec] backup terminate=EOS output set=database

else

jlogdup input set=serial device=[Device Spec] end=$ENDTIME output set=database

fi

fi

else

echo Put a new tape in the tape drive

echo -n Enter any key when ready

read DONE

jlogdup input set=current start=$JBCRELEASEDIR/logs/jlogdup_to_tape_start terminate=wait output set=serial device=[Device Spec] &

fi

JBase - User Guide - Release R15.000 - Page 600 of 629


REMOTE.JOURNAL.STARTUP
find /JBASE_APPS /JBASE_SYSFILES /JBASE_ACCOUNTS –print | jbackup –s /tmp/jbstart –v –c | rsh Nodek –l jbasesu jrestore –N

JBase - User Guide - Release R15.000 - Page 601 of 629


Transaction Journaling Utilities

jlogadmin
The jlogadmin command allows for the administration of the jBASE Transaction Journal. The jlogadmin command will enabled for interactive
usage when invoked by the super-user/Administrator; execution by other users being restricted to read-only. All administration tasks con-
tained within the jlogadmin utility can also be invoked from the command line, using jlogadmin, with optional parameters.

When the jlogadmin command is executed interactively, navigation to the next field is by using the tab key or cursor-down key and to the pre-
vious field by the cursor-up key. Each field can be modified using the same editor type commands as available in jsh. Changes to a particular
field are effected by the <Enter> key and CTRL-X is used to exit from interactive mode.

Interactive Configuration
INTERACTIVE DISPLAY

The first execution of jlogadmin will display the following screen:

Description of Fields
STATUS

Specifies the current transaction journal status, which can be On/Active, Off/Inactive or Susp/Suspended. Note: When the status is changed to
Suspended, all transactions which would be updated in the transaction log file will also suspend awaiting a change of status.

CURRENT SWITCHED LOG SET

Specifies the current log set in use. There are four possible log sets – numbered 1 to 4. An entry of 0 indicates that no log set has been chosen
at this time.

EXTENDED RECORDS

Specifies additional information:

• the application id

• the TTY name

• the login name

TIME BETWEEN LOG FILE SYNCS:

Specifies the number of seconds between each synchronization of the log set with the disk; All memory used by the log set is force flushed to
disk. Should the system crash, the maximum amount of possible data loss is limited to the updates which occurred since the last log set syn-
chronization.

Log notify program:

JBase - User Guide - Release R15.000 - Page 602 of 629


This specifies the program to execute when the warning threshold of the log set is reached. The log notify program is called every time a mes-
sage is written to jediLoggerAdminLog. The text of the message can be captured by adding arguments to the command line which the notify pro-
gram can examine using SENTENCE(). For example, possibly define the program as:

/usr/admin/bin/lognotify '%1' '%2' '%3'

In addition, when the program is loaded, the following are substituted:

%1 == {INFORMATION: | WARNING: | FATAL ERROR:} From user root at Wed Sep 04 12:38:23 2002

%2 == Process ID 12345, Port 23, tty /dev/pts/03

%3 == Depends upon the actual error message e.g. "Error number nnn while reading from file /dev/xxxxx"

NOTE: The message is designated INFORMATION, WARNING or FATAL ERROR. This designation can be used by the log notify program to
decide on a course of action. The messages that can be logged are:

Type Message StdOut

INFORMATION Log set changed to s Yes

Log set s truncated Yes

File f for log set s REMOVED Yes

File f for log set n changed to newfilename Yes

n files imported to log set n (see -i option) Yes

Status of logger set to status (current log set s) Yes

Sync count changed from every n1 seconds to every n2 seconds Yes

Log file warning threshold set to p initial percentage thereafter every additional q percent or n seconds Yes

Admin. Log Notify Program now set to program Yes

Admin. Log Notify Program REMOVED Yes

Extended Record Status now set to on|off Yes

Log set switch detected was set n1 now set n2 No

Kill initiated on jlogdup process id pid : Process id pid from port n Yes

First record read from set n Yes

Termination Statistics: usr x ,sys y, elapsed z, r records read from current log set number n : r records b blocks Yes
rb record bytes e errors in file

WARNING Journal Log Files now at p% capacity No

FATAL ERROR Unable to open logger configuration file filename Yes

Sync demon appears to have died prematurely Yes

Error number errno while reading from file filename No

Error number errno while writing to log file No

Error errno while writing to log journal file filename" Yes

Error errno while writing to log journal Yes

JBase - User Guide - Release R15.000 - Page 603 of 629


Unable to open logger file filename Yes

Out of memory to log update Yes

WARNING THRESHOLD

If the amount of space consumed in the file system, which the active logset resides upon, exceeds the specified threshold, it runs the log notify
program. Individual files in a logset have a capacity of 2GB. If the logsets are not switched, files in a logset can grow to the 2GB limit without
the file system reaching the threshold capacity. If this happens, journaling will cease to function predictably and normal database updates may
fail.

File definitions:

As indicated above, the maximum size of an individual file is 2GB. It is clear that if a single file were used for the log file, then this would likely
be insufficient for most realistic application environments. Therefore the administrator is able to set up a log set consisting of a maximum of
sixteen files, thus enabling a maximum log set of 32GB. The configuration will allow for a maximum of four log sets. Usage and switching of the
four log sets will be described in appropriate sections. If the file specified by the administrator does not already exist, then it will be created
automatically.

COMMAND-LINE SYNTAX

In addition to the interactive screen setup facility, there are options which can be added to the jlogadmin command execution. This allows the
administrator to create scripts which can be run either at pre-defined times or intervals; or in response to transaction journal events (usually
error handling events).

The command is invoked by the following:

jlogadmin –{options}

Where {options} are identified below:

SYNTAX ELEMENTS

Option Description

-a status Set status On/Active

Off/InActive or Susp/Suspend

-c Create file in log set if does not exist. ( use with -f )

-d set Delete files from logset n. Note: This option may not be combined with others

-e, set, file- s Archive files from logset n to folder/path filepath


path

-f set, Change log filename in log set where


fileno, file

Set log set

Fileno File number

File File name

-h Display help

-i [1-4]file- filename{
name...} {-
o}

JBase - User Guide - Release R15.000 - Page 604 of 629


Import a log set to override one of the 4 standard log sets. The -o argument is optional. If used it suppresses the warning and
confirmation message. You can specify up to 16 filenames to define the imported log set.

-k pid | * | ? Kill jlogdup process ‘pid’ or ‘*’ all or ‘?’ to list.

-l num | Switch to log set where


next | eldest

Num log set number 1-4

Next next sequential log set

Eldest earliest log set

-n program Set threshold notify program.

-o Perform operation without checking if the specified log set is empty. Used with -f and -t.

-s secs Set synchronization period.

-tn Truncates log set n. The log set may not be the current switched set. This option ensures that disk space will be freed and is
sometimes preferable to "rm" which may not free the disk space if any process still has log files open.

-w pp, ii, ss Set threshold where

Pp initial warning percent

Ii every percent after initial percent

Ss every second after initial percent

-x status Set extended log record ON or OFF

-C Clear transaction journal administration log file jediLoggerAdminLog.

-I path Display statistics of logset from information embedded in file at path

-V View transaction journal administration log file jediLoggerAdminLog.

-XON Disable storage of record/file path details in TRANSEND

-XOFF Enable storage of record/file path details in TRANSEND

-Znn Enables TJ log compression, where ‘nn’ stands for the threshold of TJ WRITES in bytes

Embedded Logset Information – (Release 4.1.5 onwards)


When logfiles are specified within the jBASE Transaction Journaling, information about their contents is stored in the file jediLoggerConfig in
the $JBCRELEASEDIR/config directory. In order to archive logsets, statistics about their contents needs to be archived along with the files.
This feature enables logset information to be embedded within the first file of the logset. Thus, when the logfiles are archived, the statistical
information will be archived too.

Prior to archiving a logset, jlogstatus –av will display “Not Archived” for each logset which has not been archived.

Archiving is achieved by the command e.g.:

jlogadmin -e 1,/home/tjarch

If the logset is currently active , an error message will be displayed thus:

Error! Attempting to archive the current set

JBase - User Guide - Release R15.000 - Page 605 of 629


After this command, jlogstatus –v will contain additional information about the logset e.g.

Status log set 1: 2 files , 56 records , 12177 bytes used

Date range 11:43:56 14 SEP 2005 to 11:44:47 14 SEP 2005

Archived on 11:44:49 14 SEP 2005

Archive Location /home/tjarch

Information about the archived information is obtained by the command e.g. :

jlogadmin -I /home/tjarch/logdev1

Log Set Statistics:

2 files , 56 records , 12177 bytes used

Date Range 12:13:05 14 SEP 2005 to 12:15:16 14 SEP 2005

Archived on 12:15:18 14 SEP 2005

Archive Location /home/tjarch

Files:

/home/tjarch/logdev1

/home/tjarch/logdev2

During recovery procedures this command may be used to determine the correct logset to be restored. The embedded statistical information
contained within the first file of the import specification will be used to update information in the jediLoggerConfig file, so that subsequent log-
set manipulation may proceed accurately.

jlogstatus
The jlogstatus command displays the status of the jBASE Transaction Journal. In its simplest form the jlogstatus, command shows a summary
of the current Transaction Journal activities. Additional command line options are available for output that is more verbose. The jlogstatus
command can also be used to present a rolling status screen, using the ‘-r n’ option, which will update the display every ‘n’ seconds.

SYNTAX

jlogstatus -options

SYNTAX ELEMENTS

Option Description

-a display all available information

-c display current log information

-d display jlogdup process information

-g display general information

-h display help

-l display all Log files information in summary mode

-r nn set display to repeat every nn seconds

-v verbose mode

JBase - User Guide - Release R15.000 - Page 606 of 629


EXAMPLE

jlogstatus -a –v –r 5

This will display all information and will refresh every 5 seconds.

Journal status: active

Configuration file created: 10:39:00 08 APR 1998 , by root from port 9

Configuration file modified: 10:47:55 08 APR 1998 , by root from port 9

Journal file sets switched: 10:41:21 08 APR 1998 , by root from port 9

Full log warning threshold: 70 percent , thereafter every 1 percent or 300 secs

Journal files synced every: 10 seconds , last sync 10:49:59 08 APR 1998

Background sync demon: (inactive)

Extended record: OFF

Admin log file: 10 entries , in file /usr/jbc/config/jediLoggerAdminLog

Admin log notify program: (undefined)

Current log file set: 1, date range 10:41:21 08 APR 1998 to 10:49:59 08 APR 1998

/home/jbasedev/fb1: 76.92% capacity

/home/jbasedev/fb2: 76.92% capacity

Total record count: 97.66k , 0 records/second

Total byte count: 19.47M , 0 bytes/second

jlogdup program status: NONE active

Status log set 1 (current): 2 files, 100000 records , 20415568 bytes used

Date range 10:41:21 08 APR 1998 to 10:49:59 08 APR 1998 Status log set 2:

No files defined Status log set 3:

No files defined Status log set 4:

No files defined Status log totals:

2 files, 100000 records, 20415568 bytes used Date range 10:41:21 08 APR 1998 to 10:49:59 08 APR 1998

JBase - User Guide - Release R15.000 - Page 607 of 629


jlogsync
When a jBASE application performs a database update, it writes to the transaction log file (if active). It does this to a memory image and nor-
mally it is up to the platform file system to flush the memory image to disk every so often, by default on most platforms this is usually every
minute.

You can use options in jlogadmin so that the jBASE processes themselves do this file synchronization more often. The default is every 10
seconds. This means in the event of a system failure, you will lose at the most 10 seconds worth of updates.

The use of the jlogsync program means the jlogsync process instead of individual jBASE processes performs file synchronization. Therefore alle-
viates the overhead of the synchronization from the update processes. Thus, the jlogsync process is not mandatory. However, in a large install-
ation it may provide beneficial performance gains.

SYNTAX

jlogsync -options

SYNTAX ELEMENTS

Option Description

-b run in the background (normal operation)

-d display jlogsync demon status

-i initialize and become the jlogsync demon

-k kill the jlogsync demon

-t nn Inactivity timeout period (seconds) for detecting jlogsync being killed

-v verbose mode

-S force synchronization now

JBase - User Guide - Release R15.000 - Page 608 of 629


jlogdup
The jlogdup command provides the capability to duplicate transaction log set data from the jBASE Transaction Journal. Use this command to
duplicate transaction log data to or from any platform file, including device files, standard input, ‘stdin’, and standard output, ‘stdout’.

SYNTAX

jlogdup -Options INPUT input_spec OUTPUT output_spec

SYNTAX ELEMENTS

Option Description

-e file error file for database update errors

-f used with the -v or -V option; shows information for the next (future) update; by default information for past updates is displayed

-h display help

-l file log file to write all status and errors information

-m nn maximum number of errors (default 10000)

-u nn display '*' every nn input records

-v verbose mode, 1 line per record

-x exclusive use of the database, no group locks taken

-H display verbose help screen

-V Very verbose output, also 1 line per record

INPUT_SPEC/OUTPUT_SPEC

The input/output specification can specify one or more of the following parameters

Parameter Description

blockmax=nnn (S) the maximum size, in blocks, of a serial device

blocksize=nnn the block size to read/write to TTY/SERIAL device or file

device=file%dev (S) the file name for SERIAL device. Can be more than one

encrypt=true(O) Output transfer is to be encrypted

end=timespec (I) time in log set at which to stop restore/duplication

hostname=host(IOK) Host for socket transfers to / from

key=encryptkey The key to use for encryption

noflush=true (O) suppress flush of output at end of transaction. (default false)

notrans=true (O) ignore transaction boundaries. (default false)

port=portnum (IOK) Socket port to use for socket transfer

JBase - User Guide - Release R15.000 - Page 609 of 629


prompt=true prompt when switching serial devices or files

rename=from,to convert path name directories ‘from’ to ‘to’ on restore

renamefile=file (O) use rename file list of format ‘from,to’ to rename files

retry=nn (I) specifies the interval between retries, when 'terminate=wait'

scheme=method Encryption method

set=current (IL) begin restore/duplication using the current log set as input

set=database (OD) output is to the database, i.e. Restore mode

set=eldest (IL) begin restore/duplication using the eldest log set

set=n (ILN) begin restore/duplication using log set number n

set=null (O) output is to be discarded

set=serial (S) input/output is to a serial device or file. Requires ‘device=’

set=socket (IOK) Input/output is to a socket. Requires “hostname=” and “port=”

set=stdin (IT) the input data comes from the terminal stdin

set=stdout (OT) the output data is directed to the terminal stdout

set=tty (T) the input is from stdin or the output is to stdout

set=logset (OL) the output is directed to the current log set as an update

start=timespec (I) time in log set at which to start restore/duplication

terminate=eof (I) terminate restore/duplication at eof of eldest log set

terminate=eos (I) terminate restore/duplication at end of current log set

terminate=wait (I) switch to elder log sets as required and wait for new updates

timeout=nnn (I) timeout period in seconds for ‘terminate=wait'

verbose=true display to stderr a summary of the specification

compress=true Output transfer is to be compressed

The indicators in brackets denote:

Indicator Meaning

D specification valid for type database

I specification valid for type input

K specification type for socket

O specification valid for type output

L specification valid for log set

N specification valid for type of null

S specification valid for type serial

T specification valid for type terminal

JBase - User Guide - Release R15.000 - Page 610 of 629


TIMESPEC

The time specification, used in the ‘start=’ and ‘end=’ specification can be one of the following formats:

timespec meaning

hh:mm:ss time of day (todays date assumed)

DD-MMM-YYYY date (midnight assumed), Any date convention accepted

hh:mm:ss,DD-MMM-YYYY both time and date specified either way around

jbackup_file time of file created. Use with 'jbackup -sfilename' option

filename regular file, use the time the file was last modified

HOST

The IP address or the DNS name of the host to use for socket transfers

PORTNUM

The TCP port to use for socket transfers.

KEY

The string to be used as the encryption key for the transfer of journal entries.

METHOD

The encryption scheme to use for the transfer of journal entries. This mechanism utilizes OpenSSL high level cryptographic functions. The valid
specifications for encryption are;

• RC2

• BASE64

• DES

• 3DES

• BLOWFISH

• RC2_BASE64

• DES_BASE64

• 3DES_BASE64

• BLOWFISH_BASE64

JBase - User Guide - Release R15.000 - Page 611 of 629


jlogmonitor
SYNTAX

jlogmonitor {-h|?} {-ccmd} {-Cnn} {-Dnn} {-E} {-Inn) {-Snn}

SYNTAX ELEMENTS

Option Description

-ccmd The command cmd is executed when an error occurs.

-Cnn If the file system utilization of the journal log exceeds nn% full then an error message is displayed. The error message is repeated
for every 1% increase in file system utilization.

-Dnn If the jlogdup process processes no records (or if there is no jlogdup process active), then after nn minutes of inactivity it displays
an error message. It repeats the error message every nn minutes while the jlogdup process(es) is inactive.

-E If the jlogdup program reports an error, this option causes jlogmonitor to also display an error. You can view the actual nature of
the error by either looking at the screen where the jlogdup process is active, or by listing the jlogdup error message file (assuming
the –eERRFILE option was used).

-h display help

-lnn The status of the Journaler can be ACTIVE, INACTIVE or SUSPENDED. If the status of the journaler is either INACTIVE or
SUSPENDED (with jlogadmin) for more than nn minutes, it s=displays an error message. The error message will be repeated every
nn minutes that the journaler is not active

-Snn Use this option to determine if any updates are being applied to the journal logs. If no updates are applied to the current journal
log set for nn minutes it displays an error message. It repeats the error message for every nn minutes of system inactivity.

NOTES

You must specify at least one of the options, -C, -D, -E, -I or -S.

EXAMPLE

jlogmonitor –c"MESSAGE * %"

The command "MESSAGE * %" is executed for every message sent to the screen by jlogdup. The jlogmonitor specially interprets the use of the
% by the program and will be replaced with the error message.

JBase - User Guide - Release R15.000 - Page 612 of 629


ODBC

What is ODBC?

Open Database Connectivity (ODBC) is an open standard Application Programming Interface (API) for accessing a database. By using ODBC
statements in a program, you can access files in a number of different common databases. In addition to the ODBC software, a separate module
or driver is needed for each database to be accessed

The architecture of ODBC-based data connectivity is as follows.

jBASE ODBC Connector

jAgent on jBASE Database Server

ODBC Enabled Application


This is any ODBC compliant application, such as Microsoft Excel, Crystal Reports, Microsoft Access, or similar application (Spreadsheet,
Word processor, Data Access & Retrievable Tool, etc.).

ODBC Driver Manager

The ODBC Driver Manager loads and unloads ODBC drivers on behalf of an application. It is a system component which on Windows is part of
the MDAC (Microsoft Data Access Components) package and automatically included with the latest Windows operating systems. Odb-
cad32.exe is the ODBC Data Source Administrator and odbc32.lib/ odbccp32.lib are import libraries to be used by client applications.

JBase - User Guide - Release R15.000 - Page 613 of 629


A jBASE specific driver manager is shipped with the jBASE ODBC package. This driver manager provides a command line interface to configure
jBASE ODBC

ODBC Driver
The ODBC driver processes ODBC function calls, submits SQL requests to a specific data source and returns results to the application. The
ODBC driver may also modify an application’s request so that the request conforms to syntax supported by the associated database.

In case of jBASE, we have got a driver called jBASE ODBC Connector which is an ODBC 3.0 compliant ODBC driver that works with most
existing ODBC-compliant applications such as MS Excel, MS Access, Crystal Reports, etc. The ODBC Connector is only available to Windows
platforms but SQL requests may be issued against a remote jBASE instance running on other platforms.

Data Source
The data source consists of the data the user wants to access and its database management system. This can be relational databases like
Oracle, DB2 or non-relational databases like jBASE.

JBase - User Guide - Release R15.000 - Page 614 of 629


JBase - User Guide - Release R15.000 - Page 615 of 629
Setting up jBASE ODBC

JBase - User Guide - Release R15.000 - Page 616 of 629


System Requirements

The jBASE ODBC Connector is supported on the following platforms:

l 32-bit Windows Operating Systems(x86)


l 64-bit Windows Operating Systems(x64)

The following system components must be installed prior to installing the ODBC Connector:

l Visual C++ runtime components - version 8.0.50727.762 or higher

These runtime libraries can be downloaded from Microsoft and are supplied with the following package:

Visual C++ 2005 SP1 Redistributable Package (x86 / x64)

Note: These runtime components are already included in Microsoft .NET Framework 2.0 SP1 or higher

JBase - User Guide - Release R15.000 - Page 617 of 629


Installer Package
The jBASE ODBC Connector is included in TAFC but may also be deployed on Windows operating systems which do not have TAFC installed.
A self-contained installer (mentioned as ODBC installer) is available which installs and registers the jBASE ODBC driver. These are the list of
release packages containing the jBASE ODBC Connector.

l 32-bit Windows TAFC ( from R09 onwards)


l 32-bit Windows ODBC Installer
l 64-bit Windows TAFC ( from R12 onwards)
l 64-bit Windows ODBC Installer

JBase - User Guide - Release R15.000 - Page 618 of 629


Installing the driver
The jBASE ODBC installer will automatically register the jBASE ODBC driver and ODBC Setup libraries. The registration process is required to
inform the ODBC Manager about the location of the ODBC driver libraries. The jBASE ODBC installer will also add the installation directory to
the global user environment variable PATH. This is necessary since the jBASE ODBC driver depends on other shared libraries as e.g. TAFC
JCF, ACE, etc.

Start the installation by executing jodbc32.msi. Follow the instructions on the installation wizard and complete the installation.

If the installation is successful, a new entry,’ jBASE ODBC Driver’ will appear in the drivers list.

JBase - User Guide - Release R15.000 - Page 619 of 629


jBASE ODBC Manager
The jBASE ODBC Driver can also be installed using the jBASE ODBC Manager utility. This command line utility provides various functions like
registering the ODBC driver, creating DSNs, testing connection to data sources, configuring DSNs, etc ( use jODBCManager.exe –h to list all
the available functions)

Use the following commands to install jBASE ODBC driver through jBASE ODBC Manager

For 32bit jBASE ODBC driver:

jODBCManager.exe -i -driver="C:\WINDOWS\sysWOW64\jodbc.dll" - setup="C:\WINDOWS\sysWOW64\libjODBCSetup.dll"

For 64bit jBASE ODBC driver:

jODBCManager.exe -i -driver="C:\WINDOWS\system32\jodbc.dll" -setup="C:\WINDOWS\system32\libjODBCSetup.dll"

Configuring DSN
ODBC applications usually obtain the connection details from DSNs which may be configured via Microsoft’s ODBC Data Source Administrator
(also known as ODBC Manager / odbcad32.exe or Control Panel à Administrative Tools à Data Sources (ODBC)). Use the following steps to
add a DSN for jBASE connectivity

JBase - User Guide - Release R15.000 - Page 620 of 629


Step 1:

Click ‘Add’ in the ODBC Data Source Administrator, select ‘jBASE ODBC Driver’ and click ‘Finish’

Step 2:

The jBASE ODBC data source windows will pop-up, specify the DSN name & Connection details

JBase - User Guide - Release R15.000 - Page 621 of 629


.

Parameter Use

Server   IPAddress/hostname of the machine on which the jBase_agent/tafc_agent is running.

Port  Port number on which the jBase_agent/tafc_agent is listening.

User    User login ID

Password Login Password

Step 3:

Start the jbase_ agent/tafc_agent on the jBASE Server machine to listen on the port defined in the last step. Use the ‘test’ button to see if the
connection can be established from the client machine to the jBASE Server.

JBase - User Guide - Release R15.000 - Page 622 of 629


JBase - User Guide - Release R15.000 - Page 623 of 629
Extracting Data from jBASE Server
You can extract data from jBASE server using any ODBC compliant application, such as Microsoft Excel, Crystal Reports, Microsoft Access,
etc. When MS Excel is used, following steps are to be used.

Step 1:

In MS Excel, navigate to Data->From Other Sources and select ‘From Microsoft Query’,

Step 2:

Select the DSN that was created earlier, and click OK.

JBase - User Guide - Release R15.000 - Page 624 of 629


Step 3:

You will see all the jBASE tables available in the current directory where jBASE_Agent is running. Select the file / table from which the data
need to be imported. Also select the fields of the table that are to be exported.

JBase - User Guide - Release R15.000 - Page 625 of 629


Step 4:

Identify a field that should be used for sorting, and specify the same in the ‘Sort by’ option. Select ‘Next’ and click on ‘Finish’

JBase - User Guide - Release R15.000 - Page 626 of 629


Step 5:

Select ‘OK’ on the ‘Import Data’ dialog box to produce the output in Table format. You will see the jBASE table data exported and displayed in
excel.

JBase - User Guide - Release R15.000 - Page 627 of 629


JBase - User Guide - Release R15.000 - Page 628 of 629
Additional Connection Properties
In R12, two additional properties are included in jBASE ODBC driver. They are

l Timeout
l Env.Variables

Timeout: To set the connection timeout for jAgent running on jBASE Server. If this property is not set, the default connection timeout of
jAgent will be used.

Env.Variables: To set the JEDIFILEPATH on jBASE Server. This will help us to query any table available in the specified path. By default, the
query looks for tables / files in the default JEDIFILEPATH or the tables / files in the current directory, where jAgent is running.

These properties can be defined using the DSN configuration options in ODBC Data Source Admin.

JBase - User Guide - Release R15.000 - Page 629 of 629

You might also like