c# web api pdf : Create bookmarks pdf application Library tool html asp.net winforms online BerkeleyDB-JE-GSG12-part694

Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 112
package je.gettingStarted;
import com.sleepycat.je.Cursor;
import com.sleepycat.je.Database;
import com.sleepycat.je.Environment;
...
try {
...
} catch ... {
} finally {
try {
if (myCursor != null) {
myCursor.close();
}
if (myDatabase != null) {
myDatabase.close();
}
if (myDbEnvironment != null) {
myDbEnvironment.close();
}
} catch(DatabaseException dbe) {
System.err.println("Error in close: " + dbe.toString());
}
Getting Records Using the Cursor
To iterate over database records, from the first record to the last, simply open the cursor and
then use the Cursor.getNext() method. For example:
package je.gettingStarted;
import com.sleepycat.je.Cursor;
import com.sleepycat.je.Database;
import com.sleepycat.je.DatabaseEntry;
import com.sleepycat.je.DatabaseException;
import com.sleepycat.je.LockMode;  
import com.sleepycat.je.OperationStatus; 
...
Cursor cursor = null;
try {
...
// Database and environment open omitted for brevity
...
Create bookmarks pdf - add, remove, update PDF bookmarks in C#.net, ASP.NET, MVC, Ajax, WinForms, WPF
Empower Your C# Project with Rapid PDF Internal Navigation Via Bookmark and Outline
create bookmarks in pdf reader; bookmark pdf documents
Create bookmarks pdf - VB.NET PDF bookmark library: add, remove, update PDF bookmarks in vb.net, ASP.NET, MVC, Ajax, WinForms, WPF
Empower Your VB.NET Project with Rapid PDF Internal Navigation Via Bookmark and Outline
how to add bookmarks to pdf document; creating bookmarks in pdf from word
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 113
// Open the cursor. 
cursor = myDatabase.openCursor(null, null);
// Cursors need a pair of DatabaseEntry objects to operate. These hold
// the key and data found at any given position in the database.
DatabaseEntry foundKey = new DatabaseEntry();
DatabaseEntry foundData = new DatabaseEntry();
// To iterate, just call getNext() until the last database record has 
// been read. All cursor operations return an OperationStatus, so just
// read until we no longer see OperationStatus.SUCCESS
while (cursor.getNext(foundKey, foundData, LockMode.DEFAULT) ==
OperationStatus.SUCCESS) {
// getData() on the DatabaseEntry objects returns the byte array
// held by that object. We use this to get a String value. If the
// DatabaseEntry held a byte array representation of some other 
// data type (such as a complex object) then this operation would
// look considerably different.
String keyString = new String(foundKey.getData(), "UTF-8");
String dataString = new String(foundData.getData(), "UTF-8");
System.out.println("Key | Data : " + keyString + " | " + 
dataString + "");
}
} catch (DatabaseException de) {
System.err.println("Error accessing database." + de);
} finally {
// Cursors must be closed.
cursor.close();
}
To iterate over the database from the last record to the first, instantiate the cursor, and then
use Cursor.getPrev() until you read the first record in the database. For example:
package je.gettingStarted;
import com.sleepycat.je.Cursor;
import com.sleepycat.je.Database;
import com.sleepycat.je.DatabaseEntry;
import com.sleepycat.je.DatabaseException;
import com.sleepycat.je.LockMode;  
import com.sleepycat.je.OperationStatus; 
...
Cursor cursor = null;
try {
...
// Database and environment open omitted for brevity
...
VB.NET PDF File Compress Library: Compress reduce PDF size in vb.
Bookmarks. inputFilePath = Program.RootPath + "\\" 3.pdf"; String outputFilePath = Program.RootPath + "\\" 3_optimized.pdf"; 'create optimizing options
add bookmarks to pdf; excel pdf bookmarks
VB.NET PDF File Split Library: Split, seperate PDF into multiple
file into multiple ones by PDF bookmarks or outlines As String = Program.RootPath + "\\" 1.pdf" Dim outputFileName 1 to (Page Count - 1). ' Create output PDF
bookmarks in pdf; copy pdf bookmarks
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 114
// Open the cursor. 
cursor = myDatabase.openCursor(null, null);
// Get the DatabaseEntry objects that the cursor will use.
DatabaseEntry foundKey = new DatabaseEntry();
DatabaseEntry foundData = new DatabaseEntry();
// Iterate from the last record to the first in the database
while (cursor.getPrev(foundKey, foundData, LockMode.DEFAULT) == 
OperationStatus.SUCCESS) {
String theKey = new String(foundKey.getData(), "UTF-8");
String theData = new String(foundData.getData(), "UTF-8");
System.out.println("Key | Data : " +  theKey + " | " + 
theData + "");
}
} catch (DatabaseException de) {
System.err.println("Error accessing database." + de);
} finally {
// Cursors must be closed.
cursor.close();
}
Disk Ordered Cursors
The previous example shows how to scan through the records in your database sequentially;
that is, in the record's sort order. This is mostly determined by the value contained in the
records' keys (additional sorting is required in the case of duplicate records). However, you
can use cursors to retrieve records based on how they are stored on disk. This can improve
retrieval times, and is useful if your application needs to scan all the records in the database
quickly, without concern for key sort order. You do this using the DiskOrderedCursor class.
DiskOrderedClass works in the same way as a regular cusor: you simply open the cursor,
then retrieve records one after another using the DiskOrderedClass.getNext() method.
You open a DiskOrderedCursor using the Database.openCursor() method. This version of
the method takes a single parameter: an instance of the DiskOrderedCursorConfig class,
which can be used to configure various aspects of the DiskOrderedCursor class.
package je.gettingStarted;
import com.sleepycat.je.Database;
import com.sleepycat.je.DatabaseEntry;
import com.sleepycat.je.DatabaseException;
import com.sleepycat.je.DiskOrderedCursor;
import com.sleepycat.je.DiskOrderedCursorConfig;
import com.sleepycat.je.LockMode;  
import com.sleepycat.je.OperationStatus; 
...
C# PDF File Compress Library: Compress reduce PDF size in C#.net
Bookmarks. inputFilePath = Program.RootPath + "\\" 3.pdf"; String outputFilePath = Program.RootPath + "\\" 3_optimized.pdf"; // create optimizing options
bookmark pdf in preview; creating bookmarks in a pdf document
C# PDF File Split Library: Split, seperate PDF into multiple files
Split PDF file by top level bookmarks. The following C# codes explain how to split a PDF file into multiple ones by PDF bookmarks or outlines.
bookmark a pdf file; how to bookmark a pdf file
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 115
DiskOrderedCursor dcursor = null;
DiskOrderedCursorConfig docc = new DiskOrderedCursorConfig();
try {
...
// Database and environment open omitted for brevity
...
// Open the cursor. 
dcursor = myDatabase.openCursor(docc);
// Cursors need a pair of DatabaseEntry objects to operate. These hold
// the key and data found at any given position in the database.
DatabaseEntry foundKey = new DatabaseEntry();
DatabaseEntry foundData = new DatabaseEntry();
// To iterate, just call getNext() until the last database record has 
// been read. All cursor operations return an OperationStatus, so just
// read until we no longer see OperationStatus.SUCCESS
while (dcursor.getNext(foundKey, foundData, LockMode.DEFAULT) ==
OperationStatus.SUCCESS) {
// getData() on the DatabaseEntry objects returns the byte array
// held by that object. We use this to get a String value. If the
// DatabaseEntry held a byte array representation of some other 
// data type (such as a complex object) then this operation would
// look considerably different.
String keyString = new String(foundKey.getData(), "UTF-8");
String dataString = new String(foundData.getData(), "UTF-8");
System.out.println("Key | Data : " + keyString + " | " + 
dataString + "");
}
} catch (DatabaseException de) {
System.err.println("Error accessing database." + de);
} finally {
// Cursors must be closed.
cursor.close();
}
Searching for Records
You can use cursors to search for database records. You can search based on just a key, or you
can search based on both the key and the data. You can also perform partial matches if your
database supports sorted duplicate sets. In all cases, the key and data parameters of these
methods are filled with the key and data values of the database record to which the cursor is
positioned as a result of the search.
Also, if the search fails, then cursor's state is left unchanged and OperationStatus.NOTFOUND
is returned.
The following Cursor methods allow you to perform database searches:
C# Create PDF Library SDK to convert PDF from other file formats
file. Create and save editable PDF with a blank page, bookmarks, links, signatures, etc. Create fillable PDF document with fields.
adding bookmarks to a pdf; add bookmark to pdf reader
VB.NET Create PDF Library SDK to convert PDF from other file
Create and save editable PDF with a blank page, bookmarks, links, signatures, etc. Create fillable PDF document with fields in Visual Basic .NET application.
adding bookmarks to pdf; how to bookmark a page in pdf document
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 116
• Cursor.getSearchKey()
Moves the cursor to the first record in the database with the specified key.
• Cursor.getSearchKeyRange()
Moves the cursor to the first record in the database whose key is greater than or equal
to the specified key. This comparison is determined by the comparator that you provide
for the database. If no comparator is provided, then the default unsigned byte-by-byte
lexicographical sorting is used.
For example, suppose you have database records that use the following Strings as keys:
Alabama
Alaska
Arizona
Then providing a search key of Alaska moves the cursor to the second key noted above.
Providing a key of Al moves the cursor to the first key (Alabama), providing a search key
of Alas moves the cursor to the second key (Alaska), and providing a key of Ar moves the
cursor to the last key (Arizona).
• Cursor.getSearchBoth()
Moves the cursor to the first record in the database that uses the specified key and data.
• Cursor.getSearchBothRange()
Moves the cursor to the first record in the database whose key matches the specified key
and whose data is greater than or equal to the specified data. If the database supports
duplicate records, then on matching the key, the cursor is moved to the duplicate record
with the smallest data that is greater than or equal to the specified data.
For example, suppose you have database records that use the following key/data pairs:
Alabama/Athens
Alabama/Florence
Alaska/Anchorage
Alaska/Fairbanks
Arizona/Avondale
Arizona/Florence 
then providing:
a search key of ...
and a search data of ...
moves the cursor to ...
Alaska
Fa
Alaska/Fairbanks
Arizona
Fl
Arizona/Florence
Alaska
An
Alaska/Anchorage
.NET PDF SDK - Description of All PDF Processing Control Feastures
Full page navigation, zooming & rotation; Outlines, bookmarks, & thumbnail display; Integrated annotation; More about Web Viewer ▶. Conversion. PDF Create.
bookmarks pdf; excel hyperlink to pdf bookmark
XDoc.Word for .NET, Advanced .NET Word Processing Features
& rotation; Outlines, bookmarks, & thumbnail display; Integrated annotation; More about Web Viewer ▶. Conversion. Word Create. Create Word from PDF; Create Word
how to bookmark a pdf page; export pdf bookmarks
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 117
For example, assuming a database containing sorted duplicate records of U.S. States/U.S
Cities key/data pairs (both as Strings), then the following code fragment can be used to
position the cursor to any record in the database and print its key/data values:
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 118
package je.gettingStarted;
import com.sleepycat.je.Cursor;
import com.sleepycat.je.Database;
import com.sleepycat.je.DatabaseEntry;
import com.sleepycat.je.DatabaseException;
import com.sleepycat.je.LockMode;
import com.sleepycat.je.OperationStatus; 
...
// For this example, hard code the search key and data
String searchKey = "Alaska";
String searchData = "Fa";
Cursor cursor = null;
try {
...
// Database and environment open omitted for brevity
...
// Open the cursor. 
cursor = myDatabase.openCursor(null, null);
DatabaseEntry theKey = 
new DatabaseEntry(searchKey.getBytes("UTF-8"));
DatabaseEntry theData = 
new DatabaseEntry(searchData.getBytes("UTF-8"));
// Open a cursor using a database handle
cursor = myDatabase.openCursor(null, null);
// Perform the search
OperationStatus retVal = cursor.getSearchBothRange(theKey, theData, 
LockMode.DEFAULT);
// NOTFOUND is returned if a record cannot be found whose key 
// matches the search key AND whose data begins with the search data.
if (retVal == OperationStatus.NOTFOUND) {
System.out.println(searchKey + "/" + searchData + 
" not matched in database " + 
myDatabase.getDatabaseName());
} else {
// Upon completing a search, the key and data DatabaseEntry 
// parameters for getSearchBothRange() are populated with the 
// key/data values of the found record.
String foundKey = new String(theKey.getData(), "UTF-8");
String foundData = new String(theData.getData(), "UTF-8");
System.out.println("Found record " + foundKey + "/" + foundData + 
"for search key/data: " + searchKey + 
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 119
"/" + searchData);
}
} catch (Exception e) {
// Exception handling goes here
} finally {
// Make sure to close the cursor
cursor.close();
}
Working with Duplicate Records
If your database supports duplicate records, then it can potentially contain multiple records
that share the same key. Using normal database get operations, you can only ever obtain the
first such record in a set of duplicate records. To access subsequent duplicates, use a cursor.
The following Cursor methods are interesting when working with databases that support
duplicate records:
• Cursor.getNext(), Cursor.getPrev()
Shows the next/previous record in the database, regardless of whether it is a duplicate of
the current record. For an example of using these methods, see Getting Records Using the
Cursor (page 112).
• Cursor.getSearchBothRange()
Useful for seeking the cursor to a specific record, regardless of whether it is a duplicate
record. See Searching for Records (page 115) for more information.
• Cursor.getNextNoDup(), Cursor.getPrevNoDup()
Gets the next/previous non-duplicate record in the database. This allows you to skip
over all the duplicates in a set of duplicate records. If you call Cursor.getPrevNoDup(),
then the cursor is positioned to the last record for the previous key in the database. For
example, if you have the following records in your database:
Alabama/Athens
Alabama/Florence
Alaska/Anchorage
Alaska/Fairbanks
Arizona/Avondale
Arizona/Florence
and your cursor is positioned to Alaska/Fairbanks, and you then call
Cursor.getPrevNoDup(), then the cursor is positioned to Alabama/Florence. Similarly,
if you call Cursor.getNextNoDup(), then the cursor is positioned to the first record
corresponding to the next key in the database.
If there is no next/previous key in the database, then OperationStatus.NOTFOUND is
returned, and the cursor is left unchanged.
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 120
• Cursor.getNextDup(), Cursor.getPrevDup()
Gets the next/previous record that shares the current key. If the cursor is positioned
at the last record in the duplicate set and you call Cursor.getNextDup(), then
OperationStatus.NOTFOUND is returned and the cursor is left unchanged. Likewise, if you
call getPrevDup() and the cursor is positioned at the first record in the duplicate set, then
OperationStatus.NOTFOUND is returned and the cursor is left unchanged.
• Cursor.count()
Returns the total number of records that share the current key.
For example, the following code fragment positions a cursor to a key and, if the key contains
duplicate records, displays all the duplicates. Note that the following code fragment assumes
that the database contains only String objects for the keys and data.
package je.gettingStarted;
import com.sleepycat.je.Cursor;
import com.sleepycat.je.Database;
import com.sleepycat.je.DatabaseEntry;
import com.sleepycat.je.DatabaseException;
import com.sleepycat.je.LockMode;
import com.sleepycat.je.OperationStatus; 
...
Cursor cursor = null;
try {
...
// Database and environment open omitted for brevity
...
// Create DatabaseEntry objects
// searchKey is some String.
DatabaseEntry theKey = new DatabaseEntry(searchKey.getBytes("UTF-8"));
DatabaseEntry theData = new DatabaseEntry();
// Open a cursor using a database handle
cursor = myDatabase.openCursor(null, null);
// Position the cursor
// Ignoring the return value for clarity
OperationStatus retVal = cursor.getSearchKey(theKey, theData, 
LockMode.DEFAULT);
// Count the number of duplicates. If the count is greater than 1, 
// print the duplicates.
if (cursor.count() > 1) {
while (retVal == OperationStatus.SUCCESS) {
Library Version 12.1.6.0
Using Cursors
12/7/2015
Getting Started with JE
Page 121
String keyString = new String(theKey.getData(), "UTF-8");
String dataString = new String(theData.getData(), "UTF-8");
System.out.println("Key | Data : " +  keyString + " | " + 
dataString + "");
retVal = cursor.getNextDup(theKey, theData, LockMode.DEFAULT);
}
}
} catch (Exception e) {
// Exception handling goes here
} finally {
// Make sure to close the cursor
cursor.close();
}
Putting Records Using Cursors
You can use cursors to put records into the database. JE's behavior when putting records
into the database differs depending on whether the database supports duplicate records.
If duplicates are allowed, its behavior also differs depending on whether a comparator is
provided for the database. (Comparators are described in Using Comparators (page 97)).
Note that when putting records to the database using a cursor, the cursor is positioned at the
record you inserted.
You can use the following methods to put records to the database:
• Cursor.put()
If the provided key does not exist in the database, then the order that the record is put into
the database is determined by the BTree (key) comparator in use by the database.
If the provided key already exists in the database, and the database does not support sorted
duplicates, then the existing record data is replaced with the data provided on this method.
If the provided key already exists in the database, and the database does support sorted
duplicates, then the order that the record is inserted into the database is determined by
the duplicate comparator in use by the database.
• Cursor.putNoDupData()
If the provided key and data already exists in the database, then this method returns
OperationStatus.KEYEXIST.
If the key does not exist, then the order that the record is put into the database is
determined by the BTree (key) comparator in use by the database.
• Cursor.putNoOverwrite()
If the provided key already exists in the database, then this method returns
OperationStatus.KEYEXIST.
Documents you may be interested
Documents you may be interested