Chapter 2
delimited or fixed width flat files
non DBI modules: AnyDBM_File, Storable, Data::Dumper
Chapter 7
discusses the differences in design between DBI and ODBC, the other portable database API.
Chapter 8
This chapter covers two topics that aren't exactly part of the core DBI, per se, but are extremely useful to know about
DBI shell
proxy architecture: you can connect a script running on a Unix box to a Microsoft Access database running on a Microsoft Windows box
Appendix B
contains useful extra information on each of the commonly used DBDs and their corresponding databases.
Resources
http://dbi.perl.org
http://www.perl.com/CPAN
Learning Perl, by Randal Schwartz and Tom Christiansen
Programming Perl, by Larry Wall, Tom Christiansen, and Randal Schwartz : The authoritative guide to Perl version 5
The Perl Cookbook, by Tom Christiansen and Nathan Torkington : long-awaited companion volume to Programming Perl
Writing Apache Modules with Perl and C, by Lincoln Stein and Doug MacEachern : Apache::DBI module, which provides advanced DBI functionality in relation to web services such as persistent connection pooling optimized for serving databases over the Web.
http://www.oreilly.com/catalog/perldbi/ # examples, errata
Chapter 1: Introduction
each development team choosing their preferred development environment (such as Visual Basic, PowerBuilder, Oracle Pro*C, Informix E/SQL, C++ code with ODBC—the list is almost endless). Database-independent programming interfaces.
Another aspect of today's corporate database lifestyle revolves around the idea of data warehousing , that is, creating and building vast repositories of archived information that can be scanned, or mined, for information separately from online databases
Perl takes the pain of manipulating strings out of programming, unlike C
"Swiss army knife of programming languages."
1.3. DBI in the Real World
We developed and support a large scale telephone call logging and analysis system for a major client of ours. The system collects ~1 GB of call data per day from over 1,200,000 monitored phone numbers. ~424 GB has been processed so far (over 6,200,000,000 calls). Data is processed and loaded into Oracle using DBI and DBD::Oracle. The database holds rolling data for around 20 million calls. The system generates over 44,000 PostScript very high quality reports per month (~five pages with eleven color graphs and five tables) generated by using Perl to manipulate FrameMaker templates. [Values correct as of July 1999, and rising steadily.] The whole system runs on three dual processor Sun SPARC Ultra 2 machines—one for data acquisition and processing, one for Oracle and the third does most of the report production (which is also distributed across the other two machines).
In 1997 I built a system for NASA's Langley Research Center in Virginia that puts a searchable web front end on a database of about 100,000 NASA-owned equipment items. I used Apache, DBI, Informix, WDB, and mod_perl on a Sparc 20
They have 30,000 employees world-wide who needed a secure system for getting to web-based resources. This first iteration of the Intranet is specified to handle up to forty requests for web objects per second (approximately 200 concurrent users), and runs on a single processor Intel Pentium-Pro with 512 megs of RAM. , we have developed a large reusable library of Perl code. . One of our most useful modules builds an Object-Relational wrapper around DBI to allow our application developers to talk to the database using O-O methods to access or change properties of the record
using Perl with DBI and DBD-Oracle as part of web-based reporting for significant portions of the manufacturing and distribution organizations. The use of DBI/DBD-Oracle is part of a movement away from Oracle Forms based reporting to a pure web-based reporting platform.
Chapter 2. Basic Non-DBI Databases
DBI supports relational, not Object Oriented
2.1. Storage Managers and Layers
flat-file databases are composed of pools of data with very few layers of abstraction.
DBM file libraries, like Berkeley DB, are an example of a storage manager layer that sits on top of the raw data files
You could potentially implement a more powerful database system on top of DBM files.
2.2. Query Languages and Data Functions
C.R.U.D. (Create, Read, Update, Delete).
2.3. Standing Stones and the Sample Database
Name: Stonehenge
Location: Wiltshire, England
Map Reference: SU 123 400
Type: Stone Circle and Henge
Description: The most famous megalithic site in the world, comprised of an earthen bank, or henge, and several concentric rings of massive standing stones formed into trilithons.
`tell me of all the megalithic sites in Wiltshire,'' or ``tell me about all the standing stones in Orkney,'' and so on.
the simplest form of database that you might wish to use: the flat-file database.
2.4. Flat-File Databases
Modifications to the data are usually done by updating an in-memory copy of the data held in the file, or files, then writing the entire set of data back out to disk.
two main types of flat-file database: files that separate fields with a delimiter character, and files that allocate a fixed length to each field.
2.4.1. Querying Data
Usage: scanmegadata
open MEGADATA, "<$megalithFile" or die "Can't open $megalithFile: $!\n"; while () {
( $name, $location, $mapref, $type, $description ) = split( /:/, $_ );
if ( $name eq $siteName ) { $found = $. ; last; } # hold current line number
if ($found)
Using fixed-width fields is similar to the way in which data is organized in more powerful database systems such as an RDBMS.
eliminiate hassle of parse char in data
instead of split, use unpack
( $name, $location, $mapref, $type, $description ) = unpack( "A64 A64 A16 A32 A256", $_ );
2.4.2. Inserting Data
Inserting data into a flat-file database is very straightforward and usually amounts to simply tacking the new data onto the end of the data file.
Usage: insertmegadata" "
Tuesday, February 20, 2007
perl DBI
Sunday, February 18, 2007
firefox extentions
Talkback: Submit a crash report to Mozilla.org
Session Manager: Saves and restores the state of all windows
Slogger: Log and save the pages in local files or via remote services
Selenium IDE: Record, edit, and play Selenium tests
Molybdenum: Edit and run selenium web tests
Selenium Recorder: Captures your input and generates Selenium test commands
Firebug: Web development Evolved
About this site: one click access to website metadata - traffic, related and linked pages
Session Manager: Saves and restores the state of all windows
Slogger: Log and save the pages in local files or via remote services
Selenium IDE: Record, edit, and play Selenium tests
Molybdenum: Edit and run selenium web tests
Selenium Recorder: Captures your input and generates Selenium test commands
Firebug: Web development Evolved
About this site: one click access to website metadata - traffic, related and linked pages
XAMPP components
Features
XAMPP ScreenshotXAMPP is a complete web, database and FTP server package for Windows that's ready to go in minutes and completely portable. The full XAMPP package includes:
* Apache
* MySQL
* PHP + PEAR
* MiniPerl
* OpenSSL
* phpMyAdmin
* XAMPP Control Panel
* Webalizer
* Mercury Mail Transport System
* FileZilla FTP Server
* SQLite
* ADODB
* Zend Optimizer
* XAMPP Security
XAMPP ScreenshotXAMPP is a complete web, database and FTP server package for Windows that's ready to go in minutes and completely portable. The full XAMPP package includes:
* Apache
* MySQL
* PHP + PEAR
* MiniPerl
* OpenSSL
* phpMyAdmin
* XAMPP Control Panel
* Webalizer
* Mercury Mail Transport System
* FileZilla FTP Server
* SQLite
* ADODB
* Zend Optimizer
* XAMPP Security
Thursday, February 15, 2007
sysinternals
http://sqlservercode.blogspot.com/2007/02/sysinternals-troubleshooting-utilities.html
2.15.07
Autoruns
v8.61 (1/22/2007)
See what programs are configured to startup automatically when your system boots and you login. Autoruns also shows you the full list of Registry and file locations where applications can configure auto-start settings.
• DiskView
v2.21 (11/1/2006)
Graphical disk sector utility
• Diskmon
v2.01 (11/1/2006)
This utility captures all hard disk activity or acts like a software disk activity light in your system tray.
• Du
v1.31 (11/1/2006)
View disk usage by directory
* Handle
v3.20 (11/1/2006)
This handy command-line utility will show you what files are open by which processes, and much more.
• ListDLLs
v2.25 (11/1/2006)
List all the DLLs that are currently loaded, including where they are loaded and their version numbers. Version 2.0 prints the full path names of loaded modules.
• Process Explorer
v10.21 (11/1/2006)
Find out what files, registry keys and other objects processes have open, which DLLs they have loaded, and more. This uniquely powerful utility will even show you who owns each process.
• Process Monitor
v1.01 (11/9/2006)
Monitor file system, Registry, process, thread and DLL activity in real-time.
• PsFile
v1.02 (12/4/2006)
See what files are opened remotely.
• RootkitRevealer
v1.71 (11/1/2006)
Scan your system for rootkit-based malware
2.15.07
Autoruns
v8.61 (1/22/2007)
See what programs are configured to startup automatically when your system boots and you login. Autoruns also shows you the full list of Registry and file locations where applications can configure auto-start settings.
• DiskView
v2.21 (11/1/2006)
Graphical disk sector utility
• Diskmon
v2.01 (11/1/2006)
This utility captures all hard disk activity or acts like a software disk activity light in your system tray.
• Du
v1.31 (11/1/2006)
View disk usage by directory
* Handle
v3.20 (11/1/2006)
This handy command-line utility will show you what files are open by which processes, and much more.
• ListDLLs
v2.25 (11/1/2006)
List all the DLLs that are currently loaded, including where they are loaded and their version numbers. Version 2.0 prints the full path names of loaded modules.
• Process Explorer
v10.21 (11/1/2006)
Find out what files, registry keys and other objects processes have open, which DLLs they have loaded, and more. This uniquely powerful utility will even show you who owns each process.
• Process Monitor
v1.01 (11/9/2006)
Monitor file system, Registry, process, thread and DLL activity in real-time.
• PsFile
v1.02 (12/4/2006)
See what files are opened remotely.
• RootkitRevealer
v1.71 (11/1/2006)
Scan your system for rootkit-based malware
Tuesday, February 6, 2007
php frameworks
Ask Reddit: Which PHP framework do you use or recommend? (programming.reddit.com)
niels 4 points 18 hours ago
I don't do PHP, but I just tried Cakephp and it worked really well. It is inspired by Rails.
permalink
ericthelin 2 points 18 hours ago
CodeIgniter is really good for a lightweight, very fast and well documented framework.
permalink
doctorsynapse 2 points 18 hours ago*
I use the Stratos Framework. It's pretty intuitive and allows for quick development.
permalink
dismayed 1 point 18 hours ago
The no-framework framework: http://toys.lerdorf.com/archives/38-The-no-framework-PHP-MVC-framework.html
niels 4 points 18 hours ago
I don't do PHP, but I just tried Cakephp and it worked really well. It is inspired by Rails.
permalink
ericthelin 2 points 18 hours ago
CodeIgniter is really good for a lightweight, very fast and well documented framework.
permalink
doctorsynapse 2 points 18 hours ago*
I use the Stratos Framework. It's pretty intuitive and allows for quick development.
permalink
dismayed 1 point 18 hours ago
The no-framework framework: http://toys.lerdorf.com/archives/38-The-no-framework-PHP-MVC-framework.html
web stat providers
Blue Ferret BlogTip 2-5-07 - Why You Should Use 2+ Web Stats Providers
I've used StatCounter and Performancing to track both my blog and my website for a while now.
http://www.statcounter.com/
http://performancing.com/
I've used StatCounter and Performancing to track both my blog and my website for a while now.
http://www.statcounter.com/
http://performancing.com/
Monday, February 5, 2007
Web Developers: 13 Command Line Tricks You Might Not Know
Web Developers: 13 Command Line Tricks You Might Not Know
1. ln -s /some/destination name_of_link
2. tail -f /some/file
3. ctrl+z and bg
4. fg and jobs
5. Hit the freakin tab key!
6. scp
7. screen
8. Create a file (the fast way) with touch
10. Backup and reload your databases
11. Make a directory tree (the fast way)
12. killall: kill a process by name
13. Alias: Create your own commands
Miscellaneous Tricks
see also:
HOWTO: Benchmark Drupal code
Drupal benchmark results
1. ln -s /some/destination name_of_link
2. tail -f /some/file
3. ctrl+z and bg
4. fg and jobs
5. Hit the freakin tab key!
6. scp
7. screen
8. Create a file (the fast way) with touch
10. Backup and reload your databases
11. Make a directory tree (the fast way)
12. killall: kill a process by name
13. Alias: Create your own commands
Miscellaneous Tricks
- ls -lSr List files (sorted by size)
- df -h Show available disk space in human-readable format
- du -sh /some/dir Show how much space /some/dir is taking up
- ps aux | grep blah List all the running processes but only show ones that contain 'blah'
- wget -spider http://0at.org Fetch pages and behave like a web spider: don't download the pages, just check to see if they are there
- ab - Apache benchmark, use this if you want a quick n' dirty way to benchmark how well your site performs under a heavy load.
- perl -i -pe 's/foo/bar/gi' * search through * and replace all foo with bar
see also:
HOWTO: Benchmark Drupal code
Drupal benchmark results
mysql grant all
mysql
mysql -u admin -p
mysql> use mysql
grant all on user.* to 'user'@'localhost' identified by 'pass';
SHOW GRANTS FOR user@localhost;
mysql -u admin -p
mysql> use mysql
grant all on user.* to 'user'@'localhost' identified by 'pass';
SHOW GRANTS FOR user@localhost;
Friday, February 2, 2007
PHP vs Java vs Ruby
# PHP vs Java vs Ruby
http://www.cmswire.com/cms/industry-news/php-vs-java-vs-ruby-000887.php
Uhhhhhhhhhhhhh
You're comparing two languages to a framework in another.....
How about struts vs cakephp vs rails?
anyhow, ridiculous comparison.
http://www.cmswire.com/cms/industry-news/php-vs-java-vs-ruby-000887.php
Uhhhhhhhhhhhhh
You're comparing two languages to a framework in another.....
How about struts vs cakephp vs rails?
anyhow, ridiculous comparison.
Subscribe to:
Posts (Atom)