@xtccc
2018-07-03T11:14:40.000000Z
字数 2387
阅读 5311
Database
在安装完MySQL后,MySQL会为root用户产生一个默认的初始密码,如下:
[root@ecs1 ~]# grep 'temporary password' /var/log/mysqld.log
2015-11-07T06:48:24.236714Z 1 [Note] A temporary password is generated for root@localhost: X_f#f+Zxm6P&
这里可以看出,初始的密码就是X_f#f+Zxm6P&
,用该密码登录到MySQL的控制台后,需要修改改密码才能继续操作数据库:
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'NJZD@2014*xiaotao';
Query OK, 0 rows affected (0.00 sec)mysql> flush privileges;
Query OK, 0 rows affected (0.00 sec)
上面我们可以从localhost登录MySQL,但是使用同样的用户名和密码从远程的可视化界面客户端就无法登录到MySQL了,如下:
这是因为当前的策略是不允许从localhost之外的地方以root身份登录到MySQL,可以如下修改系统表:
mysql> use mysql;
mysql> update user set host='%' where user='root';
mysql> flush privileges;
local在mysql client内操作
1. 登录到MySQL;
2. 使用某个数据库(如不存在,首先创建);
3. 将该文件导入到该数据库中
如下:
mysql> create database kms;
mysql> use kms;
mysql> source /disk1/users/tao/standard_cloud-2015-1102-1318-33.sql;
远程用mysqldump操作
MySQL Server在远程host,只要本机有mysql client,就可以进行数据的导入和导出。
$ mysql -h [host] -u [user] -p'[passwd]' [schema] < [filename]
该操作不会输出进度及细节。
local在mysql client内操作
mysql> select A, to_base64(B) from fsn.product
into outfile '/data/fsn.dump'
fields terminated by X'01'
lines terminated by X'02';
这里,X'01'
表示ASCII码为1的字节, to_base64()方法需要在5.6以上的版本才具有。
如果执行时报错: The MySQL server is running with the --secure-file-priv option so it cannot execute this statement
说明权限出了问题,参考 MySQL : How to tackle --secure-file-priv。
远程用mysql命令操作
$ mysqldump -h [host] -u [user] -p'[passwd]' [schema] [table] > [filename]
该操作不会输出进度及细节。
#!/bin/bash
declare -a arr=("attribute" "attributelist" "billing_cycle" "commitlog" "compatibilitymatrix" "compatibilitymatrix2" "contractbody" "contractmodifier" "contractoption" "contractratecode" "contractroot" "contractrule" "contractscenario" "customer_transform_rule" "customerbillingcycle" "deftable" "deftablesummary" "dictionary" "dictionaryentry" "eligibilitymatrix" "globaltable" "internaluser" "marketplacetable" "parameter" "reftable" "reftable2" "rulemodel" "scenarios")
for i in "${arr[@]}"
do
echo "dumping $i ..."
mysqldump -h [ip] -u [user] -p'[passwd]' [schema] "$i" > "sce.$i.sql"
## 如果是load,则换成下面的
## mysql -h [host] -u [user] -p'[passwd]' [new-schema] < "sce.$i.sql"
done
echo "all done !"
假设:
表test1有4列: pk, c0, c1, c2
表test2有4列: pk, c1, c2, c3
现在希望将这两张表以pk为主键关联起来进行查询,那么查询结果ResultSet中就分别存在test1和test2的c1列和c2列,怎样来区分属于两张表的列名呢?
答案是在查询时对列使用别名,如下:
select t1.pk, t1.c0, t1.c1, t1.c2, t2.c1, t2.c2, t2.c3
from test1 as t1, test2 as t2
where t1.pk = t2.pk