MySql教程

MySQL简介



什么是MySQL?

MySQL是一个多用户、多线程的SQL数据库,是一个客户机/服务器结构的应用,它由一个服务器守护程序mysqld和很多不同的客户程序和库组成。
SQL (Structured Query Language结构化查询语言)是目前使用最广的并且是标准的数据库语言。SQL语言使得存取或更新信息变得十分容易,你可以直接使用SQL从网站上查询信息。MySQL的快速和灵活性足以满足一个网站的信息管理工作。数据库与用户端之间的接口程序可以使用CGI进行通信。新网ChinaDNS使用的是PHP,使用PHP和MySQL这两样东西加在一起,对于开发数据驱动的网站这项工作而言是最佳组合。PHP是一种用于服务器端执行程序解释的脚本语言。如果你接触过ASP的话,那么您对于在HTML页面中嵌入代码应该是比较熟悉了。PHP代码在服务器一端被解释、执行并转变成普通的HTML页面内容,送给浏览器一端。这种模式使得我们可以用它来完成相当复杂的功能。


为什么用MySQL?

现在每一个人的生活几乎都离不开数据库,如果没有数据库,很多事情都会变得非常棘手,也许根本无法做得到。银行、大学和图书馆就是几个严重依赖数据库系统的地方。在互联网上,使用搜索引擎、在线购物甚至是访问网站地址(http://www...)都离不开数据库。一个数据库通常都安装在称为数据库服务器的计算机上。目前市场上运行最快的 SQL (Structured Query Language结构化查询语言) 数据库之一就是MySQL Server,由瑞典的T.c.X. DataKonsultAB公司开发。MySQL可以从http://www.mysql.com/上下载,它提供了其它数据库少有的编程工具,而且MySQL对于商业和个人用户是免费的。如果想用MySQL开发应用软件,必须支付一定的产品使用许可费用,具体情况可以访问MySQL's licensing section

MySQL的功能特点如下:
可以同时处理几乎不限数量的用户;
处理多达50,000,000以上的记录;
命令执行速度快,也许是现今最快的;
简单有效的用户特权系统。


MySQL的用户?

MySQL在企业中使用非常广泛,其中知名的公司有:

如果这些还不够,你可以在MySQL用户名单上看到更多。
这篇文章主要是向读者对MySQL服务器的基本操作进行简单的介绍,其中包括怎样建立连接,设置服务器进行简单的命令操作。这里介绍的的命令是一些最重要的,因为它们是构成一些高级命令的基础。
MySQL通常对用户来说是一种额外服务,所以在使用之前,请向新网ChinaDNS申请开设MySQL帐户。

 
 
MySQL的环境


MySQL通常用Telnet进行登录(一个非常好的Telnet软件名为Easyterm,可以从 http://www.arachnoid.com/下载)。我们向用户推荐使用WinMysql 管理工具,下载网址是http://www.tcx.se/Downloads/Win32/myAdmin1.0.1.0.zip 通过Telnet与web服务器连接后,第二个命令提供MySQL服务器的登录。登录的步骤如下:

1. 连接到服务器。


login: devshed
Password:
********

Last login: Wed Aug 12 09:49:14 from 195.103.124.222
Copyright 1992, 1993, 1994, 1995, 1996 Berkeley Software Design, Inc.
Copyright (c) 1980, 1983, 1986, 1988, 1990, 1991, 1993, 1994
The Regents of the University of California. All rights reserved.

BSDI BSD/OS 2.1 Kernel #12: Mon Feb 23 13:46:27 EST 1998

You have new mail.
www24:mywww/devshed#


2. 登录到MySQL帐户。


www24:mywww/devshed# mysql -u devshed -p

Syntax: mysql -h hostname -u username -p[password]
Or
mysql -h hostname -u username --password=password

用户会被提示输入密码。-p表示输入密码。


Enter password: *******

用户会看见如下结果:


Welcome to the MySQL monitor. Commands end with ; or \g.
Your MySQL connection id is 49 to server version: 3.21.23-beta-log
Type 'help' for help.

mysql>

登录到数据库之后,我们就可以执行各种MySQL的命令,但在对数据库操作之前必须要先调用数据库,也就是与数据库建立连接:


mysql> use devshed;

结果:


Database changed
Mysql>

现在你已经连接到数据库。注意命令后面要加上分号(;),几乎所有的MySQL命令都要加分号。有关管理数据库的命令可以通过键入help, \h 或?列出来。


mysql> help

help (\h) Display this
text ? (\h) Synonym for `help'
clear (\c) Clear command
connect (\r) Reconnect to the server. Optional arguments are db and host
edit (\e) Edit command with $EDITOR
exit (\) Exit mysql. Same as quit
go (\g) Send command to mysql server
print (\p) print current command
quit (\q) Quit mysql
rehash (\#) Rebuild completion hash
status (\s) Get status information from the server
use (\u) Use another database. Takes database name as argument

Connection id: 49 (Can be used with mysqladmin kill)

mysql>

也许这些功能不会都能用上,但应该知道每一个命令都会做什么。象命令status, use, print, connect, clear, 和quit在最开始学习使用时都会十分有用。现在,你应该对连接数据库、选择数据库和运行基本命令都应该有一定的了解。下一步将讲解有关对数据库进行操作的基本概念和方法。

 
MySQL基础


数据类型和表 
数据库其实不过是由不同层次的数据结构构成的。MySQL中可以存放块(或记录)信息的结构就是表(table)。而这些记录则由更小的信息格式组成,即数据类型。一个或多个的数据类型组成了记录。由记录组成的表构成了数据库的一部分。数据库的层次可以表示如下:
Database < Table < Record < Datatype

数据类型有不同的形式和大小,这样程序员就可以根据实际应用的需要建立表。选择合适的数据类型对于数据库的运行性能影响致关重要,所以详细了解这些概念是十分重要的。


MySQL Datatypes 数据类型

MySQL支持各种数据类型(即使是编程新手也都基本熟悉)。常用的类型包括:

CHAR (M) 固定长度字符

用来表示固定长度的字符串。字符串的长度范围是1-255。例如:car_model CHAR(10);

VARCHAR (M) 可变长度字符
VARCHAR是一个具有灵活性的字符数据类型。字符串的长度范围是1-255。 选用VARCHAR通常是比较明智的决定。尽管处理CHAR类型的数据比VARCHAR类型的数据要快,有时会快50%。(CHAR类型存储的数据的长度是声明变量时的固定长度,而不管数据的实际长度。VARCHAR存储的是按数据的实际长度,从而减小了数据文件的大小。)
car_model VARCHAR(10);

INT (M) [Unsigned] 整数类型
INT是整数类型,存储整数的值范围是-2147483648到2147483647。在声明类型时可选用"unsigned",这样值的范围就是0到4294967295。
light_years INT;
合法整数: '-24567',    非法整数: '3000000000'。
light_years INT unsigned;
合法整数: '3000000000',    非法整数: '-24567'。

MySQL基础


FLOAT [(M,D)] 浮点类型
FLOAT代表浮点类型,用来表示更精确的数字类型。
rainfall FLOAT (4,2);
这个变量可以用来表示一年当中的平均降水量,并精确到小数。FLOAT (4,2)表示数值一共可以有4位数字,小数点后有2位数字。请看下面哪些数值可以用上面的变量类型表示:

42.35是合法的
324.45是不合法的,将被修改为324.5
2.2 是合法的数值
34.542 不合法,将被修改为 34.54
注意:由于FLOAT会将数值四舍五入,所以如果不想让数值随意被更改,建议使用DECIMAL


DATE 日期类型
用来存放日期信息,缺省的格式是'YYYY-MM-DD',日期范围可以从'0000-00-00' 到 '9999-12-31'。声明日期型变量the_date
the_date DATE;


TEXT / BLOB 文本和大对象
如果字符串的长度超过了255,或者要将一篇文章保存到数据库中,CHAR和VARCHAR就无法使用了,这里就要用到TEXT和BLOB类型,该类型可以保存的字符串长度在255 - 65535字节内。BLOB是一个能保存二进制数据的的大对象。BLOB和TEXT数据类型是一样的,唯一的区别就是TEXT不区分大小写,而BLOB区分大小写。


SET 固定类型
一个SET是可以有零或多个值的一个字符串对象,其每一个必须从表创建造被指定了的允许值的一张列表中被选择。由多个集合成员组成的SET列通过由由逗号分隔(“,”)的成员被指定。SET类型最多可以64个值。
transport SET ("truck", "wagon") NOT NULL;
经过上面的声明之后,transport可以有下面几个值:
""
"truck"
"wagon"
"truck,wagon"


ENUM 枚举类型
ENUM是与SET属性相同的数据类型,但从中取值时只能取一个值。
transport ENUM ("truck", "wagon") NOT NULL;
经过上面的声明之后,transport可以有下面几个值:

""
"truck"
"wagon"

MySQL基础


Records 记录

一组数据类型就构成了记录。一个记录可以只有一个数据类型,也可以根据需要设置很多个。一个或多个记录构成了一个表。

Tables 表
在我们可以对数据库进行操作之前,必须建立一个可以存放数据的表。可以通过如下方法创建:
mysql> CREATE TABLE test (
> name VARCHAR (15),
> email VARCHAR (25),
> phone_number INT,
> ID INT NOT NULL AUTO_INCREMENT,
> PRIMARY KEY (ID));
输出结果:
Query OK, 0 rows affected (0.10 sec)
mysql>

这样你的第一个表就建成了。

所有的数据类型都可以使用下面的选项:

  • 主键值Primary Key。主键值是用来将记录区分开来,因为没有两个记录能使用同一个主键值。在必须要保持记录的唯一性时,使用主键值是非常有用的。

  • Auto_Increment自动增量。使用了这个选项的列在每增加一个记录时,都会自动将记录在该列的值加1。

  • NOT NULL非空变量。表示该列不能被分配为空值。

例:
soc_sec_number INT PRIMARY KEY;
这样soc_sec_number字段就不能有重复的值。

ID_NUMBER INT AUTO_INCREMENT;
从1开始,自动按顺序将后面的值在前面的基础上增加1。



与表相关的命令

我们可以使用一些与表有关的命令:



显示表内容

如果想显示数据库当中存在的所有表,可以使用命令show tables,
mysql> show tables;


显示列 
mysql> show columns from test;
结果:
显示出与表相关的列及数据。

现在你已经对创建表有了一个基本的认识。表是由数据类型构成的,所有的数据类型形成了记录。

对数据库进行操作

 

我们可以对数据库进行四种方式的操作:添加、删除、修改和查询(搜索)。请大家注意的是,SQL语言和其它编程语言一样,对命令语句的语法格式很在意,比如一个括号、逗号或分号的错误都会导致命令无法执行。所以一定要熟悉语法格式。

插入记录

这里我们继续使用前面创建过的数据库作为例子:


mysql> CREATE TABLE test (
>
name VARCHAR (15),
>
email VARCHAR (25),
>
phone_number INT,
>
ID INT NOT NULL AUTO_INCREMENT,
>
PRIMARY KEY (ID));

使用INSERT命令插入数据,将数据分别插入姓名、邮件地址、电话和ID号内。


mysql> INSERT INTO test VALUES
mysql>
('Bugs Bunny', 'carrots@devshed.com',
mysql>
5554321, NULL);

结果:


Query OK, 1 row affected (0.02 sec)

mysql>

  • 数据类型VARCHAR的内容必须要用单引号,所有的字符串类型数据(char, varchar, text, blob)都必须使用单引号,否则会出错误信息。

  • 电话号码的内容不用单引号。整数INT类型的数据都不用单引号。

  • NULL空值。为什么要在ID中插入空值? 实际上该数据类型使用了AUTO_INCREMENT选项,在插入空值时数据库会自动将ID的值加1。比如最后一个记录的ID值是2,那么再插入一个记录时,新记录的ID值就是3。如果将空值插入TIMESTAMP类型的记录时,那么新记录的TIMESTAMP值就是当前的时间。

注意: 每次插入新记录时必须保证新记录的值的个数与数据类型的数目一致。上面的命令中如果只有一个值,插入命令就会出错。

例如:  


mysql> insert into test values('doggy');
ERROR 1058: Column count doesn't match value count
mysql>

对数据库进行操作


选取内容

如果不能从一个数据库搜索和提取信息,那么这个数据库就没有什么用处。 在MySql里,这一功能是通过SELECT命令来实现。


mysql> SELECT * FROM test
mysql>
WHERE (name = "Bugs Bunny");

结果:

nameemailphone_numberID   
Bugs Bunnycarrots@devshed.com55543211

假设我们已经插入了多个不同的记录,所有记录都有相同的姓名,但有不同的邮件地址和电话号码。那么表test的内容显示如下:

nameemailphone_numberID   
Bugs Bunnycarrots@devshed.com55543211
Bugs Bunnypeppers@devshed.com55543312
Bugs Bunnylettuce@devshed.com55543413
Bugs Bunnycelery@devshed.com55543514

 

删除

我们如果想将表中的某些记录删除,可以使用DELETE命令:


mysql> DELETE FROM test
mysql>
WHERE (name = "Bugs Bunny");

结果:
test表中所有包含"Bugs Bunny"字段的记录会被删除。

例如:


mysql> DELETE FROM test
mysql>
WHERE (phone_number = 5554321);

结果:

nameemailphone_numberID   
Bugs Bunnypeppers@devshed.com55543312
Bugs Bunnylettuce@devshed.com55543413
Bugs Bunnycelery@devshed.com55543514

 

修改

MySQL也提供对表中的数据进行修改的功能,该操作可以用UPDATE命令完成。


mysql> UPDATE test SET name = 'Daffy Duck'
mysql>
WHERE name = "Bugs Bunny";

nameemailphone_numberID   
Lippylippys@cexpress.com55543312
Leelee@cexpress.com55543413
Fishfish@cexpress.com55543514


上面我们讲过了对MySQL数据库中的数据进行基本的插入、删除、修改和查询功能。下面将结合实际数据库操作的应用,详细讲讲这些命令的具体使用方法。

MySQL高级命令


逻辑运算

MySQL支持所有的基本逻辑运算。


AND (&&) 与


mysql> SELECT * FROM test WHERE
mysql>
(name = "Bugs Bunny") AND
mysql>
(phone_number = 5554321);

结果:
所有同时包含名字 "Bugs Bunny"电话号码'5554321'的记录会显示出来。



OR ( || ) 或


mysql> SELECT * FROM test WHERE
mysql>
(name = "Bugs Bunny") OR
mysql>
(phone_number = 5554321);

结果:
所有包含名字 "Bugs Bunny" 电话号码'5554321'的记录会显示出来。



NOT ( ! ) 非


mysql> SELECT * FROM test WHERE
mysql>
(name != "Bugs Bunny");

结果:
所有不包含名字 "Bugs Bunny" 的记录会显示出来。



Order By 按序排列


mysql> SELECT * FROM test WHERE
mysql>
(name = "Bugs Bunny") ORDER BY
mysql>
phone_number;

结果:
所有包含名字 "Bugs Bunny" 的记录会显示出来,并以电话号码为排序方式。



查询功能

MySQL为用户提供了粗略搜索和详细搜索的选择。


mysql> SELECT * FROM test WHERE
mysql>
(name LIKE "%gs Bunny");

结果:
显示出来的是所有包含字符"gs Bunny"的记录,下面的字段都符合该条件:"Bugs Bunny", "ags Bunny", "gs Bunny", and "234rtgs Bunny"。请注意这里使用的是"LIKE"而不是等号(=),表示搜索的是和条件相似的记录,而不必是完全一样。百分号 '%'可以放在字符串当中的任何地方,服务器搜索字符串的方式则取决于'%'放在何处。


mysql> SELECT * FROM test WHERE
mysql>
(name LIKE "Bugs Bunny%");

结果:
显示出来的是所有包含字符"gs Bunny"的记录,下面的字段都符合该条件:"Bugs Bunnys", "Bugs Bunnyyyy453", "Bugs Bunnytrtrtrtrtr", 但是 "gs Bunny"则不符合条件。



我们也可以使用等号条件式来搜索:


mysql> SELECT name FROM test WHERE
mysql>
(name = "Bugs Bunny");

结果:

name
Bugs Bunny




更改表内容

MySQL的另一个重要功能就是修改表中已经存在的数据。修改表数据要使用ALTER命令,该命令可以增加、修改、删除列,同时也可以对表进行重命名。

例如: 将表名称由test改为mytest,


mysql> ALTER table test RENAME mytest;

例如: 在表mytest中添加列日期型表列birthday,


mysql> ALTER table mytest ADD birthday DATE;

例如: 将表mytest中的name列改为newname,类型是VARCHAR (25),

mysql> ALTER table mytest CHANGE
mysql>
name newname VARCHAR (25);

例如: 删除表mytest中名为newname的列,


mysql> ALTER table mytest DROP newname;

顺序执行上面的四个命令之后的结果是生成下面的表。


mysql> TABLE mytest (
>
email VARCHAR (25),
>
phone_number INT,
>
ID INT AUTO_INCREMENT,
>
birthday DATE );

在这部教程里,我们只对MySQL的使用进行了简单的介绍。但这些功能都是我们进行编程所必须熟悉的基本操作。最重要的还是多多实践,参考相关技术文档,多参加网上相关技术的讨论。

 

转至:www.cexpress.com网

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL教程CSDN是一个非常受欢迎的学习MySQL数据库的平台。它提供了丰富的教程和示例代码,帮助初学者快速入门并深入了解MySQL数据库的使用和管理。 在MySQL教程CSDN中,你可以学习到如何安装和配置MySQL数据库,掌握数据库的基本概念和操作语句。教程以简洁明了的方式呈现,适合初学者从零开始学习。你可以通过跟随教程中的步骤,轻松地安装MySQL并开始编写SQL语句。 教程还提供了大量的实例和案例,帮助读者理解和掌握各种常见的SQL语句,如查询、插入、更新和删除数据,以及创建和管理表等。通过实际操作,你可以学习到如何利用MySQL数据库解决实际问题,提升自己的数据编程能力。 除了基本的SQL语句,MySQL教程CSDN还介绍了一些高级的数据库技术,如事务处理、索引优化和性能调优等。这些内容对于想要进一步提升数据库应用能力的读者来说非常有用。 总的来说,MySQL教程CSDN是一个很好的学习MySQL数据库的平台。通过学习教程中的内容,你可以快速入门MySQL并掌握数据库的基本操作和高级技术。无论你是初学者还是有一定经验的开发者,都可以从中受益。 ### 回答2: MySQL教程是CSDN上提供的一种学习MySQL数据库的资料。MySQL是一种开源的关系型数据库管理系统,广泛应用于Web开发中,具有操作简单、性能高、可定制性强等特点。 在MySQL教程中,CSDN给出了MySQL的基本概念和操作方法,帮助读者快速入门。教程中介绍了MySQL的安装与配置、数据库的创建与删除、表的创建与操作、数据的插入和查询等内容。通过这些教程,读者可以了解MySQL数据库的基本原理,学会使用MySQL进行数据管理和查询。 除了基础操作外,MySQL教程还涵盖了一些高级的数据库操作,如多表查询、数据的更新和删除、索引的创建和使用等。这些内容对于需要处理大量数据和优化数据库性能的开发者来说尤为重要。 在CSDN的MySQL教程中,不仅提供了理论知识,还配有示例代码和案例分析,帮助读者更好地理解和应用所学内容。此外,教程中还介绍了一些常用的MySQL工具和优化方法,帮助读者提高数据库管理和查询的效率。 总之,MySQL教程是CSDN提供的一种学习MySQL数据库的资料,通过学习教程中的内容,读者可以掌握MySQL的基本操作和高级技巧,提高数据库管理和查询的能力。对于想要从事Web开发或数据库管理的人来说,MySQL教程是一个很好的学习资源。 ### 回答3: MySQL教程(CSDN)是一份详细的学习和使用MySQL数据库的指南。CSDN作为一个知名的IT社区,提供了丰富的技术资源和教程。这个MySQL教程的内容包含了MySQL的基本概念、安装和配置、基本操作、高级查询、数据备份和恢复等内容。 MySQL是一个开源的关系型数据库管理系统,被广泛应用于网站开发和数据存储。学习MySQL教程可以帮助读者了解数据库的基本概念和工作原理,掌握MySQL的安装和配置技巧,学会使用SQL语句进行数据的增删改查操作,以及进行高级查询和优化。此外,还可以了解数据库索引、事务处理和备份恢复的方法,提高数据库的性能和安全性。 这份MySQL教程在CSDN上提供了详细的讲解和案例,读者可以根据自己的需求和学习进度选择相应的章节进行学习。教程使用了简单明了的语言和实例,帮助读者更好地理解和掌握MySQL的知识。同时,教程也提供了一些常见问题和解决方案,帮助读者更好地应对实际开发中遇到的问题。 总而言之,MySQL教程(CSDN)是一个值得学习的资源,对于想要学习和使用MySQL数据库的开发者来说是非常有帮助的。通过学习教程,读者可以系统性地了解到MySQL的各个方面,提高自己的数据库开发和管理能力。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值