Php/mysql 3rd-Third day (ii)

Source: Internet
Author: User
Tags define ereg expression html tags connect variable valid mysql database
III. handling of regular expressions

Let's talk a little bit about regular expressions with ereg () and eregi () two functions. As I mentioned earlier, some of these functions are simple, and some are very complex, which depends on your actual needs.

With regular expressions, you can examine a string and search for some of its structural patterns to determine whether these patterns meet your requirements. The most common uses include checking that an e-mail address is valid (and, of course, that the email address does not really exist even if the method is judged to be valid).

Here we do not examine the complex details of regular expressions, just give a few examples. You can use the table used in the previous page-copy the appropriate program code and add it to the following code snippet to see how it works.

First, we want to make sure that the columns in the table can only enter letters. The following general expression is true when the user enters one or more lowercase letters, and the input number is not allowed:

if (!ereg ("[A-Z]", $first) | |!ereg ("[A-Z]", $last)) {

Now we go further and check whether the string is four to six characters long. using [[: Alpha:]] is a simple way to check that characters are not letters. The numbers in the curly braces check the number of characters. Also note that ^ and $ represent the beginning and end of the string, respectively.

if (!ereg ("^[[:alpha:]]{4,6}$", $first) | |!ereg ("^[[:alpha:]]{4,6}$", $last)) {

Finally, we construct a regular expression that verifies the validity of an e-mail address. The effect of this type of test has already sparked quite a lot of discussion. Nothing is perfect, but the procedure I have given below is very effective.

  if (!ereg) (^[-!#$%&\*+\\./0-9=? A-z^_ ' a-z{|} ~]+.

@.

[-!#$%&\*+\\/0-9=? A-z^_ ' a-z{|} ~]+\..

[-!#$%&\*+\\./0-9=? A-z^_ ' a-z{|} ~]+$, $last)) {

Don't spend too much time to scrutinize this code, or first to the next page of content.

Four, simple method

What about the previous regular expressions? It's interesting, isn't it? Would it be interesting to write a procedure in every program that needs to check an email address? Think about it, have to write so messy a program, but also have to write so many times! ... But, of course, there's a simpler way.

Do you remember the front? Did you learn the header papers? It allows us to write a program, like the check procedure for this email address, and then include the program in multiple programs. In this way, if we want to rewrite this program, we just need to change one place and do not need to modify multiple files.

But to do this, we have to use a function.

We've used many times. Every time we query the database or check the length of the string, we do it with a function. These are the functions that PHP takes from you. If you are an enthusiastic programmer, you can use the functions you have written to augment the functionality of PHP itself. But this part of the tutorial is a bit too advanced. The function we want to create is not the one, but the function written inside the PHP script.

A function is a piece of program code, we can pass one or more values to this code, and then this code will process the data we pass to it and return a value. Depending on the actual needs, the function can be simple or complex. But as long as we pass in a number, and then can get a number, you control it is complex or simple it! This is the loveliness of the function.

The function in PHP is similar to the function in C language. When we define a function, we must indicate what data the function needs to receive. It doesn't seem very good at first to understand why it has to receive data, but it can prevent some weird problems. The function can do this because the variables inside the function are private variables, that is, it exists only within the function. For example, you have a variable called $myname in your program, and if you create a function, you want the function to use that $myname variable (the value is the same), that's not going to work. You can create a variable inside a function, called $myname, which can be used to get together, but with different values. But I don't suggest you do that! If you do, you may get confused when you wait six months to revise the program.

So we're going to create a function right now, let's start with a simple one. We're going to give it a name and specify what variable it's going to receive. We also have to define this function before we call this function.

  $#@60;html$#@62;

$#@60;body$#@62;

$#@60;? Php

function Addnum ($first, $second) {

$newnum = $first + $second;

return $newnum;

}

echo Addnum (4,5);

? $#@62;

$#@60;/body$#@62;

$#@60;/html$#@62;

It's all right! First, we created our own first function. We have defined two new variables, $first and $second, and notice how they are defined. When calling this function, give the two variables a value of 4 assigned to the $first,5 in the order in which they appear. Then we simply add the two numbers together and return the results. "Back" here means sending the results back. In the final part of the program we show the number 9.

Let's create a function that will help a little bit with our database application. What about a function that handles errors properly? Try the following procedure:

  $#@60;html$#@62;

$#@60;body$#@62;

$#@60;? Php

function Do_error ($error) {


echo "Oh, it seems a bit of a problem ... $#@60;br$#@62;";


The error reported by Echo system is: $error. \n$#@60;br$#@62; ";


echo "It is best to temporarily close the Web site and notify the system administrator." ";

Die

}


if (! $db = @mysql_connect ("localhost", "User", "password")) {


$db _error = "Unable to connect to MySQL database";

Do_error ($db _error);
}

? $#@62;

$#@60;/body$#@62;

$#@60;/html$#@62;

Before running the program, try shutting down the MySQL database or using the wrong username or password. You will see a friendly, useful error message. A careful friend notices the @ symbol before the mysql_connect () function. It suppresses system error messages, allowing the program to get information about the error only from the Do_error () function. You'll also notice that we can pass a variable defined elsewhere as a parameter to a function, rather than assigning a value directly to the call.

Remember when I used a private variable for a function? That's not exactly the right words to say. In fact, you can have the function access to variables outside the function. You might want to write a function that queries the database and then displays the results in multiple pages. You don't want to pass the database connection identity to the function every time. In this case, you can define the connection identity as a global variable. For example:

  $#@60;html$#@62;

$#@60;body$#@62;

$#@60;? Php

function Db_query ($sql) {

Global $db;

$result = mysql_query ($sql, $db);

return $result;

}

$sql = "SELECT * FROM MyTable";

$result = Db_query ($sql);

? $#@62;

$#@60;/body$#@62;

$#@60;/html$#@62;

This is a very simple function, but it is important that you do not have to pass the $DB variable when you call this function-you can use the Word global to enable the function to access the variable. In this statement you can define multiple global variables, separated by commas between the individual global variables.

Finally, you can use optional parameters so that you seem to be a real expert. The key point here is that you specify a default value when you define a parameter in a function. Then, when you call this function, if you do not specify a different value for the parameter variable, the function automatically assigns the default value to the variable. If you specify a different value, the default value does not work.

Don't understand? For example, when you connect to a database, you are almost always connected to the same server and use the same username and password. Sometimes, however, you also need to connect to other servers. Look at the following program:

  $#@60;html$#@62;

$#@60;body$#@62;

$#@60;? Php



function Db_connect ($host = "localhost", $user = "username", $pass = "Graeme") {

$db = mysql_connect ($host, $username, $password);

return $db;

}


$old _db = Db_connect ();



$new _host = "site.com";

$new _db = db_connect ($new _host);

? $#@62;


$#@60;/body$#@62;

$#@60;/html$#@62;

It's cool, isn't it? When you define a function, the variables used inside the function are defined as well. The first time this function is called, all parameter variables are the default values used. On the second call, the server name changed, and the username and password did not change. Oh, that's great!

Think about where you can still use a function. You can use functions for data validation to perform commonly used functions, and so on. I use a lot of functions when I work with text that is displayed on a Web page. I can finish checking, parsing, and modifying the text at once to add line breaks and HTML tags.

Now, the rest is the advice I have to give you.

Five, advanced skills

Talking about database development, we have a lot of things to learn. If you haven't learned how to design a database, and how to run the database reliably on different platforms, go and find a good book to read. This ability will bring you immeasurable benefits, in the long run, it will save you a lot of time and energy. Also, learn to learn MySQL carefully. This is a complex and interesting database with a lot of good documentation. The table structure, data type and SQL of the Learning database. If you have a real grasp of SQL, you can do quite a lot of actual work.

Finally, there's PHP. Almost everything you want can be found on the PHP Web site, including comprehensive documentation, discussion of mail discussion groups, program code base, and so on. An excellent way to learn about PHP is to study the examples given in the user's manual and look up the code on the Web. The code that users publish includes many functions and classes that you can use directly in your program without having to start over yourself. In addition, if you are having problems, the mail discussion group is a resource that is worth taking advantage of. PHP developers themselves will also participate in the mail discussion group, as well as many experienced experts, they can help you solve the problem.

I wish you a smooth programming, everything goes well!



Related Article

Contact Us

The content source of this page is from Internet, which doesn't represent Alibaba Cloud's opinion; products and services mentioned on that page don't have any relationship with Alibaba Cloud. If the content of the page makes you feel confusing, please write us an email, we will handle the problem within 5 days after receiving your email.

If you find any instances of plagiarism from the community, please send an email to: info-contact@alibabacloud.com and provide relevant evidence. A staff member will contact you within 5 working days.

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.