External Function Summary

Total Page:16

File Type:pdf, Size:1020Kb

External Function Summary APPENDIX I External Function Summary Conditional Logic Functions FBUDF INULLIF (VALUE1, VALUE2) Linux, Win32 Returns NULL for a sub-expression if it resolves to a non-null value; otherwise, returns the value of the sub-expression. Applicable to flxed numeric types only and should be used only with Firebird l.O.x. With Firebird 1.5 and higher, use internal function NULLIF( ). Arguments valuel: The column or expression that is tobe evaluated. value2: A constant or expression with which valuel is to be compared. Ifthere is a match, the iNulllf expressionwill return NULL. Return value Will be NULL if valuel and value2 resolve to a match; if there is no match, then value l is returned. Notes iNulllf( ) has an effect equivalent to using the internal SQL function NULLIF(), implemented in Firebird 1.5 and higher, with flxed numeric types. The iNulllf() external function comes in three implementations: two for 32-bit and 16-bit types (inullif and dnullif), the other for 64-bit types (i64nullif). Ifyou wanttobe able to use it with any flxed numeric type, declare all implementations. The declarations can be found in the script fbudf.sql, in the /UDF directory ofyour Firebird installation. Do not declare the i64nullif implementation in any database that does not support 64-bit numeries-in an unported InterBase 5 database, for example. Example This Statement will cause the STOCK value in the PRODUCTS table to be set to NULL on all rows where it is currently stored as 0: UPDATE PRODUCTS SET STOCK = iNULLIF(STOCK, o) Related or similar See also NULLIF( ), sNulllf( ). functions 881 Appendix! FBUDF INVL(VALUE1, VALUE2) Linux, Win32 This function attempts to mirnie the NVL( ) function of Oracle, for fiXed numerie types only. It will cause a specified non-null value tobe output if the column is actually storing a NULL. Arguments valuel: A column or expression involving a column. Floating-point typesarenot supported. Ifnecessary, use CAST() in your expression to transform the value to a numeric type. value2: An expression or constant that will resolve to the value which is to be output if value 1 resolves to NULL. Return value A non-null value. If valuel is not null, it is returned; otherwise, value2 is returned. Ifboth valuel and value2 resolve to NULL, then NULL is returned. Notes Logically, this function is equivalent to the simple form ofthe v.l.5 COALESCE( ) function when used with a column of a fixed numerie type, namely COALESCE(valuel, value2). It should be regarded as deprecated for versions of Firebird from 1.5 onward. The iNVL() external function comes in three implementations: two for 32-bit and 16-bit types (invl and dnvl), the other for 64-bit types (i64nvl). Ifyou wanttobe able to use itwith anyfixed numeric type, declare all implementations. The declarations can be found in the script tbudf.sql, in the /UDF directory ofyour Firebird installation. Do not declare the i64nvl implementation in any database that does not support 64-bit numeries-in an unported InterBase 5 database, for example. Example The following query outputs 0 if STOCK is NULL: SELECT PRODUCT_ID, PRODUCT_NAME, INVL(STOCK, o) FROM PRODUCTS; Related or similar See also sNVL( ), iNulllf( ), internal function COALESCE( ). functions FBUDF SNULLIF (VALUE1, VALUE2) Linux, Win32 Returns NULLfora sub-expression ifit resolves to a non-null value; otherwise, returns the value of the sub-expression. Applicable to character types only and should be used only with Firebird l.O.x. With Firebird 1.5 and higher, use NULLIF(). Arguments valuel: The column or expression that is tobe evaluated. value2: A constant or expression with which valuel is to be compared. If there is a match, the sNulllf expression will return NULL. 882 External Function Summary FBUDF SNULLIF (VALUE1, VALUE2) (continued) Return value Will be NULL if valuel and value2 resolve to a match. If there is no match, then valuel is returned. Notes sNullif() has an effect equivalent to using the internal SQL function NULLIF( ), implemented in Firebird 1.5 and higher, with character types. Example This query will set the column IS_REGISTERED to NULL in all rows where its value is 'T' and REGISTRATION_DATE is NULL: UPDATE ATABLE SET IS_REGISTERED = SNULLIF(IS_REGISTERED, 'T') WHERE REGISTRATION_DATE IS NULL; Related or similar See also iNulllf( ). For Firebird 1.5 and higher, see internal function functions NULLIF(). FBUDF SNVL(VALUE1, VALUE2) Linux, Win32 This function attempts to mirnie the NVL() function of Oracle, for character types only. It will cause a specified non-null value to be output if the column is actually storing a NULL. Arguments valuel: A column or expression involving a column. value2: An expression or constant that will resolve to the value that is to be output if valuel resolves to NULL. Return value A non-null value. If valuel is not null, it is returned; otherwise, value2 is returned. If both valuel and value2 resolve to NULL, then NULL is returned. Notes Logically, this function is equivalent to the simple form of the v.l.5 COALESCE() function when used with a column of a character type, namely COALESCE(valuel, value2). sNVL( ) should be regarded as deprecated for versions of Firebird from 1.5 onward. Example The following query calculates and outputs a runtime column, BIRTH_yEAR, for each student. Where this value resolves to NULL, the string "Not known" is output instead: SELECT FIRST_NAME, LAST_NAME, SNVL(CAST(EXTRACT(YEAR FROM BIRTH_DATE) AS VARCHAR(9)), 'Not known') AS BIRTH YEAR FROM STUDENT_REGISTER; Related or similar See also iNVL( ) , sNulllf(), internal function COALESCE( ) . functions 883 Appendix! Mathematical Functions IB_UDF ABS{VALUE) Linux, Win32 Returns the absolute value of a number. Arguments value is column or expression that is compatible with a signed or unsigned DOUBLE PRECISION NUMBER. Return value A DOUBLE PRECISION number. Example This statementwill calculate a total of values that are negative and return it as a positive value: SELECT ABS(SUM(ASSET_VALUE)) AS LIABILITY FROM ASSET REGISTER WHERE ASSET_VALUE < o; Similar function See f_DoubleAbs( )-another external function that performs the sametask. IB_UDF BIN_AND{VALUE1, VALUE2) Linux, Win32 Returns the result of a bitwise AND operation performed on the two input values. Arguments valuel and value2 are columns or expressions that evaluate to SMALLINT or INTEGER type. Return value An INTEGER number. Example SELECT BIN_AND(128,24) AS ANDED RESULT FROM RDB$DATABASE; IB_UDF BIN_OR{VALUE1, VALUE2) Linux, Win32 Returns the result of a binary (bitwise) OR operation performed on the two input values. Arguments valuel and value2 are columns or expressions that evaluate to SMALLINT or INTEGER type. Return value An INTEGER number. Example SELECT BIN_OR(128,24) AS ORED_RESULT FROM RDB$DATABASE; IB_UDF BIN_XOR{VALUE1, VALUE2) Linux, Win32 Returns the result of a binary (bitwise exclusive or) XOR operation performed on the two input values. Arguments valuel and value2 are columns or expressions that evaluate to SMALLINT or INTEGER type. 884 Externat Function Summary IB_UDF BIN_XOR(VALUE1, VALUE2) (continued) Return value An INTEGER number. Example SELECT BIN_XOR(128,24) AS EXORED_RESULT FROM RDB$DATABASE; IB_UDF CEILING(VALUE) Linux, Win32 Returns a DOUBLE PRECISION value representing the smallest integer that is greater than or equal to the input value. Arguments value is a column or expression that evaluates to a number of DOUBLE PRECISION type. Return value A DOUBLE PRECISION number with a zero decimal part. Example SELECT CEILING(LAST_TOTAL) AS ROUND_UP_NEAREST FROM SALES_HISTORY; IB_UDF DIV(VALUE1, VALUE2) Linux, Win32 Divides the two integer inputs and returns the quotient, discarding the decimal part. Arguments valuel and value2 are columns or expressions that evaluate to numbers of SMALLINT or INTEGER type. Return value A DOUBLE PRECISION number with a zero decimal part. Notes The function behaves almost like integer-by-integer division in databases created in dialect 3-the distinction being that the division returns a double. Example SELECT DIV(TERM, (CURRENT_DATE - START_DATE)/365) AS YEARS REMAINING FROM MORTGAGE ACCOUNT WHERE ACCOUNT_ID = 12345; FBUDF DPOWER(VALUE, EXPONENT) Linux, Win32 Takes a number and an exponent and returns to exponential value. Arguments value: A column or expression that evaluates to a number of type DOUBLE PRECISION. exponent A column or expression that evaluates to a number of type DOUBLE PRECISION. Return value Returns the exponential value as a DOUBLE PRECISION number. Example SELECT DPOWER(2.64575,2) AS NEARLY_7 FROM RDB$DATABASE; Related or similar See also SQRT( ). functions 885 Appendix! FREEUDFLIB F_DOUBLEABS(VALUE} Win32 Returns the absolute value of a floating-point number. Arguments value is a column or expression that evaluates to a nurober of type DOUBLE PRECISION or FLOAT. Return value A positive nurober oftype DOUBLE PRECISION. Example SELECT ABS(SUM(ASSET_VALUE)) AS LIABILITY FROM ASSET REGISTER WHERE ASSET_VALUE < 0; Related or similar See also ABS( ), another external function that performs the same functions task and is available on non-Windows platforms. FREEUDFLIB F_ISDVISIBLEBY(VALUE1, VALUE2} Win32 Determines whether a value is evenly divisibly by another value. Returns 1 if Numerator (valuel) is evenly divisible by Denominator (value2); otherwise, returns 0. Arguments valuel: A column or expression that evaluates to an integer type, the nurober that is be divided (the numerator). value2: Another integer, the nurober to use as the denominator. Return value Returns 1 ifTrue, 0 ifFalse. Example This function could be called in a CHECK constraint as follows: ALTER TABLE ORDER DETAIL ADD CONSTRAINT CHECK MULTIPLE CHECK (ISDIVISIBLEBY(ORDER_QTY, PACK_QTY) = 1); Such a check might be used for validation where multiple pre­ packaged units are priced on a per-unit basis, rather than per-pack. FREEUDFLIB F_MODULO(VALUE1, VALUE2) Win32 Modulo function-returns the remainder from a division between two integers. Arguments valuel and value2 are columns or expressions that evaluate to numbers of SMALLINT or INTEGER type.
Recommended publications
  • Firebird 3.0 Developer's Guide
    Firebird 3.0 Developer’s Guide Denis Simonov Version 1.1, 27 June 2020 Preface Author of the written material and creator of the sample project on five development platforms, originally as a series of magazine articles: Denis Simonov Translation of original Russian text to English: Dmitry Borodin (MegaTranslations Ltd) Editor of the translated text: Helen Borrie Copyright © 2017-2020 Firebird Project and all contributing authors, under the Public Documentation License Version 1.0. Please refer to the License Notice in the Appendix This volume consists of chapters that walk through the development of a simple application for several language platforms, notably Delphi, Microsoft Entity Framework and MVC.NET (“Model-View-Controller”) for web applications, PHP and Java with the Spring framework. It is hoped that the work will grow in time, with contributions from authors using other stacks with Firebird. 1 Table of Contents Table of Contents 1. About the Firebird Developer’s Guide: for Firebird 3.0 . 6 1.1. About the Author . 6 1.1.1. Translation… . 6 1.1.2. … and More Translation . 6 1.2. Acknowledgments . 6 2. The examples.fdb Database . 8 2.1. Database Creation Script. 8 2.1.1. Database Aliases . 9 2.2. Creating the Database Objects. 10 2.2.1. Domains . 10 2.2.2. Primary Tables. 11 2.2.3. Secondary Tables . 13 2.2.4. Stored Procedures. 17 2.2.5. Roles and Privileges for Users . 25 2.3. Saving and Running the Script . 26 2.4. Loading Test Data . 27 3. Developing Firebird Applications in Delphi . 28 3.1.
    [Show full text]
  • Language Reference
    InterBase 6 Language Reference Borland/INPRISE 100 Enterprise Way, Scotts Valley, CA 95066 http://www.interbase.com Inprise/Borland may have patents and/or pending patent applications covering subject matter in this document. The furnishing of this document does not convey any license to these patents. Copyright 1999 Inprise/Borland. All rights reserved. All InterBase products are trademarks or registered trademarks of Inprise/Borland. All Borland products are trademarks or registered trademarks of Inprise/Borland. Other brand and product names are trademarks or registered trademarks of their respective holders. 1INT0055WW21004 6E1R0699 Table of Contents List of Tables.....................................xi CHAPTER 1 Using the InterBase Language Reference Who should use this book .....................13 Topics covered in this book .....................14 CHAPTER 2 SQL Statement and Function Reference Database object naming conventions ...............16 Statement list .............................17 Function list .............................18 Datatypes ...............................19 Error handling ............................20 Using statement and function definitions .............21 ALTER DATABASE ..........................22 ALTER DOMAIN ...........................23 ALTER EXCEPTION .........................25 ALTER INDEX ............................26 ALTER PROCEDURE .........................27 ALTER TABLE .............................28 ALTER TRIGGER ...........................35 AVG( ) .................................36 BASED
    [Show full text]
  • Development of Cross-Platform Problem-Oriented Systems Using Specifications of Database Applications ?
    Development of cross-platform problem-oriented systems using specifications of database applications ? Alexei Hmelnov1;2[0000−0002−0125−1130] and Evgeny Fereferov1;2[0000−0002−7316−444X] 1 Matrosov Institute for System Dynamics and Control Theory of Siberian Branch of Russian Academy of Sciences, 134 Lermontov st. Irkutsk, Russia [email protected] http://idstu.irk.ru 2 Institute of Mathematics, Economics and Informatics, Irkutsk State University, Gagarin Blvd. 20, Irkutsk, Russia Abstract. We consider the approach to development of AIS (automated information system) using declarative specifications of database applica- tions (SDA). The specifications of database applications contain all the information about database structure, which is required to build a typical AIS. The information is represented in its pure form, so the specifications are rather concise. The AIS'es are implemented using general algorithms, which are directed by the specifications. We have developed algorithms for such tasks as: user interface generation, query building, report gener- ation, GIS interaction. Using the specifications of database applications and the algorithms the software system GeoARM was implemented. The technology considered was well-tried by use of the system GeoARM for development of several dozens of true-life AIS for different purposes. In this article we'll describe the approach, that we use for creation of several versions of the GeoARM engine, which use different data access libraries, from the common source code base. The resulting versions of the GeoARM engine allow us to create problem-oriented AIS'es for all the supported platforms from the single SDA. Keywords: Specifications of database applications · automated infor- mation systems · rapid application development · data access technology · source code structuring.
    [Show full text]
  • An Overview of the Usage of Default Passwords (Extended Version)
    An Overview of the Usage of Default Passwords (extended version) Brandon Knieriem, Xiaolu Zhang, Philip Levine, Frank Breitinger, and Ibrahim Baggili Cyber Forensics Research and Education Group (UNHcFREG) Tagliatela College of Engineering University of New Haven, West Haven CT, 06516, United States fbknie1, [email protected],fXZhang, FBreitinger, [email protected] Summary. The recent Mirai botnet attack demonstrated the danger of using default passwords and showed it is still a major problem in 2017. In this study we investigated several common applications and their pass- word policies. Specifically, we analyzed if these applications: (1) have default passwords or (2) allow the user to set a weak password (i.e., they do not properly enforce a password policy). In order to understand the developer decision to implement default passwords, we raised this question on many online platforms or contacted professionals. Default passwords are still a significant problem. 61% of applications inspected initially used a default or blank password. When changing the password, 58% allowed a blank password, 35% allowed a weak password of 1 char- acter. Key words: Default passwords, applications, usage, security 1 Introduction Security is often disregarded or perceived as optional to the average consumer which can be a drawback. For instance, in October 2016 a large section of the In- ternet came under attack. This attack was perpetuated by approximately 100,000 Internet of Things (IoT) appliances, refrigerators, and microwaves which were compromised and formed the Mirai botnet. Targets of this attack included Twit- ter, reddit and The New York Times all of which shut down for hours.
    [Show full text]
  • Ibsurgeon Interbase/Firebird Database Information Tool
    IBSurgeon Free Tools: User Guide © IBSurgeon, 2015, www.ib-aid.com IBSurgeon Free Tools: User Guide IBSurgeon Free Tools is a set of 3 tools for Firebird and InterBase administrators and developers, designed to facilitate several typical tasks: 1) measure response time of specific SQL query to find time when query runs slower than usual (“Response Checker”), 2) view how much data, indices, blobs, etc, are stored in your Firebird or InterBase database (“DBInfo”) 3) investigate Firebird log for errors and warnings, (“Log Viewer”) These tools are simple to use, below you can find their short overview and frequently asked questions. IBSurgeon Response Checker 1. Why do you need Response Checker? If you are trying to improve Firebird database performance, the first thing you need to define is criteria of performance optimization. And, Firebird database performance has such criteria: Average response time Maximum response time Response time should be measured with your real-world application and with your production database (or in test environment which simulates production close enough). There is no reason to measure average response time out of the scope of your real application, until you want some abstract «optimization» - or you are using test environment which is proven to be very close or even identical to your production database. Response time is what your end users will refer as «slow», «very slow» or «good enough» (end users never say that your software is «fast»). How to measure the average and maximum response times in real-world production environments running Firebird? For the basic response time measurement you can use IBSurgeon Response Checker.
    [Show full text]
  • Interbase 2020 Award Winning Multi-Device Secure Embeddable Database
    InterBase 2020 Award winning Multi-device Secure Embeddable Database © Embarcadero Technologies, Inc. Embarcadero® InterBase® 2020 is a full-featured, high-performance, encryptable, multiplatform and scalable relational database for developers who are looking to embed a low-cost, zero admin, lightweight secure database into their cross-platform connected applications. With InterBase 2020 you get powerful access control, data change management, disaster recovery and journaling, as well as support for popular database drivers for increased deployment flexibility. SMALL, ULTRAFAST, HIGHLY EFFICIENT, SECURE FireMonkey comes with hundreds of controls and components, covering all of the functionality you need. Responsive UIs can use the platform native style, or a single cross- platform look and feel, letting you rapidly create visually stunning designs perfect for your app that highlight your brand across platforms. CHANGE VIEWS™ Many frameworks mimic controls, but FireMonkey provides pixelperfect, platform-specific styling. Real, platform-native controls on Windows, iOS, and Android are also available. Cross-platform design does not have to mean generic: give your users a real, native look-andfeel. BUILT FOR MODERN CPU ARCHITECTURES Without FireMonkey, other developers recreate their UI for each platform, using a different language and separate IDE. With FireMonkey, you can build a single visually stunning responsive platform aware UI once in a single language and deploy it to every platform. Rapidly design your UI, directly connected to your code and easily make platform and device-specific changes to cut development and maintenance times in half or more! SPEED UP TO LOWER RISK DEVELOPMENT AND DEPLOYMENT A UI should be fast, responsive, and snappy, with awesome rendering quality and smooth animations.
    [Show full text]
  • An Empirical Study of Local Database Usage in Android Applications
    2017 IEEE International Conference on Software Maintenance and Evolution An Empirical Study of Local Database Usage in Android Applications Yingjun Lyu∗, Jiaping Gui∗, Mian Wan, William G.J. Halfond Department of Computer Science University of Southern California Email: {yingjunl, jgui, mianwan, halfond}@usc.edu For example, both local and remote databases can be attacked Abstract—Local databases have become an important compo- using SQL injection (SQLI) attacks, if developers do not nent within mobile applications. Developers use local databases follow best practices for validating user input and interacting to provide mobile users with a responsive and secure service for data storage and access. However, using local databases comes with the databases [4], [5], [6]. However, some of the problems with a cost. Studies have shown that they are one of the most are unique to the context in which mobile devices operate. energy consuming components on mobile devices and misuse Many database operations, such as transactions, require file of their APIs can lead to performance and security problems. locking and rollback capability. This means that the use of In this paper, we report the results of a large scale empirical such operations is resource intensive, requiring CPU time, study on 1,000 top ranked apps from the Google Play app store. Our results present a detailed look into the practices, costs, memory, and I/O access. Unsurprisingly, the use of these and potential problems associated with local database usage in operations means that the use of local databases also comes deployed apps. We distill our findings into actionable guidance with a high energy cost; recent studies have found that they are for developers and motivate future areas of research related to among the top two or three energy consumers of all services on techniques to support mobile app developers.
    [Show full text]
  • Firebird 3 Quick Start Guide
    Firebird 3 Quick Start Guide IBPhoenix Editors, Firebird Project Members Version 5.4, 27 June 2020 Table of Contents Table of Contents 1. About this guide . 3 2. The Firebird licenses . 4 3. Installing Firebird . 5 3.1. Installation kits . 5 3.2. Installing the Firebird server. 5 3.2.1. Before installation. 5 3.2.2. Installation drives . 6 3.2.3. Installation script or program . 6 3.2.4. Server modes . 6 3.2.5. Installing on Windows. 7 3.2.6. Installing on Linux and other Unix-like platforms . 8 3.3. Installing multiple servers . 8 3.4. Testing your installation . 9 3.4.1. Pinging the server . 9 3.4.2. Making sure that the Firebird server is running. 9 3.5. Performing a client-only install . 12 3.5.1. Windows . 12 3.5.2. Linux and some other Posix clients . 12 4. Default disk locations . 14 4.1. Linux . 14 4.2. Windows. 14 5. Server configuration and management . 17 5.1. User management . 17 5.1.1. Changing the SYSDBA password . 17 5.1.2. Adding Firebird user accounts . 18 5.1.3. The security database . 19 5.1.4. Appointing co-administrators . 19 5.2. Security . 21 5.3. Administration tools . 26 6. Working with databases . 27 6.1. Connection strings . 27 6.1.1. Local connection strings . 27 6.1.2. TCP/IP connection strings . 28 6.1.3. NetBEUI connection strings . 29 6.1.4. URL-style connection strings . 30 6.1.5. Third-party programs . 31 6.2. Connecting to an existing database .
    [Show full text]
  • Issn: 2278-6244 a Comparative Analysis of Sql Server And
    International Journal of Advanced Research in IT and Engineering ISSN: 2278-6244 A COMPARATIVE ANALYSIS OF SQL SERVER AND INTERBASE SERVER Ajala F. A.* Emuoyibofarhe O.J* Alamu F.O* Abstract: Data storage, information management and subsequent retrieval constitute one of the ultimate goals in Computing Technology. Choosing the right Database Management System depending on the operation of the Establishment cannot be over emphasized. To select the right server for an application, two things to be considered are how data will be accessed and modified in the application, and how the server will behave in a data access or update situation. This research work compares two Database Management Systems with different architecture; Interbase server with multigenerational architecture and SQL server with classical architecture. The analysis was based on Execution time (Insert time, Update time and Delete time), using Delphi 6 programming language as the platform and Open Database Connectivity (ODBC) as the Application Programming Interface (API). Results obtained revealed that insert time in SQL server was in the range of 95343 µs to 3783171 µs when the record size ranged from 10,000 to 1,000,000 which almost doubled the insert time for Interbase server. Update time for SQL server is about twice that for Interbase for number of records between 10,000 and 100,000, but about three to six times for higher number of records. The delete time for SQL server was about 5 times that of the Interbase server. Keywords: ODBC, Multigenerational Architecture, Classical Architecture, DBMS, SQL Server and Interbase server. *Department of Computer Science and Engineering, Ladoke Akintola University of Technology, Ogbomoso, Nigeria.
    [Show full text]
  • ODBC Driver for Interbase
    Contents I Table of Contents Part I What's New 1 Part II General Information 3 1 Overvie..w... .............................................................................................................................. 4 2 Feature..s.. ............................................................................................................................... 5 3 Compa.t.i.b..i.l.i.t.y.. ........................................................................................................................ 7 4 Requir.e..m...e..n..t.s. ....................................................................................................................... 9 5 Licensi.n..g.. .............................................................................................................................. 9 6 Gettin.g.. .S...u..p..p..o..r.t. .................................................................................................................. 13 Part III Using ODBC Driver 14 1 Install.a..t.i.o..n.. .......................................................................................................................... 14 Window s .......................................................................................................................................................... 15 Window s Sile.n...t. ..................................................................................................................................................... 18 macOS .........................................................................................................................................................
    [Show full text]
  • IBX for Lazarus User Guide
    MWA Software IBX for Lazarus User Guide Issue 1.6, 14 April 2018 McCallum Whyman Associates Ltd EMail: info@ mccallumwhyman.com, http://www.mccallumwhyman.com Registered in England Registration No. 2624328 COPYRIGHT The copyright in this work is vested in McCallum Whyman Associates Ltd. The contents of the document may be freely distributed and copied provided the source is correctly identified as this document. © Copyright McCallum Whyman Associates Ltd (2016) trading as MWA Software. Disclaimer Although our best efforts have been made to ensure that the information contained within is up-to-date and accurate, no warranty whatsover is offered as to its correctness and readers are responsible for ensuring through testing or any other appropriate procedures that the information provided is correct and appropriate for the purpose for which it is used. ii CONTENTS Page 1 INTRODUCTION................................................................................................................................................1 1.1 REFERENCES............................................................................................................................................................2 1.2 CHANGE HISTORY....................................................................................................................................................2 1.2.1 Version 1.1....................................................................................................................................................2 1.2.2 Version
    [Show full text]
  • Interbase & Firebird, Corruptions Reasons
    Interbase & Firebird, corruptions reasons by Alexey Kovyazin and Dmitry Kuzmenko, 2005-2007 Hardware-related errors Abnormal shutdown Abnormal shutdowns are the leading cause of corruption. They can be caused by power loss on a computer with no UPS when a big mutant mole eats your city©s power supply cable (or any other explanation your energy company might give), or the cleaning lady pulls the ªwrongº cable while cleaning your office. Sometimes people just power off their computers without concern for what the machine might be engaged in. Any of these conditions can lead to corruption. Nonetheless, you have probably observed that not every abnormal shutdown leads to corruption. The initial design of InterBase was, with some restrictions, forgiving toward such unstable environments. As you may know, earlier versions of InterBase were used in the fire control system of the MLRPS artillery platform. Every volley of MPLRS was accompanied by a strong electromagnetic pulse, causing the on-board computerto reboot every time. It was a strong requirement that the on- board database server be able to reload in seconds be robust against the potential for corruption caused by power shutdown. InterBase fitted both conditions: it started quickly and its multi- generation architecture made it capable of bypassing uncommitted or even corrupted versions of records, and retain its ability to read good records. But time passes. In later versions advanced caching was implemented and ªcivilianº InterBase versions became more vulnerable in abnormal shutdowns. The best-known problem is related to Forced Writes on Windows. Forced writes is a flag, set on the database file, that determines Windows caching behavior for this file.
    [Show full text]