首页 > 数据库 > MySQL > 正文

学习使用数据库MySQL

2024-07-24 12:54:49
字体:
来源:转载
供稿:网友

[摘要]:mysql是一个遵循gpl的开源软件、在linux平台底下它是lamp(lamp 在英语中是“灯”的意思,但是在 it 行业当然不是那么简单的一个意思了。这个术语在德国十分流行。代表了 linux 平台上的 apache 网站服务器;mysql 数据库以及 perl 、python 或者 php 编程语言的结合)组合重要组成部分。同时它提供的c api可以结合glade/gtk+,可以代替windows平台的vb+access/ms sql server组合。本篇文章介绍数据库mysql及其各种工具的简单用法.

一、为什么使用mysql:mysql是一种高性能的数据库,因为如下原因。它可以和市场下任何同类的产品竞争。

l         速度。mysql本身并不复杂。http://www.mysql.com/information/crash-me.php上可以找到mysql和其他数据库产品进行竞争的数据的相关信息

l         可升级性。mysql能够同时处理无限数量的拥护和5亿个纪录

l         简单性。mysql的核心是一个小而快速的数据库,面向那些了解数据库工作的人员,是他们能够有效的工作和编写高级功能。

l         价值:mysql是遵循gpl协议的自由软件,你可以下载并且使用它。

l         可移植性。因为mysql是开放源代码的自由软件,可以运行于所有的平台,如果不能运行于你的平台,你可以修改、编译源代码。

二、mysql缺少什么

  mysql所保护的都是基于权限的,不是基于市场的。mysql能做什么和不能做什么是我们在使用之前需要清楚的。

l         图形界面:mysql开始提供类似ms sql server的界面,尚处于测试中

l         事务处理:mysql不支持事务处理,但是2000年5月9日的发行说明中,mysql宣称版本3.23.15“试验性支持”sleepy software的berkely db数据库。版本3.23.25完全实现了这一个功能。

l         存储过程:mysql没有存储过程机制。mysql开发团体的“to do”列表中有一种存储过程机制,它将包含在版本4中。

l         触发器:触发器是一种程序,通常存在于一种嵌入式脚本语言如zend或者python中。有消息说这种触发器会应用于版本4中,使用zend脚本引擎。

l         参照完整性:将来支持

l         记录等级锁定:mysql不支持记录等级锁定。将来会改善,这都是开放源代码的力量。

l         子查询:mysql不支持子查询。但是通过它提供的c语言接口可以很容易的弥补。

l         视图:mysql不支持视图。但是它在mysql开发团体的to do列表中。

很清楚地看到mysql对于转向linux的平台应用的将来的意义。

三、mysql数据库系统的安装

这里只讨论在linux系统下的mysql数据库系统的安装,可以通过rpm包安装和tar包安装,这里只讨论rpm方式安装binary。

通过rpm包安装,你需要下面三个文件:

1、  mysql-3.23.25-1.i386.rpm这是一个服务器部分。它包含接受请求和返回结果的实际数据库服务器

2、  mysql-client-3.23.25-1.i386.rpm这是客户端部分。

3、  mysql-devel-3.23.25-1.i386.rpm.从这个文件中,你需要一个c api文件。

安装过程如下:首先安装服务器部分,然后安装客户端部分,最后需要安装c程序开发需要的文件。

1、  安装服务器:

键入如下命令:#rpm –ivh mysql-3.23.25-1.i386.rpm

2、  安装客户端

键入如下命令:#rpm –ivh mysql-client-3.23.25-1.i386.rpm

4、  安装c开发文件

键入如下命令:#rpm –ivh mysql-devel-3.23.25-1.i386.rpm

5、  卸载mysql: 首先需要关闭服务器

#mysqladmin shutdown

#rpm –e –vv mysql-3.23.25-1

#rpm –e –vv mysql-client-3.23.25-1

6、  安装账号管理mysql服务器:从rpm安装。mysql用户账号会自动创建。这是一个用来运行mysql的服务的用户。

更改mysqladmin口令:为了增强安全性,需要为mysql的根用户改变口令,这可以通过下面的两个命令来完成

%mysqladmin –u root –p password ‘new-password’

或者

%mysqladmin –u root –h servername –p password ‘new-password’

四、启动和停止mysql服务器daemon

   使用rpm安装,mysql服务器dameon自动为你启动和停止,redhat的系统在/etc/init.d/mysqld的mysql服务器脚本。

   如果由于某些原因,你需要启动mysql dameon,是用如下命令

  %safe_mysqld –user=mysql &

   要关闭mysql服务器dameon,发送入下命令:

  %mysqladmin shutdown

五、应用于mysql的工具和程序

   除了mysql服务器(mysqld)。mysql程序组包含大量的程序,来管理数据库和数据库服务器。当通过rpm安装mysql时,这些程序被安装。isamchk和myisamchk是验证和重修数据库表和文件的工具。mysqlaccess 用于授权、更改和撤销用户许可权限。mysqladmin是一种高级管理工具,如创建数据库和关闭数据库等。mysqldump用于在紧急关头倒出数据和备份表,它在sql insert语句中输出数据,所使用的方法能够将输出文件反馈到mysql服务器,并且行也将被装载。mysqlimport是一种整体装载工具,而mysqlshow显示关于数据库对象的信息(如标)。

1.         isamchk:查看和修理被毁坏的表

如果由于某些未知的原因,是数据库表被毁坏,这个工具能够对它进行修补。容纳基本数据的数据文件叫做索引顺序存取法(index sequential access method,isam)文件。

mysql在3.23和更高版本中将myisam文件格式作为了默认选项。需要使用myisamchk工具,而不是isamchk。isam表结构被myisam结构替换。将来isam将不被支持。下面重点介绍一下myisam文件结构:

isam旧文件结构:数据库中的每一个表实际上是三个文件的组合:*.isd文件包含数据,*.ism文件包含关于数据结构的信息,比如密钥和索引,*.frm文件包含表的结构。

查看/var/lib/mysql/test_db/目录中发现三个文件

tb1_books_1.frm 88bytes

tb1_books_1.myi 1024 bytes

tb1_books_1.myd 8604 bytes

*.frm和旧的文件结构相同,*.myi文件和*.ism文件一致,并且*.myd文件符合旧的*.isd文件。

2.         myisamchk

这是myisam存储格式的isamchk的更新版本工具,它的基本用法如下所示:

myisamchk [options] tables..myi

利用如下命令可以得到你的系统中可以使用的全部选项列表

 

3.         mysqlaccess这个工具最值得讨论的就是-howto命令行,当你执行一下命令的时候,你就得到一个如何使用这个工具的例子:

%mysqlaccess –howto

mysqlaccess的使用方法相当简单:

mysqlaccess [host [user [db]]] options.。如果没有提供选项,那么就必须提供user和db。如果没有指定主机,则用本地服务器。

4.         mysqladmin

这个命令的常规用法如下:

mysqladmin [option] command,选项是标准的unix命令方式:-v用于详细说明,-t=xx指连接到服务器的超时时间。使用命令

%mysqladmin -?| more可以看到所有的列表。command部分用于规则的条件。现免得列表中是常用的command


命令

说明

create db_name

创建一个叫做db_name的数据库

drop db_name

删除数据库名称

flush-logs

清除所有日志

flush-privileges或者reload

重载授权表,或者执行相同操作的命令

ping

查看mysqld是否启动

shutdown

关闭数据库

status

查看服务器的状态


 

5.         mysqldump

这是一个用于备份、移植或者重载数据库的工具。命令用法有以下两种:

%mysqldump [options] database [tables]

或者

%mysqldump [options]。在使用第二种方法时,你必须提供-databases或者—all-databases选项

6.         mysqlimport

这是mysql的大量输入工具,它类似于ms sql server的bcp工具。它是load data语句的命令行接口,用法如下:

%mysqlimport [options] db_name file_name

7.         mysqlshow

mysqlshow 给出了关于数据库、表或者列的信息,它是show语句的命令行接口

用法:

%mysqlshow [options] [database_name [table_name [column]]]

8.         myisampack

myisampack可以把一个myisam表压缩到一个相对小的空间。他有点象gzip,只是它运行于表中。它运行于.myd文件,并且把它压缩到一个很小的尺寸。运行myisampack之后,你可以查看表,但是不能更新表。

 版权所有,如需转载,请注明出处。

 
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表