Tải bản đầy đủ (.pdf) (866 trang)

MySQL cookbook, 3rd edition

Bạn đang xem bản rút gọn của tài liệu. Xem và tải ngay bản đầy đủ của tài liệu tại đây (6.73 MB, 866 trang )

Sort query results and generate summaries

■■

Use stored routines, triggers, and scheduled events

■■

Import, export, validate, and reformat data

■■

Perform transactions and work with statistics

■■

Process web input, and generate web content from
query results

■■

Use MySQL-based web session management

■■

Provide security and server administration

—Ulf Wendel,

Senior Software Engineer for MySQL and
co-author of the mysqlnd PHP library



Paul DuBois is one of the primary contributors to the MySQL Reference Manual,
a renowned online manual that has supported MySQL administrators and
database developers for years. He’s a member of the MySQL documentation
team at Oracle and author of several books.

DATABA SES

CAN $83.99

ISBN: 978-1-449-37402-0

MySQL
Cookbook
SOLUTIONS FOR DATABASE DEVELOPERS AND ADMINISTRATORS

DuBois

US $79.99

Twitter: @oreillymedia
facebook.com/oreilly

d

■■



te


Work with dates and times

da

■■

on

Store, retrieve, and manipulate strings

Up

■■

iti

Create, populate, and select data from tables

d

■■

an

Use the mysql client and write MySQL-based programs

d

■■


MySQL recipes available.
This book covers basics
needed by beginners, 
and presents the very 
latest developments that
advanced users can use 
to deepen their knowledge.
And it’s crowded with 
tips that make it even 
more valuable to MySQL
professionals.

Ed

se

Ideal for beginners and professional database and web developers, this
updated third edition covers powerful features in MySQL 5.6 (and some
in 5.7). The book focuses on programming APIs in Python, PHP, Java, Perl,
and Ruby. With more than 200+ recipes, you’ll learn how to:

classic, this remains 
“Athetrue
best collection of

THIRD EDITION

MySQL Cookbook


MySQL’s popularity has brought a flood of questions about how to solve
specific problems, and that’s where this cookbook is essential. When you
need quick solutions or techniques, this handy resource provides scores
of short, focused pieces of code, hundreds of worked-out examples, and
clear, concise explanations for programmers who don’t have the time (or
expertise) to solve MySQL problems from scratch.

d

vi

3r

Re

MySQL Cookbook

Paul DuBois
www.it-ebooks.info


d

■■

Sort query results and generate summaries

■■

Use stored routines, triggers, and scheduled events


■■

Import, export, validate, and reformat data

■■

Perform transactions and work with statistics

■■

Process web input, and generate web content from
query results

■■

Use MySQL-based web session management

■■

Provide security and server administration



—Ulf Wendel,

Senior Software Engineer for MySQL and
co-author of the mysqlnd PHP library

Paul DuBois is one of the primary contributors to the MySQL Reference Manual,

a renowned online manual that has supported MySQL administrators and
database developers for years. He’s a member of the MySQL documentation
team at Oracle and author of several books.

DATABA SES

CAN $83.99

ISBN: 978-1-449-37402-0

MySQL
Cookbook
SOLUTIONS FOR DATABASE DEVELOPERS AND ADMINISTRATORS

DuBois

Twitter: @oreillymedia
facebook.com/oreilly

d

Work with dates and times

te

■■

da

Store, retrieve, and manipulate strings


on

■■

Up

Create, populate, and select data from tables

iti

■■

d

Use the mysql client and write MySQL-based programs

an

■■

MySQL recipes available.
This book covers basics
needed by beginners, 
and presents the very 
latest developments that
advanced users can use 
to deepen their knowledge.
And it’s crowded with 
tips that make it even 

more valuable to MySQL
professionals.

Ed

se

Ideal for beginners and professional database and web developers, this
updated third edition covers powerful features in MySQL 5.6 (and some
in 5.7). The book focuses on programming APIs in Python, PHP, Java, Perl,
and Ruby. With more than 200+ recipes, you’ll learn how to:

classic, this remains 
“Athetrue
best collection of

THIRD EDITION

MySQL Cookbook

MySQL’s popularity has brought a flood of questions about how to solve
specific problems, and that’s where this cookbook is essential. When you
need quick solutions or techniques, this handy resource provides scores
of short, focused pieces of code, hundreds of worked-out examples, and
clear, concise explanations for programmers who don’t have the time (or
expertise) to solve MySQL problems from scratch.

US $79.99

d


vi

3r

Re

MySQL Cookbook

Paul DuBois
www.it-ebooks.info


THIRD EDITION

MySQL Cookbook

Paul DuBois

www.it-ebooks.info


MySQL Cookbook , Third Edition
by Paul DuBois
Copyright © 2014 Paul DuBois and O’Reilly Media, Inc.. All rights reserved.
Printed in the United States of America.
Published by O’Reilly Media, Inc., 1005 Gravenstein Highway North, Sebastopol, CA 95472.
O’Reilly books may be purchased for educational, business, or sales promotional use. Online editions are
also available for most titles (). For more information, contact our corporate/
institutional sales department: 800-998-9938 or


Editors: Andy Oram and Allyson MacDonald
Production Editor: Nicole Shelby
Proofreader: Kim Cofer
Indexer: Lucie Haskins
October 2002:

First Edition

November 2006:

Second Edition

August 2014:

Third Edition

Cover Designer: Randy Comer
Interior Designer: David Futato
Illustrator: Rebecca Demarest

Revision History for the Third Edition:
2014-07-25:

First release

See for release details.
Nutshell Handbook, the Nutshell Handbook logo, and the O’Reilly logo are registered trademarks of O’Reilly
Media, Inc. MySQL Cookbook, the picture of a green anole, and related trade dress are trademarks of O’Reilly
Media, Inc.

Many of the designations used by manufacturers and sellers to distinguish their products are claimed as
trademarks. Where those designations appear in this book, and O’Reilly Media, Inc. was aware of a trademark
claim, the designations have been printed in caps or initial caps.
While every precaution has been taken in the preparation of this book, the publisher and author assume no
responsibility for errors or omissions, or for damages resulting from the use of the information contained
herein.

ISBN: 978-1-449-37402-0
[LSI]

www.it-ebooks.info


Table of Contents

Preface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . xi
1. Using the mysql Client Program. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.1. Setting Up a MySQL User Account
1.2. Creating a Database and a Sample Table
1.3. What to Do if mysql Cannot Be Found
1.4. Specifying mysql Command Options
1.5. Executing SQL Statements Interactively
1.6. Executing SQL Statements Read from a File or Program
1.7. Controlling mysql Output Destination and Format
1.8. Using User-Defined Variables in SQL Statements

2
4
6
8

13
15
17
22

2. Writing MySQL-Based Programs. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
2.1. Connecting, Selecting a Database, and Disconnecting
2.2. Checking for Errors
2.3. Writing Library Files
2.4. Executing Statements and Retrieving Results
2.5. Handling Special Characters and NULL Values in Statements
2.6. Handling Special Characters in Identifiers
2.7. Identifying NULL Values in Result Sets
2.8. Techniques for Obtaining Connection Parameters
2.9. Conclusion and Words of Advice

29
42
51
65
79
89
91
95
103

3. Selecting Data from Tables. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105
3.1. Specifying Which Columns and Rows to Select
3.2. Naming Query Result Columns
3.3. Sorting Query Results

3.4. Removing Duplicate Rows
3.5. Working with NULL Values

106
108
112
113
114

iii

www.it-ebooks.info


3.6. Writing Comparisons Involving NULL in Programs
3.7. Using Views to Simplify Table Access
3.8. Selecting Data from Multiple Tables
3.9. Selecting Rows from the Beginning, End, or Middle of Query Results
3.10. What to Do When LIMIT Requires the “Wrong” Sort Order
3.11. Calculating LIMIT Values from Expressions

116
117
119
121
124
125

4. Table Management. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
4.1. Cloning a Table

4.2. Saving a Query Result in a Table
4.3. Creating Temporary Tables
4.4. Generating Unique Table Names
4.5. Checking or Changing a Table Storage Engine
4.6. Copying a Table Using mysqldump

127
128
131
133
135
136

5. Working with Strings. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139
5.1. String Properties
5.2. Choosing a String Data Type
5.3. Setting the Client Connection Character Set
5.4. Writing String Literals
5.5. Checking or Changing a String’s Character Set or Collation
5.6. Converting the Lettercase of a String
5.7. Controlling Case Sensitivity in String Comparisons
5.8. Pattern Matching with SQL Patterns
5.9. Pattern Matching with Regular Expressions
5.10. Breaking Apart or Combining Strings
5.11. Searching for Substrings
5.12. Using Full-Text Searches
5.13. Using a Full-Text Search with Short Words
5.14. Requiring or Prohibiting Full-Text Search Words
5.15. Performing Full-Text Phrase Searches


140
144
146
148
150
153
155
158
160
165
168
169
173
175
177

6. Working with Dates and Times. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 179
6.1. Choosing a Temporal Data Type
6.2. Using Fractional Seconds Support
6.3. Changing MySQL’s Date Format
6.4. Setting the Client Time Zone
6.5. Shifting Temporal Values Between Time Zones
6.6. Determining the Current Date or Time
6.7. Using TIMESTAMP or DATETIME to Track Row-Modification Times
6.8. Extracting Parts of Dates or Times
6.9. Synthesizing Dates or Times from Component Values

iv

|


Table of Contents

www.it-ebooks.info

180
182
183
187
189
190
191
194
199


6.10. Converting Between Temporal Values and Basic Units
6.11. Calculating Intervals Between Dates or Times
6.12. Adding Date or Time Values
6.13. Calculating Ages
6.14. Finding the First Day, Last Day, or Length of a Month
6.15. Calculating Dates by Substring Replacement
6.16. Finding the Day of the Week for a Date
6.17. Finding Dates for Any Weekday of a Given Week
6.18. Performing Leap-Year Calculations
6.19. Canonizing Not-Quite-ISO Date Strings
6.20. Selecting Rows Based on Temporal Characteristics

201
205

210
215
216
219
220
221
224
227
228

7. Sorting Query Results. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 233
7.1. Using ORDER BY to Sort Query Results
7.2. Using Expressions for Sorting
7.3. Displaying One Set of Values While Sorting by Another
7.4. Controlling Case Sensitivity of String Sorts
7.5. Date-Based Sorting
7.6. Sorting by Substrings of Column Values
7.7. Sorting by Fixed-Length Substrings
7.8. Sorting by Variable-Length Substrings
7.9. Sorting Hostnames in Domain Order
7.10. Sorting Dotted-Quad IP Values in Numeric Order
7.11. Floating Values to the Head or Tail of the Sort Order
7.12. Defining a Custom Sort Order
7.13. Sorting ENUM Values

234
238
239
243
246

250
250
254
258
261
263
266
267

8. Generating Summaries. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 271
8.1. Basic Summary Techniques
8.2. Creating a View to Simplify Using a Summary
8.3. Finding Values Associated with Minimum and Maximum Values
8.4. Controlling String Case Sensitivity for MIN() and MAX()
8.5. Dividing a Summary into Subgroups
8.6. Summaries and NULL Values
8.7. Selecting Only Groups with Certain Characteristics
8.8. Using Counts to Determine Whether Values Are Unique
8.9. Grouping by Expression Results
8.10. Summarizing Noncategorical Data
8.11. Finding Smallest or Largest Summary Values
8.12. Date-Based Summaries
8.13. Working with Per-Group and Overall Summary Values Simultaneously
8.14. Generating a Report That Includes a Summary and a List

Table of Contents

www.it-ebooks.info

273

279
280
282
283
287
290
291
292
293
296
298
300
303

|

v


9. Using Stored Routines, Triggers, and Scheduled Events. . . . . . . . . . . . . . . . . . . . . . . . . 307
9.1. Creating Compound-Statement Objects
9.2. Using Stored Functions to Encapsulate Calculations
9.3. Using Stored Procedures to “Return” Multiple Values
9.4. Using Triggers to Implement Dynamic Default Column Values
9.5. Using Triggers to Simulate Function-Based Indexes
9.6. Simulating TIMESTAMP Properties for Other Date and Time Types
9.7. Using Triggers to Log Changes to a Table
9.8. Using Events to Schedule Database Actions
9.9. Writing Helper Routines for Executing Dynamic SQL
9.10. Handling Errors Within Stored Programs

9.11. Using Triggers to Preprocess or Reject Data

310
312
314
315
317
320
322
325
327
328
332

10. Working with Metadata. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 335
10.1. Determining the Number of Rows Affected by a Statement
10.2. Obtaining Result Set Metadata
10.3. Determining Whether a Statement Produced a Result Set
10.4. Using Metadata to Format Query Output
10.5. Listing or Checking Existence of Databases or Tables
10.6. Accessing Table Column Definitions
10.7. Getting ENUM and SET Column Information
10.8. Getting Server Metadata
10.9. Writing Applications That Adapt to the MySQL Server Version

337
340
350
350
354

356
361
363
364

11. Importing and Exporting Data. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 367
11.1. Importing Data with LOAD DATA and mysqlimport
11.2. Importing CSV Files
11.3. Exporting Query Results from MySQL
11.4. Importing and Exporting NULL Values
11.5. Writing Your Own Data Export Programs
11.6. Converting Datafiles from One Format to Another
11.7. Extracting and Rearranging Datafile Columns
11.8. Exchanging Data Between MySQL and Microsoft Excel
11.9. Exporting Query Results as XML
11.10. Importing XML into MySQL
11.11. Guessing Table Structure from a Datafile

371
383
383
385
387
392
393
396
398
401
404


12. Validating and Reformatting Data. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 409
12.1. Using the SQL Mode to Reject Bad Input Values
12.2. Validating and Transforming Data
12.3. Using Pattern Matching to Validate Data
12.4. Using Patterns to Match Broad Content Types

vi

|

Table of Contents

www.it-ebooks.info

410
411
415
417


12.5. Using Patterns to Match Numeric Values
12.6. Using Patterns to Match Dates or Times
12.7. Using Patterns to Match Email Addresses or URLs
12.8. Using Table Metadata to Validate Data
12.9. Using a Lookup Table to Validate Data
12.10. Converting Two-Digit Year Values to Four-Digit Form
12.11. Performing Validity Checking on Date or Time Subparts
12.12. Writing Date-Processing Utilities
12.13. Importing Non-ISO Date Values
12.14. Exporting Dates Using Non-ISO Formats

12.15. Epilogue

418
420
424
425
428
431
432
435
440
441
442

13. Generating and Using Sequences. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 445
13.1. Creating a Sequence Column and Generating Sequence Values
13.2. Choosing the Definition for a Sequence Column
13.3. The Effect of Row Deletions on Sequence Generation
13.4. Retrieving Sequence Values
13.5. Renumbering an Existing Sequence
13.6. Extending the Range of a Sequence Column
13.7. Reusing Values at the Top of a Sequence
13.8. Ensuring That Rows Are Renumbered in a Particular Order
13.9. Sequencing an Unsequenced Table
13.10. Managing Multiple Auto-Increment Values Simultaneously
13.11. Using Auto-Increment Values to Associate Tables
13.12. Using Sequence Generators as Counters
13.13. Generating Repeating Sequences

446

449
451
453
457
460
460
461
462
464
465
467
471

14. Using Joins and Subqueries. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 473
14.1. Finding Matches Between Tables
14.2. Finding Mismatches Between Tables
14.3. Identifying and Removing Mismatched or Unattached Rows
14.4. Comparing a Table to Itself
14.5. Producing Master-Detail Lists and Summaries
14.6. Enumerating a Many-to-Many Relationship
14.7. Finding Per-Group Minimum or Maximum Values
14.8. Using a Join to Fill or Identify Holes in a List
14.9. Using a Join to Control Query Sort Order
14.10. Referring to Join Output Column Names in Programs

474
482
487
490
494

497
501
504
507
509

15. Statistical Techniques. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 511
15.1. Calculating Descriptive Statistics
15.2. Per-Group Descriptive Statistics

512
515

Table of Contents

www.it-ebooks.info

|

vii


15.3. Generating Frequency Distributions
15.4. Counting Missing Values
15.5. Calculating Linear Regressions or Correlation Coefficients
15.6. Generating Random Numbers
15.7. Randomizing a Set of Rows
15.8. Selecting Random Items from a Set of Rows
15.9. Calculating Successive-Row Differences
15.10. Finding Cumulative Sums and Running Averages

15.11. Assigning Ranks
15.12. Computing Team Standings

517
520
522
525
527
529
531
533
538
541

16. Handling Duplicates. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 549
16.1. Preventing Duplicates from Occurring in a Table
16.2. Dealing with Duplicates When Loading Rows into a Table
16.3. Counting and Identifying Duplicates
16.4. Eliminating Duplicates from a Table

550
552
556
560

17. Performing Transactions. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 565
17.1. Choosing a Transactional Storage Engine
17.2. Performing Transactions Using SQL
17.3. Performing Transactions from Within Programs
17.4. Using Transactions in Perl Programs

17.5. Using Transactions in Ruby Programs
17.6. Using Transactions in PHP Programs
17.7. Using Transactions in Python Programs
17.8. Using Transactions in Java Programs

566
567
569
571
573
574
575
576

18. Introduction to MySQL on the Web. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 577
18.1. Basic Principles of Web Page Generation
18.2. Using Apache to Run Web Scripts
18.3. Using Tomcat to Run Web Scripts
18.4. Encoding Special Characters in Web Output

579
581
591
596

19. Generating Web Content from Query Results. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 605
19.1. Displaying Query Results as Paragraphs
19.2. Displaying Query Results as Lists
19.3. Displaying Query Results as Tables
19.4. Displaying Query Results as Hyperlinks

19.5. Creating Navigation Indexes from Database Content
19.6. Storing Images or Other Binary Data
19.7. Serving Images or Other Binary Data
19.8. Serving Banner Ads

viii

|

Table of Contents

www.it-ebooks.info

606
608
618
622
626
631
638
641


19.9. Serving Query Results for Download

643

20. Processing Web Input with MySQL. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 647
20.1. Writing Scripts That Generate Web Forms
20.2. Creating Single-Pick Form Elements from Database Content

20.3. Creating Multiple-Pick Form Elements from Database Content
20.4. Loading Database Content into a Form
20.5. Collecting Web Input
20.6. Validating Web Input
20.7. Storing Web Input in a Database
20.8. Processing File Uploads
20.9. Performing Web-Based Database Searches
20.10. Generating Previous-Page and Next-Page Links
20.11. Generating “Click to Sort” Table Headings
20.12. Web Page Access Counting
20.13. Web Page Access Logging
20.14. Using MySQL for Apache Logging

650
653
669
674
679
689
691
694
700
703
708
712
716
717

21. Using MySQL-Based Web Session Management. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 725
21.1. Using MySQL-Based Sessions in Perl Applications

21.2. Using MySQL-Based Storage in Ruby Applications
21.3. Using MySQL-Based Storage with the PHP Session Manager
21.4. Using MySQL for Session-Backing Store with Tomcat

728
734
738
748

22. Server Administration. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 757
22.1. Configuring the Server
22.2. Managing the Plug-In Interface
22.3. Controlling Server Logging
22.4. Rotating or Expiring Logfiles
22.5. Rotating Log Tables or Expiring Log Table Rows
22.6. Monitoring the MySQL Server
22.7. Creating and Using Backups

757
760
762
765
768
769
780

23. Security. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 783
23.1. Understanding the mysql.user Table
23.2. Managing User Accounts
23.3. Implementing a Password Policy

23.4. Checking Password Strength
23.5. Expiring Passwords
23.6. Assigning Yourself a New Password
23.7. Resetting an Expired Password
23.8. Finding and Fixing Insecure Accounts

784
785
790
793
794
795
795
796

Table of Contents

www.it-ebooks.info

|

ix


23.9. Disabling Use of Accounts with Pre-4.1 Passwords
23.10. Finding and Removing Anonymous Accounts
23.11. Modifying “Any Host” and “Many Host” Accounts

800
801

802

Index. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 805

x

|

Table of Contents

www.it-ebooks.info


Preface

The MySQL database management system is popular for many reasons. It’s fast, and it’s
easy to set up, use, and administer. It runs under many varieties of Unix and Windows,
and MySQL-based programs can be written in many languages.
MySQL’s popularity raises the need to address questions its users have about how to
solve specific problems. That is the purpose of MySQL Cookbook: to serve as a handy
resource to which you can turn for quick solutions or techniques for attacking particular
types of questions that come up when you use MySQL. Naturally, because it’s a cookbook,
it contains recipes: straightforward instructions you can follow rather than develop your
own code from scratch. It’s written using a problem-and-solution format designed to
be extremely practical and to make the contents easy to read and assimilate. It contains
many short sections, each describing how to write a query, apply a technique, or develop
a script to solve a problem of limited and specific scope. This book doesn’t develop fullfledged, complex applications. Instead, it assists you in developing such applications
yourself by helping you get past problems that have you stumped.
For example, a common question is, “How can I deal with quotes and special characters
in data values when I’m writing queries?” That’s not difficult, but figuring out how to

do it is frustrating when you’re not sure where to start. This book demonstrates what
to do; it shows you where to begin and how to proceed from there. This knowledge will
serve you repeatedly because after you see what’s involved, you’ll be able to apply the
technique to any kind of data, such as text, images, sound or video clips, news articles,
compressed files, or PDF documents. Another common question is, “Can I access data
from multiple tables at the same time?” The answer is “Yes,” and it’s easy to do because
it’s just a matter of knowing the proper SQL syntax. But it’s not always clear how until
you see examples, which this book gives you. Other techniques that you’ll learn from
this book include how to:
• Use SQL to select, sort, and summarize rows
• Find matches or mismatches between tables

xi

www.it-ebooks.info


• Perform transactions
• Determine intervals between dates or times, including age calculations
• Identify or remove duplicate rows
• Use LOAD DATA to read your datafiles properly or find which values in the file are
invalid
• Use strict mode to prevent entry of bad data into your database
• Generate sequence numbers to use as unique row identifiers
• Use a view as a “virtual table”
• Write stored procedures and functions, set up triggers that activate to perform
specific data-handling operations when you insert or update table rows, and use
the Event Scheduler to run queries on a schedule
• Generate web pages from database content
• Manage user accounts

• Control server logging
One part of using MySQL is understanding how to communicate with the server—that
is, how to use SQL, the language in which queries are formulated. Therefore, one major
emphasis of this book is using SQL to formulate queries that answer particular kinds of
questions. One helpful tool for learning and using SQL is the mysql client program that
is included in MySQL distributions. You can use client interactively to send SQL state‐
ments to the server and see the results. This is extremely useful because it provides a
direct interface to SQL; so useful, in fact, that the first chapter is devoted to mysql.
But the ability to issue SQL queries alone is not enough. Information extracted from a
database often requires further processing or presentation in a particular way. What if
you have queries with complex interrelationships, such as when you need to use the
results of one query as the basis for others? What if you need to generate a specialized
report with very specific formatting requirements? These problems bring us to the other
major emphasis of the book—how to write programs that interact with the MySQL
server through an application programming interface (API). When you know how to
use MySQL from within the context of a programming language, you gain other ways
to exploit MySQL’s capabilities:
• You can save query results and reuse them later.
• You have full access to the expressive power of a general-purpose programming
language. This enables you to make decisions based on success or failure of a query,
or on the content of the rows that are returned, and then tailor the actions taken
accordingly.

xii

|

Preface

www.it-ebooks.info



• You can format and display query results however you like. If you’re writing a
command-line script, you can generate plain text. If it’s a web-based script, you can
generate an HTML table. If it’s an application that extracts information for transfer
to some other system, you might generate a datafile expressed in XML.
Combining SQL with a general-purpose programming language gives you an extremely
flexible framework for issuing queries and processing their results. Programming lan‐
guages increase your capability to perform complex database operations. But that
doesn’t mean this book is complex. It keeps things simple, showing how to construct
small building blocks using techniques that are easy to understand and easily mastered.
I’ll leave it to you to combine these techniques in your own programs, which you can
do to produce arbitrarily complex applications. After all, the genetic code is based on
only four nucleic acids, but these basic elements have been combined to produce the
astonishing array of biological life we see all around us. Similarly, there are only 12 notes
in the scale, but in the hands of skilled composers, they are interwoven to produce a
rich and endless variety of music. In the same way, when you take a set of simple recipes,
add your imagination, and apply them to the database programming problems you want
to solve, you can produce applications that perhaps are not works of art, but are certainly
useful and will help you and others be more productive.

Who This Book Is For
This book will be useful for anybody who uses MySQL, ranging from individuals who
want to use a database for personal projects such as a blog or wiki, to professional
database and web developers. The book is also intended for people who do not now use
MySQL, but would like to. For example, it will be useful if you want to learn about
databases but realize that a “big” database system such as Oracle can be daunting as a
learning tool. (Perhaps I shouldn’t say that. Oracle bought MySQL in 2010 and is now
my employer!)
If you’re new to MySQL, you’ll find lots of ways to use it here that may be new to you.

If you’re more experienced, you’re probably already familiar with many of the problems
addressed here, but may not have had to solve them before and should find the book a
great timesaver. Take advantage of the recipes given in the book and use them in your
own programs rather than writing the code from scratch.
The material ranges from introductory to advanced, so if a recipe describes techniques
that seem obvious to you, skip it. Conversely, if you don’t understand a recipe, set it
aside and come back to it later, perhaps after reading some of the other recipes.

Preface

www.it-ebooks.info

|

xiii


What’s in This Book
It’s very likely when you use this book that you’re trying to develop an application but
are not sure how to implement certain pieces of it. In this case, you already know what
type of problem you want to solve; check the table of contents or the index for a recipe
that shows how to do what you want. Ideally, the recipe will be just what you had in
mind. Alternatively, you may be able to adapt a recipe for a similar problem to suit the
issue at hand. I explain the principles involved in developing each technique so that you
can modify it to fit the particular requirements of your own applications.
Another way to approach this book is to just read through it with no specific problem
in mind. This can give you a broader understanding of the things MySQL can do, so I
recommend that you page through the book occasionally. It’s a more effective tool if
you know the kinds of problems it addresses.
As you get into later chapters, you’ll find recipes that assume a knowledge of topics

covered in earlier chapters. This also applies within a chapter, where later sections often
use techniques discussed earlier in the chapter. If you jump into a chapter and find a
recipe that uses a technique with which you’re not familiar, check the table of contents
or the index to find where the technique is explained earlier. For example, if a recipe
sorts a query result using an ORDER BY clause that you don’t understand, turn to Chap‐
ter 7, which discusses various sorting methods and explains how they work.
Here’s a summary of each chapter to give you an overview of the book’s contents.
Chapter 1, Using the mysql Client Program, describes how to use the standard MySQL
command-line client. mysql is often the first or primary interface to MySQL that people
use, and it’s important to know how to exploit its capabilities. This program enables you
to issue queries and see their results interactively, so it’s good for quick experimentation.
You can also use it in batch mode to execute canned SQL scripts or send its output into
other programs. In addition, the chapter discusses other ways to use mysql, such as how
to make long lines more readable or generate output in various formats.
Chapter 2, Writing MySQL-Based Programs, demonstrates the essential elements of
MySQL programming: how to connect to the server, issue queries, retrieve the results,
and handle errors. It also discusses how to handle special characters and NULL values in
queries, how to write library files to encapsulate code for commonly used operations,
and various ways to gather the parameters needed for making connections to the server.
Chapter 3, Selecting Data from Tables, covers several aspects of the SELECT statement,
which is the primary vehicle for retrieving data from the MySQL server: specifying
which columns and rows you want to retrieve, dealing with NULL values, and selecting
one section of a query result. Later chapters cover some of these topics in more detail,
but this chapter provides an overview of the concepts on which they depend if you need
some introductory background on row selection or don’t yet know a lot about SQL.

xiv

| Preface


www.it-ebooks.info


Chapter 4, Table Management, covers table cloning, copying results into other tables,
using temporary tables, and checking or changing a table’s storage engine.
Chapter 5, Working with Strings, describes how to deal with string data. It covers char‐
acter sets and collations, string comparisons, dealing with case-sensitivity issues, pattern
matching, breaking apart and combining strings, and performing FULLTEXT searches.
Chapter 6, Working with Dates and Times, shows how to work with temporal data. It
describes MySQL’s date format and how to display date values in other formats. It also
covers how to use MySQL’s special TIMESTAMP data type, how to set the time zone, how
to convert between different temporal units, how to perform date arithmetic to compute
intervals or generate one date from another, and how to perform leap-year calculations.
Chapter 7, Sorting Query Results, describes how to put the rows of a query result in the
order you want. This includes specifying the sort direction, dealing with NULL values,
accounting for string case sensitivity, and sorting by dates or partial column values. It
also provides examples that show how to sort special kinds of values, such as domain
names, IP numbers, and ENUM values.
Chapter 8, Generating Summaries, shows techniques for assessing the general charac‐
teristics of a set of data, such as how many values it contains or its minimum, maximum,
and average values.
Chapter 9, Using Stored Routines, Triggers, and Scheduled Events, describes how to write
stored functions and procedures that are stored on the server side, triggers that activate
when tables are modified, and events that execute on a scheduled basis.
Chapter 10, Working with Metadata, discusses how to get information about the data
that a query returns, such as the number of rows or columns in the result, or the name
and data type of each column. It also shows how to ask MySQL what databases and
tables are available or determine the structure of a table.
Chapter 11, Importing and Exporting Data, describes how to transfer information be‐
tween MySQL and other programs. This includes how to use LOAD DATA, convert files

from one format to another, and determine table structure appropriate for a dataset.
Chapter 12, Validating and Reformatting Data, describes how to extract or rearrange
columns in datafiles, check and validate data, and rewrite values such as dates that often
come in a variety of formats.
Chapter 13, Generating and Using Sequences, discusses AUTO_INCREMENT columns,
MySQL’s mechanism for producing sequence numbers. It shows how to generate new
sequence values or determine the most recent value, how to resequence a column, and
how to use sequences to generate counters. It also shows how to use AUTO_INCREMENT
values to maintain a master-detail relationship between tables, including pitfalls to
avoid.

Preface

www.it-ebooks.info

|

xv


Chapter 14, Using Joins and Subqueries, shows how to perform operations that select
rows from multiple tables. It demonstrates how to compare tables to find matches or
mismatches, produce master-detail lists and summaries, and enumerate many-to-many
relationships.
Chapter 15, Statistical Techniques, illustrates how to produce descriptive statistics, fre‐
quency distributions, regressions, and correlations. It also covers how to randomize a
set of rows or pick rows at random from the set.
Chapter 16, Handling Duplicates, discusses how to identify, count, and remove duplicate
rows—and how to prevent them from occurring in the first place.
Chapter 17, Performing Transactions, shows how to handle multiple SQL statements

that must execute together as a unit. It discusses how to control MySQL’s auto-commit
mode and how to commit or roll back transactions.
Chapter 18, Introduction to MySQL on the Web, gets you set up to write web-based
MySQL scripts. Web programming enables you to generate dynamic pages from data‐
base content or collect information for storage in your database. The chapter discusses
how to configure Apache to run Perl, Ruby, PHP, and Python scripts, and how to con‐
figure Tomcat to run Java scripts written using JSP notation.
Chapter 19, Generating Web Content from Query Results, shows how to use the query
results to generate various HTML structures such as paragraphs, lists, tables, hyperlinks,
and navigation indexes. It also describes how to store images into MySQL and retrieve
and display them later, and how to generate downloadable result sets.
Chapter 20, Processing Web Input with MySQL, discusses how to obtain input from
users over the Web and use it to create new database rows or as the basis for performing
searches. It deals heavily with form processing, including how to construct form ele‐
ments such as radio buttons, pop-up menus, or checkboxes, based on information con‐
tained in your database.
Chapter 21, Using MySQL-Based Web Session Management, describes how to write web
applications that remember information across multiple requests, using MySQL for
backing store. This is useful for collecting information in stages, or when you need to
make decisions based on prior user actions.
Chapter 22, Server Administration, is written for database administrators. It covers
server configuration, the plug-in interface, log management, server monitoring, and
making backups.
Chapter 23, Security, is another administrative chapter. It discusses user account man‐
agement, including creating accounts, setting passwords, and assigning privileges. It
also describes how to implement password policy, find and fix insecure accounts, and
expire or unexpire passwords.

xvi


|

Preface

www.it-ebooks.info


MySQL APIs Used in This Book
MySQL programming interfaces exist for many languages, including C, C++, Eiffel, Go,
Java, Perl, PHP, Python, Ruby, and Tcl. Given this fact, writing a MySQL cookbook
presents an author with a challenge. The book should provide recipes for doing many
interesting and useful things with MySQL, but which API or APIs should the book use?
Showing an implementation of every recipe in every language results either in covering
very few recipes or in a very, very large book! It also results in redundancies when
implementations in different languages bear a strong resemblance to each other. On the
other hand, it’s worthwhile taking advantage of multiple languages, because one often
is more suitable than another for solving a particular problem.
To resolve this dilemma, I’ve chosen a small number of APIs to write the recipes in this
book. This makes its scope manageable while permitting latitude to choose from mul‐
tiple APIs:
• The Perl and Ruby DBI modules
• PHP, using the PDO extension
• Python, using the MySQL Connector/Python driver for the DB API
• Java, using the MySQL Connector/J driver for the JDBC interface
Why these languages? Perl and PHP were easy to pick. Perl is a widely used language
that became so based on certain strengths such as its text-processing capabilities. In
addition, it’s very popular for writing MySQL programs. Ruby has an easy-to-use
database-access module modeled after the Perl module. PHP is widely deployed, espe‐
cially on the Web. One of PHP’s strengths is the ease with which you can use it to access
databases, making it a natural choice for MySQL scripting. Python and Java are perhaps

not as popular as Perl or PHP for MySQL programming, but each has a significant
number of followers. In the Java community in particular, MySQL has a strong following
among developers who use JavaServer Pages (JSP) technology to build database-backed
web applications.
I believe these languages taken together reflect pretty well the majority of the existing
user base of MySQL programmers. If you prefer some language not shown here, be sure
to pay careful attention to Chapter 2, to familiarize yourself with the book’s primary
APIs. Knowing how to perform database operations with the programming interfaces
used here will help you translate recipes for other languages.

Version and Platform Notes
Development of the code in this book took place under MySQL 5.5, 5.6, and 5.7. Because
new features are added to MySQL on a regular basis, some examples will not work under
older versions. For example, MySQL 5.5 introduces authentication plug-ins, and
Preface

www.it-ebooks.info

|

xvii


MySQL 5.6 introduces TIMESTAMP-like auto-initialization and auto-update properties
for the DATETIME data type.
I do not assume that you are using Unix, although that is my own preferred development
platform. (In this book, “Unix” also refers to Unix-like systems such as Linux and Mac
OS X.) Most of the material here is applicable both to Unix and Windows.

Conventions Used in This Book

This book uses the following font conventions:
Constant width

Used for program listings, as well as within paragraphs to refer to program elements
such as variable or function names, databases, data types, environment variables,
statements, and keywords.
Constant width bold

Used to indicate text that you type when running commands.
Constant width italic

Used to indicate variable input; you should substitute a value of your own choosing.
Italic
Used for URLs, hostnames, names of directories and files, Unix commands and
options, programs, and occasionally for emphasis.
This element signifies a tip or suggestion.

This element indicates a warning or caution.

This element signifies a general note.

Commands often are shown with a prompt to illustrate the context in which they are
used. Commands issued from the command line are shown with a % prompt:
xviii

| Preface

www.it-ebooks.info



% chmod 600 my.cnf

That prompt is one that Unix users are used to seeing, but it doesn’t necessarily signify
that a command works only under Unix. Unless indicated otherwise, commands shown
with a % prompt generally should work under Windows, too.
If you should run a command under Unix as the root user, the prompt is # instead:
# perl -MCPAN -e shell

Commands that are specific to Windows use the C:\> prompt:
C:\> "C:\Program Files\MySQL\MySQL Server 5.6\bin\mysql"

SQL statements that are issued from within the mysql client program are shown with a

mysql> prompt and terminated with a semicolon:
mysql> SELECT * FROM my_table;

For examples that show a query result as you would see it when using mysql, I sometimes
truncate the output, using an ellipsis (...) to indicate that the result consists of more
rows than are shown. The following query produces many rows of output, from which
those in the middle have been omitted:
mysql> SELECT name, abbrev FROM states ORDER BY name;
+----------------+--------+
| name
| abbrev |
+----------------+--------+
| Alabama
| AL
|
| Alaska
| AK

|
| Arizona
| AZ
|

| West Virginia | WV
|
| Wisconsin
| WI
|
| Wyoming
| WY
|
+----------------+--------+

Examples that show only the syntax for SQL statements do not include the mysql>
prompt, but they do include semicolons as necessary to make it clearer where statements
end. For example, this is a single statement:
CREATE TABLE t1 (i INT)
SELECT * FROM t2;

But this example represents two statements:
CREATE TABLE t1 (i INT);
SELECT * FROM t2;

The semicolon is a notational convenience used within mysql as a statement terminator.
But it is not part of SQL itself, so when you issue SQL statements from within programs
that you write (for example, using Perl or Java), don’t include terminating semicolons.

Preface


www.it-ebooks.info

|

xix


The MySQL Cookbook Companion Website
MySQL Cookbook has a companion website where you can obtain source code and
sample data for examples developed throughout this book, errata, and auxiliary docu‐
mentation.
The website also makes examples from the book available online so you can try them
from your browser.

Recipe Source Code and Data
The examples in this book are based on source code and sample data from two distri‐
butions named recipes and mcb-kjv available at the companion website.
The recipes distribution is the primary source of examples, and references to it occur
throughout the book. The distribution is available as a compressed TAR file (rec
ipes.tar.gz) or as a ZIP file (recipes.zip). Either distribution format when unpacked cre‐
ates a directory named recipes.
Use the recipes distribution to save yourself a lot of typing. For example, when you see
a CREATE TABLE statement in the book that describes what a database table looks like,
you’ll usually find an SQL batch file in the tables directory that you can use to create the
table instead of entering the definition manually. Change location into the tables direc‐
tory and execute the following command, where filename is the name of the file con‐
taining the CREATE TABLE statement:
% mysql cookbook < filename


If you need to specify MySQL username or password options, add them to the command
line.
The recipes distribution contains programs as shown in the book, but in many cases
also includes implementations in additional languages. For example, a script shown in
the book using Python may be available in the recipes distribution in Perl, Ruby, PHP,
or Java as well. This may save you translation effort should you wish to convert a program
shown in the book to a different language.
The other distribution is named mcb-kjv and contains the text of the King James Version
of the Bible, formatted suitably for loading into MySQL. It’s used in Chapter 5 as the
source of a reasonably large body of text for examples that demonstrate FULLTEXT
searches, and occasionally elsewhere in the book. This distribution is provided sepa‐
rately from the recipes distribution due to its size. It’s available as a compressed TAR
file (mcb-kjv.tar.gz) or as a ZIP file (mcb-kjv.zip). Either distribution format when un‐
packed creates a directory named mcb-kjv.

xx

|

Preface

www.it-ebooks.info


The mcb-kjv distribution is derived from KJV text originally found on the Unbound
Bible site, restructured to be more usable for examples in the book. The distribution
includes notes that describe the modifications I made.

MySQL Cookbook Companion Documents
Some appendixes included in previous MySQL Cookbook editions are now available in

standalone form at the companion website. They provide background information for
topics covered in the book.
• “Executing Programs from the Command Line” provides instructions for executing
commands at the command prompt and setting environment variables such as
PATH.
• “JSP, JSTL, and Tomcat Primer” provides a general overview of JavaServer Pages
(JSP) programming and installation instructions for the Tomcat web server. Read
this document if you need to install Tomcat or are not familiar with it, or if you’ve
never written pages using JSP notation. It also provides an overview of the Java
Standard Tag Library (JSTL) that is used heavily for JSP pages in this book. This
material is background for topics covered in the web programming chapters, be‐
ginning with Chapter 18.

Obtaining MySQL and Related Software
To run the examples in this book, you need access to MySQL, as well as the appropriate
MySQL-specific interfaces for the programming languages that you want to use. The
following notes describe what software is required and where to get it.
If you access a MySQL server run by somebody else, you need only the MySQL client
software on your own machine. To run your own server, you need a full MySQL dis‐
tribution.
To write your own MySQL-based programs, you communicate with the server through
a language-specific API. The Perl and Ruby interfaces rely on the MySQL C API client
library to handle the low-level client-server protocol. This is also true for the PHP
interface, unless PHP is configured to use mysqlnd, the native protocol driver. For Perl
and Ruby, you must install the C client library and header files first. PHP includes the
required MySQL client support files, but must be compiled with MySQL support en‐
abled or you won’t be able to use it. The Python and Java drivers for MySQL implement
the client-server protocol directly, so they do not require the MySQL C client library.
You may not need to install the client software yourself—it might already be present on
your system. This is a common situation if you have an account with an Internet service


Preface

www.it-ebooks.info

|

xxi


provider (ISP) that provides services such as a web server already enabled for access to
MySQL.

MySQL
MySQL distributions and documentation, including the MySQL Reference Manual, are
available from and />If you need to install the MySQL C client library and header files, they’re included when
you install MySQL from a source distribution, or when you install MySQL using a binary
(precompiled) distribution other than an RPM binary distribution. Under Linux, you
have the option of installing MySQL using RPM files, but the client library and header
files are not installed unless you install the development RPM. (There are separate RPM
files for the server, the standard client programs, and the development libraries and
header files.) If you don’t install the development RPM, you’ll join the many Linux users
who’ve asked, “I installed MySQL, but I cannot find the libraries or header files; where
are they?”

Perl Support
General Perl information is available on the Perl Programming Language website.
You can obtain Perl software from the Comprehensive Perl Archive Network (CPAN).
To write MySQL-based Perl programs, you need the DBI module and the MySQLspecific DBD module, DBD::mysql.
To install these modules under Unix, let Perl itself help you. For example, to install DBI

and DBD::mysql, run the following commands (you’ll probably need to do this as root):
# perl -MCPAN -e shell
cpan> install DBI
cpan> install DBD::mysql

If the last command complains about failed tests, use force install DBD::mysql in‐
stead. Under ActiveState Perl for Windows, use the ppm utility:
C:\> ppm
ppm> install DBI
ppm> install DBD-mysql

You can also use the CPAN shell or ppm to install other Perl modules mentioned in this
book.
Once the DBI and DBD::mysql modules are installed, documentation is available from
the command line:
% perldoc DBI
% perldoc DBI::FAQ
% perldoc DBD::mysql

xxii

|

Preface

www.it-ebooks.info


Documentation is also available from the Perl website.


Ruby Support
The primary Ruby website provides access to Ruby distributions and documentation.
The Ruby DBI and MySQL driver modules are available from RubyGems; the Ruby DBI
driver for MySQL requires the mysql-ruby module, also available from RubyGems.
To use session support as described in Chapter 21, you need the mysql-session package.
It’s available from the MySQL Cookbook companion website described earlier in this
Preface. Obtain the mysql-session package, unpack it, and install its mysqlstore.rb and
sqlthrow.rb files in some directory that your Ruby interpreter searches when looking
for library files (see Recipe 2.3).

PHP Support
The primary PHP website provides access to PHP distributions and documentation,
including PDO documentation.
PHP source distributions include PDO support, so you need not obtain it separately.
However, you must enable PDO support for MySQL when you configure the distribu‐
tion. If you use a binary distribution, be sure that it includes PDO MySQL support.

Python Support
The primary Python website provides access to Python distributions and documenta‐
tion. General documentation for the DB API database access interface is on the Python
Wiki.
For MySQL Connector/Python, the driver module that provides MySQL connectivity
for the DB API, distributions and documentation are available from and />
Java Support
You need a Java compiler to build and run Java programs. The javac and jikes compilers
are two possible choices. On many systems, you’ll find one or both installed already.
Otherwise, you can get a compiler as part of the Java Development Kit (JDK). If no JDK
is installed on your system, versions are available for Solaris, Linux, and Windows at
Oracle’s Java site. The same site provides access to documentation (including the spec‐
ifications) for JDBC, servlets, JavaServer Pages (JSP), and the JSP Standard Tag Library

(JSTL).

Preface

www.it-ebooks.info

|

xxiii


Tài liệu bạn tìm kiếm đã sẵn sàng tải về

Tải bản đầy đủ ngay
×