建用户命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password';
说明: username:你将创建的用户名 host:指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost,如果想让该用户可以从任意远程主机登陆,可以使用通配符% password:该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器 例子: CREATE USER 'dog'@'localhost' IDENTIFIED BY '123456'; CREATE USER 'pig'@'192.168.1.101_' IDENDIFIED BY '123456'; CREATE USER 'pig'@'%' IDENTIFIED BY '123456'; CREATE USER 'pig'@'%' IDENTIFIED BY ''; CREATE USER 'pig'@'%';
二. 授权:
命令:GRANT privileges ON databasename.tablename TO 'username'@'host'
说明: privileges:用户的操作权限,如SELECT,INSERT,UPDATE等,如果要授予所的权限则使用ALL databasename:数据库名 tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示,如*.* 例子: GRANT SELECT, INSERT ON test.user TO 'pig'@'%'; GRANT ALL ON *.* TO 'pig'@'%'; GRANT ALL ON maindataplus.* TO 'pig'@'%'; 注意: 用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令: GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;
设置与更改用户密码
命令:SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');
如果是当前登陆用户用: SET PASSWORD = PASSWORD("newpassword"); 例子: SET PASSWORD FOR 'pig'@'%' = PASSWORD("123456");
四. 撤销用户权限 命令:REVOKE privilege ON databasename.tablename FROM 'username'@'host'; 说明: privilege, databasename, tablename:同授权部分
例子: REVOKE SELECT ON *.* FROM 'pig'@'%'; 注意: 假如你在给用户'pig'@'%'授权的时候是这样的(或类似的):GRANT SELECT ON test.user TO 'pig'@'%',则在使用REVOKE SELECT ON *.* FROM 'pig'@'%';命令并不能撤销该用户对test数据库中user表的SELECT 操作。相反,如果授权使用的是GRANT SELECT ON *.* TO 'pig'@'%';则REVOKE SELECT ON test.user FROM 'pig'@'%';命令也不能撤销该用户对test数据库中user表的Select权限。
SELECT
CONCAT(
'create database ',
'`',
SCHEMA_NAME,
'`',
' DEFAULT CHARACTER SET ',
DEFAULT_CHARACTER_SET_NAME,
';'
) AS CreateDatabaseQuery
FROM
information_schema.SCHEMATA
WHERE
SCHEMA_NAME NOT IN (
'information_schema',
'performance_schema',
'mysql',
'sys'
);
5.拼接创建用户的语句
SELECT
CONCAT(
'create user \'',
user,
'\'@\'',
Host,
'\''
' IDENTIFIED BY PASSWORD \'',
authentication_string,
'\';'
) AS CreateUserQuery
FROM
mysql.`user`
WHERE
`User` NOT IN (
'root',
'mysql.session',
'mysql.sys'
);
#有密码字符串哦 在其他实例执行 可直接创建出与本实例相同密码的用户
6.导出权限脚本 这个shell脚本也用到了拼接
#!/bin/bash
#Function export user privileges
pwd=yourpass
expgrants()
{
mysql -B -u'root' -p${pwd} -N $@ -e "SELECT CONCAT( 'SHOW GRANTS FOR ''', user, '''@''', host, ''';' ) AS query FROM mysql.user" | \
mysql -u'root' -p${pwd} $@ | \
sed 's/\(GRANT .*\)/\1;/;s/^\(Grants for .*\)/-- \1 /;/--/{x;p;x;}'
}
SELECT t.TABLE_SCHEMA,
t.TABLE_NAME,
t.TABLE_ROWS,
concat(round(t.DATA_LENGTH / 1024 / 1024, 2), 'M') AS size,
t.INDEX_LENGTH,
concat(round(t.DATA_FREE / 1024 / 1024, 2), 'M') AS datafree
FROM information_schema.tables t
WHERE t.TABLE_SCHEMA = 'test' order by DATA_LENGTH desc;
8.查找无主键表 这个没用到拼接 也分享出来吧
#查找某一个库无主键表
SELECT
table_schema,
table_name
FROM
information_schema.TABLES
WHERE
table_schema = 'test'
AND TABLE_NAME NOT IN (
SELECT
table_name
FROM
information_schema.table_constraints t
JOIN information_schema.key_column_usage k USING (
constraint_name,
table_schema,
table_name
)
WHERE
t.constraint_type = 'PRIMARY KEY'
AND t.table_schema = 'test'
);
#查找除系统库外 无主键表
SELECT
t1.table_schema,
t1.table_name
FROM
information_schema. TABLES t1
LEFT OUTER JOIN information_schema.TABLE_CONSTRAINTS t2 ON t1.table_schema = t2.TABLE_SCHEMA
AND t1.table_name = t2.TABLE_NAME
AND t2.CONSTRAINT_NAME IN ('PRIMARY')
WHERE
t2.table_name IS NULL
AND t1.TABLE_SCHEMA NOT IN (
'information_schema',
'performance_schema',
'mysql',
'sys'
) ;
#########PS:
mysql 查询后不显示标题 2018年10月22日 15:48:00 weixin_33872566 阅读数 2 mysql -h 146.240.54.1 -P 60028 -u dba -p123456 -Dtestdb
直接进入命令行,select,是有|显示的格式的。
mysql -h 146.240.54.1 -P 60028 -u dba -p123456 -Dtestdb<1.sql
这样使用批处理的方式执行,显示是没有|的。
mysql -h 146.240.54.1 -P 60028 -u dba -p123456 -Dtestdb -t<1.sql
如果增加了-t命令项,则会显示|格式
如果使用-vvv选项,则会回显命令。
mysql -h 146.240.54.1 -P 60028 -u dba -p123456 -Dtestdb -N<1.sql
7 个回复
nccloud
1、替换内容字段中的换行符
nccloud
建库:create DATABASE `local-eop` DEFAULT CHARSET utf8mb4;
注:数据库名带特殊字符用``包括起来
建用户命令:CREATE USER 'username'@'host' IDENTIFIED BY 'password';
说明:
username:你将创建的用户名
host:指定该用户在哪个主机上可以登陆,如果是本地用户可用localhost,如果想让该用户可以从任意远程主机登陆,可以使用通配符%
password:该用户的登陆密码,密码可以为空,如果为空则该用户可以不需要密码登陆服务器
例子:
CREATE USER 'dog'@'localhost' IDENTIFIED BY '123456';
CREATE USER 'pig'@'192.168.1.101_' IDENDIFIED BY '123456';
CREATE USER 'pig'@'%' IDENTIFIED BY '123456';
CREATE USER 'pig'@'%' IDENTIFIED BY '';
CREATE USER 'pig'@'%';
二. 授权:
命令:GRANT privileges ON databasename.tablename TO 'username'@'host'
说明:
privileges:用户的操作权限,如SELECT,INSERT,UPDATE等,如果要授予所的权限则使用ALL
databasename:数据库名
tablename:表名,如果要授予该用户对所有数据库和表的相应操作权限则可用*表示,如*.*
例子:
GRANT SELECT, INSERT ON test.user TO 'pig'@'%';
GRANT ALL ON *.* TO 'pig'@'%';
GRANT ALL ON maindataplus.* TO 'pig'@'%';
注意:
用以上命令授权的用户不能给其它用户授权,如果想让该用户可以授权,用以下命令:
GRANT privileges ON databasename.tablename TO 'username'@'host' WITH GRANT OPTION;
设置与更改用户密码
命令:SET PASSWORD FOR 'username'@'host' = PASSWORD('newpassword');
如果是当前登陆用户用:
SET PASSWORD = PASSWORD("newpassword");
例子:
SET PASSWORD FOR 'pig'@'%' = PASSWORD("123456");
四. 撤销用户权限
命令:REVOKE privilege ON databasename.tablename FROM 'username'@'host';
说明:
privilege, databasename, tablename:同授权部分
例子:
REVOKE SELECT ON *.* FROM 'pig'@'%';
注意:
假如你在给用户'pig'@'%'授权的时候是这样的(或类似的):GRANT SELECT ON test.user TO 'pig'@'%',则在使用REVOKE SELECT ON *.* FROM 'pig'@'%';命令并不能撤销该用户对test数据库中user表的SELECT 操作。相反,如果授权使用的是GRANT SELECT ON *.* TO 'pig'@'%';则REVOKE SELECT ON test.user FROM 'pig'@'%';命令也不能撤销该用户对test数据库中user表的Select权限。
具体信息可以用命令SHOW GRANTS FOR 'pig'@'%'; 查看。
五.删除用户
命令:DROP USER 'username'@'host';
nccloud
mysql 添加成系统服务
#my.cnf会覆盖mysql.server里的basedir和datadir配置
#RPM安装方式下,mysql.server存放于/usr/share/mysql/mysql.server
将/mysql数据库文件目录/support-files/mysql.server 复制到 /etc/rc.d/init.d/mysql 并修改其中的
basedir=/data/mysql-5.7.28-linux-glibc2.12-x86_64
datadir=/data/mysql/data
nccloud
转 【MySQL】常用拼接语句 shell 下执行mysql 命令
【MySQL】常用拼接语句
前言:在MySQL中 CONCAT ()函数用于将多个字符串连接成一个字符串,利用此函数我们可以将原来一步无法得到的sql拼接出来,在工作中也许会方便很多,下面主要介绍下几个常用的场景。
注:适用于5.7版本 低版本可能稍许不同。
1.拼接查询所有用户
2.拼接DROP table
3.拼接kill连接
4.拼接创建数据库语句
5.拼接创建用户的语句
6.导出权限脚本 这个shell脚本也用到了拼接
7.查找表碎片
8.查找无主键表 这个没用到拼接 也分享出来吧
#########PS:
mysql 查询后不显示标题
2018年10月22日 15:48:00 weixin_33872566 阅读数 2
mysql -h 146.240.54.1 -P 60028 -u dba -p123456 -Dtestdb
直接进入命令行,select,是有|显示的格式的。
mysql -h 146.240.54.1 -P 60028 -u dba -p123456 -Dtestdb<1.sql
这样使用批处理的方式执行,显示是没有|的。
mysql -h 146.240.54.1 -P 60028 -u dba -p123456 -Dtestdb -t<1.sql
如果增加了-t命令项,则会显示|格式
如果使用-vvv选项,则会回显命令。
mysql -h 146.240.54.1 -P 60028 -u dba -p123456 -Dtestdb -N<1.sql
如果使用-N选项,则不显示标题。
在mysql命令行下,可以直接执行批处理文件。
mysql>. 1.sql
作者:mydriverc2
来源:CSDN
原文:https://blog.csdn.net/mydriverc2/article/details/38895395
###3
https://www.cnblogs.com/wangkangluo1/archive/2012/04/27/2472898.html
shell 下执行mysql 命令
原文链接
在shell开发中,很多时候我们需要操作mysql数据库(比如:查询数据、导出数据等),但是我们又无法进入mysql命令行的环境,就需要在shell环境中模拟mysql的环境,使用mysql相关命令,本文总结几种shell操作mysql的方法,供大家参考。
方案1
方案2
方案3
方案4
nccloud
1、创建一个TS类字段,默认根据数据修改时间更新
CREATE TABLE
patch_confict
(
id INT NOT NULL AUTO_INCREMENT,
md5 CHAR(32) NOT NULL,
contents VARCHAR(1024) DEFAULT '0',
real_path VARCHAR(1024),
ts DATETIME DEFAULT CURRENT_TIMESTAMP,
PRIMARY KEY (id),
CONSTRAINT patchconfict_ix_md5 UNIQUE (md5)
)
ENGINE=InnoDB DEFAULT CHARSET=utf8;
后增加字段:
ALTER TABLE `表名`
ADD COLUMN `字段名` datetime NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP AFTER `字段名`;
nccloud
2、mysql 通过命令执行外部脚本
mysql –u用户名 –p密码 –D数据库 <【sql脚本文件绝对路径】
或者,登录到服务器命令行后
source
sql脚本文件绝对路径
nccloud
某个字段值前面增加:邮掌柜ID:
update mlos_am_member a set a.memo4=''邮掌柜ID:'||a.memo4
where memberid='M0000277100100112'
某个字段值去掉:邮掌柜ID:
UPDATE mlos_am_member SET memo4 = REPLACE(memo4, '邮掌柜ID:','')
WHERE memberid='M0000277100100112'