扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
第一步:安装MySQL客户端
公司主营业务:网站设计、网站建设、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联建站是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联建站推出洪洞免费做网站回馈大家。
当然你得确保MySQL客户端已经安装完毕。如果没有的话,可以按照下面的方法。
在Debian,Ubuntu 或者 Linux Mint上:
$ sudo apt-get install mysql-client
$ sudo apt-get install mysql
第二步:登陆到MySQL服务器
首先,你需要使用root用户登陆进你的MySQL数据库,如下:
$ mysql -u root -h -p
请注意:为了能登进远程的MySQL服务器,你需要开启服务器上的远程访问,如果你想调用同一主机上的MySQL服务器,你可以省略 "-h " 参数
$ mysql -u root -p
你将需要输入MySQL服务器的密码,如果认证成功,MySQL提示将会出现。
第三步:创建一个MySQL数据库
在MySQL提示中输入命令之前,请记住所有的命令都是以分号结束的(否则将不会执行)。另外,考虑输入命令的时候使用大些字母,输入数据库对象使用小写字母。但那不是必须的,只是方便的阅读。
现在,创建一个叫做xmodulo_DB的数据库:
mysql CREATE DATABASE IF NOT EXISTS xmodulo_DB;
第四步:创建一个数据库表
为了达到演示的目的,创建一个叫做posts_tbl的表,表里会存储关于文章的如下信息:
文章的标题
作者的名字
作者的姓
文章可用或者不可用
文章创建的日期
这个过程分两步执行:
首先,选择需要使用的数据库:
mysql USE xmodulo_DB;
然后,在数据库中创建新表:
mysql CREATE TABLE 'posts_tbl' (
'post_id' INT UNSIGNED NOT NULL AUTO_INCREMENT,
'content' TEXT,
'author_FirstName' VARCHAR(100) NOT NULL,
'author_LastName' VARCHAR(50) DEFAULT NULL ,
'isEnabled' TINYINT(1) NOT NULL DEFAULT 1,
'date' TIMESTAMP NOT NULL DEFAULT CURRENT_TIMESTAMP ,
PRIMARY KEY ( 'post_id' )
TYPE = MYISAM;
第五步:创建一个用户,并授予权限
当涉及到访问新创的数据库和表的时候,创建一个新用户是一个很好的主意。这样做就可以让用户在没有整个MySQL服务器权限的情况下,去访问那个数据库(而且只能是那个数据库)
你可以创建新用户,授予权限,并且使改变生效:
mysql GRANT ALL PRIVILEGES ON xmodulo_DB.* TO 'new_user'@'%' IDENTIFIED BY 'new_password';
mysql FLUSH PRIVILEGES;
'newuser'和'newpassword'分别指的是新的用户名和他的密码。这条信息将会被保存在mysql.user表中,而且密码会被加密。
第六步:测试
先插入一个虚拟的记录到posts_tbl表:
mysql USE xmodulo_DB;
mysql INSERT INTO posts_tbl (content, author_FirstName, author_Las tName)
VALUES ('Hi! This is some dummy text.', 'Gabriel', 'Canepa');
然后查看posts_tbl表中的所有记录:
mysql SELECT * FROM posts_tbl;
注意:MySQL会在先前定义的地方自动插入适当的默认值(比如,'isEnabled'和'date')。
MySQL添加用户、删除用户与授权
MySql中添加用户,新建数据库,用户授权,删除用户,修改密码(注意每行后边都跟个;表示一个命令语句结束):
1.新建用户
1.1
登录MYSQL:
@mysql
-u
root
-p
@密码
1.2
创建用户:
mysql
insert
into
mysql.user(Host,User,Password)
values("localhost","test",password("1234"));
这样就创建了一个名为:test
密码为:1234
的用户。
注意:此处的"localhost",是指该用户只能在本地登录,不能在另外一台机器上远程登录。如果想远程登录的话,将"localhost"改为"%",表示在任何一台电脑上都可以登录。也可以指定某台机器可以远程登录。
1.3
然后登录一下:
mysqlexit;
@mysql
-u
test
-p
@输入密码
mysql登录成功
2.为用户授权
授权格式:grant
权限
on
数据库.*
to
用户名@登录主机
identified
by
"密码";
2.1
登录MYSQL(有ROOT权限),这里以ROOT身份登录:
@mysql
-u
root
-p
@密码
2.2
首先为用户创建一个数据库(testDB):
mysqlcreate
database
testDB;
2.3
授权test用户拥有testDB数据库的所有权限(某个数据库的所有权限):
mysqlgrant
all
privileges
on
testDB.*
to
test@localhost
identified
by
'1234';
mysqlflush
privileges;//刷新系统权限表
格式:grant
权限
on
数据库.*
to
用户名@登录主机
identified
by
"密码";
2.4
如果想指定部分权限给一用户,可以这样来写:
mysqlgrant
select,update
on
testDB.*
to
test@localhost
identified
by
'1234';
mysqlflush
privileges;
//刷新系统权限表
2.5
授权test用户拥有所有数据库的某些权限:
mysqlgrant
select,delete,update,create,drop
on
*.*
to
test@"%"
identified
by
"1234";
//test用户对所有数据库都有select,delete,update,create,drop
权限。
//@"%"
表示对所有非本地主机授权,不包括localhost。(localhost地址设为127.0.0.1,如果设为真实的本地地址,不知道是否可以,没有验证。)
//对localhost授权:加上一句grant
all
privileges
on
testDB.*
to
test@localhost
identified
by
'1234';即可。
3.
删除用户
@mysql
-u
root
-p
@密码
mysqlDelete
FROM
user
Where
User='test'
and
Host='localhost';
mysqlflush
privileges;
mysqldrop
database
testDB;
//删除用户的数据库
删除账户及权限:drop
user
用户名@'%';
drop
user
用户名@
localhost;
4.
修改指定用户密码
@mysql
-u
root
-p
@密码
mysqlupdate
mysql.user
set
password=password('新密码')
where
User="test"
and
Host="localhost";
mysqlflush
privileges;
5.
列出所有数据库
mysqlshow
database;
6.
切换数据库
mysqluse
'数据库名';
7.
列出所有表
mysqlshow
tables;
8.
显示数据表结构
mysqldescribe
表名;
9.
删除数据库和数据表
mysqldrop
database
数据库名;
mysqldrop
table
数据表名;
CREATE USER 'username'@'%' IDENTIFIED BY 'password';
上述语句为创建数据库用户username并设置密码为passwd。
GRANT ALL PRIVILEGES ON *.* TO 'username'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;
上述语句意思为username用户赋上所有主机访问权限。
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流