Show/Hide Toolbars

XSharp

NoteThis command is defined in a header file and will be preprocessed by the X# preprocessor to a function call. If you disable the standard header (-nostddefs) files then this command will not be available. If you tell the compiler to use a different standard header file (-stddef ) then this command may also be not available

Purpose

Produce a new database file with the field definitions taken from the contents of a structure-extended file.

Syntax

CREATE <xcTargetFile> FROM <xcSourceFile> [NEW] [ALIAS <xcAlias>] [VIA <cDriver>]

Arguments

<xcTargetFile>The name of the target database file to create, including an optional drive, directory, and extension. After the file is created, it remains open in the mode specified by the SetExclusive() flag for the work area.
 
If <xcTargetFile> does not exist, it is created. If it exists, this command attempts to open the file in exclusive mode and, if successful, the file is overwritten without warning or error. If access is denied because, for example, another process is using the file, NetErr() is set to TRUE.  

 

<xcSourceFile>The name of a structure-extended file to use as the structure definition for the new database file, including an optional drive, directory, and extension.
 
If <xcSourceFile> does not exist, a runtime error is raised. If it exists, this command attempts to open the file in shared mode and, if successful, it proceeds. If access is denied because, for example, another process has exclusive use of the file, NetErr() is set to TRUE.  
 
See SetDefault() and SetPath() for file searching and creation rules. The default extension for database files is determined by the RDD.
 
To qualify as a structure-extended file, the structure of the database file must be the same as the structure generated by COPY STRUCTURE EXTENDED, which you can refer to for more details.
 
Note: For data dictionary applications, you can have additional fields within the structure-extended file to describe the extended field attributes. For example, you can have fields to describe such field attributes as a description, key flag, label, color, picture, and a validation expression for the VALID clause. CREATE FROM creates the new database file from the required fields only, ignoring all other fields in the extended structure. Moreover, it is not sensitive to the order of the required fields.

 

NEWSelects the next unoccupied work area before opening <xcTargetFile>. If this clause is not specified, the current work area is used.

 

ALIAS <xcAlias>An identifier name to associate with the work area when <xcTargetFile> is opened. If this clause is not specified, the alias defaults to the database file name. Duplicate alias names are not allowed within a single application.

 

VIA <cDriver>The name of the RDD that will service the work area. If not specified, the default RDD as determined by RDDSetDefault() is used.

Notes

Character field lengths greater than 255: There are two methods for creating a character field with a length greater than 255 digits:

       Specify the field length using both the Field_Len and Field_Dec fields according to the following formulation:

       _FIELD->Field_Len := <nLength> % 256

       _FIELD->Field_Dec := Integer(<nLength> / 256)

 

       Modify the structure of the structure-extended file by changing the length of Field_Len to 5, then specify the actual field length.  

Examples

This example is a procedure that simulates an interactive CREATE utility:

 

FUNCTION Start()
 CreateDatabase("newfile")
 
FUNCTION CreateDatabase(cNewDbf)
 // Create empty structure-extended file
 CREATE tmpext
 USE tmpext
 lMore := TRUE
 DO WHILE lMore
         // Input new field definitions
         APPEND BLANK
         CLEAR
         @ 5, 0 SAY "Name.....:  " GET Field_Name
         @ 6, 0 SAY "Type.....:  " GET Field_Type
         @ 7, 0 SAY "Length...:  " GET Field_Len
         @ 8, 0 SAY "Decimals.:  " GET Field_Dec
         READ
         lMore := (!EMPTY(Field_Name))
 ENDDO
 
 // Remove all blank records
 DELETE ALL FOR EMPTY(Field_Name)
 PACK
 CLOSE
 
 // Create new database file
 CREATE (cNewDbf) FROM tmpext        
 ERASE tmpext.dbf

 

The next example creates a new definition in a structure-extended file for a character field with a length of 4000 characters:

 

APPEND BLANK
REPLACE Field_Name WITH "Notes",;
 Field_Type WITH "C",;
 Field_Len WITH 4000 % 256,;
 Field_Dec WITH INTEGER(4000 / 256)

Assembly

XSharp.RT.DLL

See Also

COPY STRUCTURE, COPY STRUCTURE EXTENDED, CREATE, DbCopyXStruct(), DbCreate(), RDDSetDefault(), SetDefault(), SetExclusive(), SetPath()