格式:grant select on 数据库.* to 用户名@登陆主机 identified by “密码”
一、增长一个用户test1密码为abc,让他能够在任何主机上登陆,并对全部数据库有查询、插入、修改、删除的权限。首先用root用户连入MYSQL,而后键入如下命令: grant select,insert,update,delete on *.* to test1@”%” Identified by “abc”;
二、增长一个用户test2密码为abc,让他只能够在localhost上登陆,并能够对数据库mydb进行查询、插入、修改、删除的操做(localhost指本地主机,即MYSQL数据库所在的那台主机),这样用户即便用知道test2的密码,他也没法从internet上直接访问数据库,只能经过MYSQL主机上的web页来访问了。 grant select,insert,update,delete on mydb.* to test2@localhost identified by “abc”;
若是你不想test2有密码,能够再打一个命令将密码消掉。 grant select,insert,update,delete on mydb.* to test2@localhost identified by “”; 4.1 建立数据库注意:建立数据库以前要先链接Mysql服务器
命令:create database <数据库名>
例1:创建一个名为xhkdb的数据库 mysql> create database xhkdb;
例2:建立数据库并分配用户
①CREATE DATABASE 数据库名;
②GRANT SELECT,INSERT,UPDATE,DELETE,CREATE,DROP,ALTER ON 数据库名.* TO 数据库名@localhost IDENTIFIED BY '密码';
③SET PASSWORD FOR '数据库名'@'localhost' = OLD_PASSWORD('密码');
依次执行3个命令完成数据库建立。注意:中文 “密码”和“数据库”是户本身须要设置的。 4.2 显示数据库命令:show databases (注意:最后有个s) mysql> show databases;
例子2:删除一个不肯定存在的数据库 mysql> drop database drop_database; ERROR 1008 (HY000): Can't drop database 'drop_database'; database doesn't exist //发生错误,不能删除'drop_database'数据库,该数据库不存在。 mysql> drop database if exists drop_database; Query OK, 0 rows affected, 1 warning (0.00 sec)//产生一个警告说明此数据库不存在 mysql> create database drop_database; Query OK, 1 row affected (0.00 sec) mysql> drop database if exists drop_database;//if exists 判断数据库是否存在,不存在也不产生错误 Query OK, 0 rows affected (0.00 sec) 4.4 链接数据库命令: use <数据库名>
例如:若是xhkdb数据库存在,尝试存取它: mysql> use xhkdb; 屏幕提示:Database changed
use 语句能够通告MySQL把db_name数据库做为默认(当前)数据库使用,用于后续语句。该数据库保持为默认数据库,直到语段的结尾,或者直到发布一个不一样的USE语句: mysql> USE db1; mysql> SELECT COUNT(*) FROM mytable; # selects from db1.mytable mysql> USE db2; mysql> SELECT COUNT(*) FROM mytable; # selects from db2.mytable
使用USE语句为一个特定的当前的数据库作标记,不会阻碍您访问其它数据库中的表。下面的例子能够从db1数据库访问做者表,并从db2数据库访问编辑表: mysql> USE db1; mysql> SELECT author_name,editor_name FROM author,db2.editor -> WHERE author.editor_id = db2.editor.editor_id;
USE语句被设立出来,用于与Sybase相兼容。
有些网友问到,链接之后怎么退出。其实,不用退出来,use 数据库后,使用show databases就能查询全部数据库,若是想跳到其余数据库,用 use 其余数据库名字 就能够了。 4.5 当前选择的数据库命令:mysql> select database();
3. 显示年月日 SELECT DAYOFMONTH(CURRENT_DATE); +--------------------------+ | DAYOFMONTH(CURRENT_DATE) | +--------------------------+ | 15 | +--------------------------+ 1 row in set (0.01 sec)
SELECT MONTH(CURRENT_DATE); +---------------------+ | MONTH(CURRENT_DATE) | +---------------------+ | 9 | +---------------------+ 1 row in set (0.00 sec)
SELECT YEAR(CURRENT_DATE); +--------------------+ | YEAR(CURRENT_DATE) | +--------------------+ | 2009 | +--------------------+ 1 row in set (0.00 sec)
4. 显示字符串 mysql> SELECT "welecome to my blog!"; +----------------------+ | welecome to my blog! | +----------------------+ | welecome to my blog! | +----------------------+ 1 row in set (0.00 sec)
6. 串接字符串 select CONCAT(f_name, " ", l_name) AS Name from employee_data where title = 'Marketing Executive'; +---------------+ | Name | +---------------+ | Monica Sehgal | | Hal Simlai | | Joseph Irvine | +---------------+ 3 rows in set (0.00 sec) 注意:这里用到CONCAT()函数,用来把字符串串接起来。另外,咱们还用到之前学到的AS给结果列'CONCAT(f_name, " ", l_name)'起了个假名。 5.1 建立数据表命令:create table <表名> ( <字段名1> <类型1> [,..<字段名n> <类型n>]);
例如,创建一个名为MyClass的表,
字段名
数字类型
数据宽度
是否为空
是否主键
自动增长
默认值
id
int
4
否
primary key
auto_increment
name
char
20
否
sex
int
4
否
0
degree
double
16
是
mysql> createtable MyClass( > id int(4) not null primary key auto_increment, > name char(20) not null, > sex int(4) not null default '0', > degree double(16,2)); 5.3 删除数据表命令:drop table <表名>
例如:删除表名为 MyClass 的表 mysql> drop table MyClass;
DROP TABLE用于取消一个或多个表。您必须有每一个表的DROP权限。全部的表数据和表定义会被取消,因此使用本语句要当心!