- 注册时间
- 2008-5-19
- 最后登录
- 2012-2-3
- 在线时间
- 1757 小时
- 阅读权限
- 200
- 积分
- 12741
- 帖子
- 2521
- 主题
- 1198
- 精华
- 24
- UID
- 1
  
 - 注册时间
- 2008-5-19
- 最后登录
- 2012-2-3
- 在线时间
- 1757 小时
- 阅读权限
- 200
- 积分
- 12741
- 帖子
- 2521
- 主题
- 1198
- 精华
- 24
- UID
- 1
|
MySQL服务的配置和使用:
初始状态,给MySQL结密码:
#mysqladmin -u root password 密码字符串
修改MySQL管理员的密码:
#mysqladmin -u root -p password 新的密码字符串.
#mysql -uroot -p 输入密码登陆.
数据库的创建与删除:
create database netseek;
user netseek
dorp database netseek;
show databases;
表的创建与删除:
部分字段。。。图表画上.
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)
-> );
mysql> show tables;
+---------------+
| Tables_in_stu |
+---------------+
| student |
+---------------+
1 row in set (0.00 sec)
mysql> desc student
-> ;
+-----------+-------------+------+-----+---------+-------+
| Field | Type | Null | Key | Default | Extra |
+-----------+-------------+------+-----+---------+-------+
| sno | varchar(7) | NO | PRI | | |
| sname | varchar(20) | NO | | | |
| ssex | char(1) | YES | | t | |
| sbirthday | date | YES | | NULL | |
| sdepa | char(20) | YES | | NULL | |
+-----------+-------------+------+-----+---------+-------+
复制表
create table xstudent like student;(可以复制表结构及内容,且能从表源中复制键)
删除表:
mysql> drop table xstudent;
更改表名:
alter table xstu rename to xstudent;
alter table studnet rename to xstudent;
修改表:
增加字段:
mysql> alter table xstu add saddress varchar(25);
改更字段名,和字段类型.
mysql> alter table xstu change saddress shome text;
alter table xstu change shome shome varchar(25); 这样也可以更改字段类型.
alter table xstu modify shome varchar(25); ,这个也一样可以更改字段类型.
删除字段:
alter table xstu drop shome; 即可删除shome这个字段.
总结:alter可以完成多项任务,更改表名,更改字段名,和类型,删除字段.
也可以用一条alter语句完成多项任务:
mysql> alter table xstudent
-> add saddress varchar(25),
-> change sbirthday sage int(3),
-> rename to xstu;
表中的数据插入与删除,修改.
mysql> insert into student (sno,sname,ssex,sbirthday,sdepa)
-> values ('02320','Linda',default,19850516,'computer');
>select * from student; 就可以看到刚才插入的数据.
insert还可以同是插入多个values子句,可以同进插入多个条记录.
mysql> insert into student values
-> ('02322','JinPing','m',19830215,'computer'),
-> ('02323','Lenmi','f',19850819,'english');
删除记录:
mysql> delete from student where sno='02322';
册除字段为sname中的字段值的前2位,为Li的记录。
mysql> delete from student where left(sname,2)='Li';
如果要删除表中所有的记录:
mysql> delete from student;
Query OK, 2 rows affected (0.01 sec)
另一种删除表中所有记录的方法:
mysql> truncate table student;
Query OK, 0 rows affected (0.00 sec)
总结,对比一下delete,truncate,可以看出来什么:
truncate命令不管表中有多少记录,它都是删除表,然后重建请表,因此0 rows affected;而delete
命令是将表中所有的记录一个一个删除,所以2 rows affected,所以,truncate命令比delete命令要快,
特别是在表中记录非常多时非常明显。
修改记录:update
mysql> update student set sdep='english' where sno='0318990';
创建索引与删除索引。
为什么要创建:
为了加速数据查询的速度,MySQL允许用户为一个表的特定字段设置索引,一个索引就是该字段值的一个列表。
索引既可以在使用create table句语创建的同时创建,也可以使用create index语句,向已存在的表中添加。
1.创建表的同是创建索引:
创建一个选课表course,将课程编号cno设为主键,同时为课程名称cname字段创建一个名为cna的索引。
mysql> create table course(
-> cno varchar(5) not null,
-> cname varchar(30) not null,
-> teacher varchar(20),
-> primary key (cno),
-> index cna(cname)
-> );
如果将:index cna(cname)改为unique(cname),创建的是UNIQUE索引,该索引要求索引字段中的值必须
是唯一的,也就是说,表中各条记录中该字段的值不能相同,若向表中插入一个与现有记录中访字段值相同的记录,则会失败。
2. 向已存的表中添加索引。
为为表student中的sname字段创建名为sna的索引.
create index sna on student (sname);
删除索引:
mysql> drop index sna on student;
为为表student的sname字段建名为sna的索引,并指定索引长度值为10,可以使用:
mysql> create index sna on student (sname(10));
注:这里指定索引长度值为10,是基于大多数名字通常在前10个字符是不一样的考虑,这样创建的索引
文件会更小一些,既可以节省磁盘空间,又可以加速速insert等速度。
用户的创建和删除:
授权表:
查看数据库,mysql 中表user前4个字段的内容:
mysql> select host,user,password,select_priv from mysql.user;
查看数据库mysql中表db的前4个字段内容:
mysql> select host,db,user,select_priv from mysql.db;
注:虽然在表db中定义了允许任何用户可以从任何主机访问数据库test,但由于在表user中限制任何用户只
能从本地localhost来连接数据库,因为在这两个表的共同作用下,MySQL默认设置是任何用户只能从本地
完全访问数据库test。
创建用户与授权:
利用insert语句添加用户.
mysql> insert into mysql.user (host,user,password)
-> values ('%','guest',password('guest'));
mysql> flush privileges;
利用开始加的用户登陆:
[root@rhel4 ~]# mysql -h 192.168.0.3 -u guest -p
让远程客户端连接到linux系统中的数据库,还要开启TCP3306端口:
/sbin/iptables -I INPUT -p tcp --dport 3306 -j ACCEPT
删除用户:
利用delete句语删除guest用户
mysql> delete from mysql.user where user='guest';
mysql> update mysql.user set password=password('123456')
-> where user='guest';
Query OK, 1 row affected (0.01 sec)
Rows matched: 1 Changed: 1 Warnings: 0
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
还有一种更改密码的方运河,要将用户guest的密码更改为guest
mysql> set password for guest@'%'=password('guest');
注:guest@'%'基本格式:用户名@客户端的域名,eg:netseek@'%.linux-lab.cn'.
或者试试与update配合.
grant 用户授权:
mysql> grant all on stu.* to netseek@'%' identified by '52netseek';
Query OK, 0 rows affected (0.00 sec)
# mysql -h www.linux-lab.cn -u netseek -p 这个登陆成功
mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
grant all on stu.* to okman@'%.linux-lab.cn' identified by 'okman';
Query OK, 0 rows affected (0.00 sec)
mysql -h www.linux-lab.cn -uokman -p 这个连接为什么不能成功.
授予不同级别的权限:
要新建一个用户tom,他能从子网192.168.0.0中任何主机连接到数据库服务器,可以读取数据库
stu的内容,并且能修改表course中字段teacher的值.
grant select on stu.* to tom@'192.168.0.%' identified by '123456';
grant update(teacher) on stu.course to tom@'192.168.0.36'
授予管理权限:
>grant all on stu.* to admin@locahost identified by '52netseek'
->with grant option;
>show grants for admin@lochost. 来检测该用户授权是否正确.
收回权限:
revoke create,drop on stu.* from admin@localhost;
revoke grant option on stu.* from admin@localhost; |
|