MySQL服务的配置和使用修改MySQL管理员的口令:mysqladmin –u root password 密码字符串如:连接MySQL服务器,使用命令:mysql [-h 主机名或IP地址] [-u 用户名] [-p]如:mysql –u root –p如已有密码需修改root密码用命令: mysqladmin –u root –p password 新密码字符串如:mysqladmin –u root –p password 111111mysqldmin –u root password 111111创建数据库格式为:CREATE DATABASE 数据库名称;如:mysql>create database abc; 默认创建数据库保存在/var/lib/mysql 中查看数据库是 mysql>show abc;选择数据库是 USE 数据库名称; 如:mysql>use abc;删除数据库是 DROP DATABASE 数据库名称;如:mysql>drop database abc;数据库的创建和删除创建表是CREATE TABLE 表名称(字段1,字段2,…[表级约束]) [TYPE=表类型];其中字段(1,2 )格式为:字段名字段类型[字段约束]如创建一个表student,如下:mysql>create table student (sno varchar(7) not null, 字段不允许为空sname varchar (20 )not null,ssex char (1) default ‘t’,sbirthday date,sdepa char (20),primary key (sno) 表的主键);可用describe命令查看表的结构。
默认表的类型为MYISAM,并在/var/lib/mysql/abc 目录下建立student.frm(表定义文件),student.MDY(数据文件),stedent.MYI(索引文件)。
复制表CREATE TABLE 新表名称LIKE 原表名称;如:mysql>create table xtable like student;删除表DROP TABLE 表名称1[表名称2…];如:mysql> drop table xtale;修改表ALTER TABLE 表名称更改动作1[动作2];动作有ADD(增加) DROP(删除)CHANGE、MODIFY(更改字段名和类型)RENAME增加字段:mysql>alter table student add saddress varchar(25);更改字段名和字段类型:mysql>alter table student change saddress sremark test;即使不更改字段类型也要给出字段类型如:mysql>alter table student change saddress sremark varchar (25);更改字段类型:mysql> alter table student modify sremark varchar(25); 删除字段:mysql>alter table student drop sremark;更改表名称:mysql>alter table student rename to xs;表中数据的插入、删除和修改插入记录:INSERT INTO 表名称(字段名1,字段名2…V ALUES(字段1的值,字段2的值如:mysql>insert into student (sno,sname,ssex,sbirthday,sdepa)values(‘0321001’,’Liu Tao’,dagault,19870201,’math’);查看表 mysql>select * from student;插入与前面相同的记录,可用insert命令的缩写格式,如: mysql>insert into student values (‘0321001’, ‘Liu Tao’, default, 19870201, ‘mth’);如果字段名列表中没有给出表中的某些字段,那么这些字段设置为默认值,如:mysql>insert into student (sno,sname,sbirthday)values(‘0321002’,’Wang Jun’,1870112);一个单独的insert语句中可使用多个valuse字句,插入多条记录,如:mysql>insert into student values(‘0322001’, ‘Zhang Liaoyun’, ‘f’ 1971102,’computer’),(‘0322002’, ‘Li Ming’, ‘t’ 1971105,’computer’);删除记录:DELETE FROM 表名称WHERE 条件表达式;如:mysql>delete from student where sno=’0321002’;删除student表中sno字段值前4位为‘0322’的记录如:my sql>delete from student where left (sno,4)=’0322’;删除所以记录,可以不带where字句如:mysql>delete from student;删除所以记录可以用命令truncate 删除表,然后重建表,所以比delete命令快如:mysql>truncate table student;修改记录UPDATE 表名称SET 字段名1=字段值1WHERE 条件表达式如:mys ql>update student set sbirthday=1920113, sdepa=’math’ where sno=’0321002’;索引的创建与删除在创建表的同时创建索引创建表时,可用INDEX字句或UNIQUE(字段值必须惟一)字句创建索引如:创建课程表course, 课程编号cno字段为主键,课程名称cname 字段创建一个名为can的索引mysql>create table course(cno varchar(5) not null,cname varchar(30) not null,teacher varchar(20),primary key (cno),index can (cname));向已存在的表添加索引 CREATE [UNIQUE ] INDEX 索引名ON 表名称(字段名1[(长度)]);如:mysql>create index sna on student (sname);对于类型为CHAR和V ARCHAR的字段建立索引时还可指定长度值,类型为BLOB和TEXT的字段索引时必须指定长度值。
如mysql>create index sna on student (sname(10));删除索引 DROP INDEX 索引ON表名称;如:mysql>drop index sna on student;用户的创建和删除初始化时有5个MySQL授权表,其中host、tables_priv和columnts_priv 是空的,表user和db决定了MySQL默认的访问规则。
默认有mysql和test两个数据库。
授权表:user 用户从哪些主机可以连接到数据库服务器,以及对所以数据库的访问权限(全局权限)db 用户可以使用哪些权限,以及对数据库执行哪些操作(数据库级权限)host 当表db 中的host 字段值为空时,用户从哪些主机可以连接到数据库服务器。
tables_priv 连接的用户可以访问哪些表(表级权限)columnts_priv 连接的用户可以访问哪些字段(字段级权限)创建新用户以MySQL管理员连接到数据库服务器:#mysql –u root –p创建新用户guess并设置密码,同时可以从任何主机连接数据库服务器:mysql>insert into er (host,user,password)values (‘%’,’gusee’,password(‘guest’));使用password()函数,密码是加密的重载MySQL授权表:mysql>flush privileges;远程客户端连接数据库服务器:#mysql –h 192.168.0.50 –u guess –p 开放服务器的TCP断口3306查看当前用户可用数据库:show database删除用户mysql>delete from er where user=’guest’;mysql>flush privileges; 重载MySQL授权表更改用户密码如:更改guset密码为123456mysql>update er set password=password(‘123456’) where user =’guset’;mysql>flush privileges;或者是mysql>se t password for guset@’%’=password(‘123456’);用户权限的设置在表user、db和host中,所有字段声明为ENUM(‘N’,’Y’),默认是‘N’;在表tables_priv和columns_priv中,权限字段声明为SET类型修改授权表中的访问权限有两中方法,一是使用INSERT、UPDATE和DELETE等DML语句,另一中是GRANT和GRVOKE语句使用GRANT语句授权:格式如下:GRANT 权限列表[(字段列表)] on 数据库名称.表名称TO 用户名@域名或IP地址[INDETIFIED BY ‘密码值’] [WITH CRANT OPTION];授权哪个用户能连接,从哪连接如:授权用户guest从任意主机连接数据库服务器,并具有完全访问数据库abc的权限。
Mysql>grant all on abc.* to guset@’%’ identified by ‘guest’注意几点:如指定用户不存在,则创建该新用户;‘权限列表’处ALL表示授予全部权限,USAGE表不授予任何权限。
‘数据库名称.表名称’处可以使用通配符“*”。
如“abc.*”表数据库abc中所有表‘用户名@域名或IP地址’设置谁能连,从哪连。
用户名不能用通配符,但可以用‘ ’空字符串,表任何用户;域名或IP地址可以用通配符“%”,使用是用单引号括起来。