(1)MySQL的启动

重启了一次服务器后,使用> mysql -u root -p登陆是出现下面的错误:

ERROR 2002 (HY000): Can't connect to local MySQL server through socket '/tmp/mysql.sock' (2)

查看状态: > /etc/rc.d/init.d/mysqld  status

显示stop,未运行:>/etc/rc.d/init.d/mysqld  restart

(2)mysql数据库导入、导出

1.导出整个数据库

mysqldump -u 用户名 -p 数据库名 > 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc > wcnc.sql
2.导出一个表
mysqldump -u 用户名 -p 数据库名 表名> 导出的文件名
mysqldump -u wcnc -p smgp_apps_wcnc users> wcnc_users.sql
3.导出一个数据库结构
mysqldump -u wcnc -p -d --add-drop-table smgp_apps_wcnc >d:wcnc_db.sql
-d 没有数据 --add-drop-table 在每个create语句之前增加一个drop table
备忘: mysqldump在linux下可直接使用 在windows下有时需要进入mysql/bin中使用 因为有时用的是类似appserv的套装软件 这样的话命令就不能直接使用 因为这些命令没在环境变量的目录里 而且用mysqldump导出的备份 必须先建立数据库才能导入
4.导入数据库
常用source 命令
进入mysql数据库控制台,
如mysql -u root -p
mysql>use 数据库
然后使用source命令,后面参数为脚本文件(如这里用到的.sql)
mysql>source d:wcnc_db.sql
(3)MySQL数据文件目录

MySQL默认的数据文件存储目录为/var/lib/mysql,MySQL配置文件:/etc/my.cnf,MySQL启动脚本:/etc/init.d/mysqld。

(4)Linux下的shell操作数据库的例子

1.shell文件内容:

[html] view plaincopy
  1. #!/bin/bash
  2. HOSTNAME="11.8.8.87"
  3. PORT="3306"
  4. USERNAME="root"
  5. PASSWORD="root"
  6. DBNAME="testa"
  7. TABLENAME="test"
  8. use_db_sql="use ${DBNAME}"
  9. mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} -e "${use_db_sql}"
  10. insert_sql="insert into ${TABLENAME} values('7','mike','123456')"
  11. mysql -h${HOSTNAME} -P${PORT} -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${insert_sql}"

主机地址:11.8.8.87 端口:3306  数据库:testa 表:test

2.test表结构:

[html] view plaincopy
  1. mysql> desc test;
  2. +----------+-------------+------+-----+---------+----------------+
  3. | Field    | Type        | Null | Key | Default | Extra          |
  4. +----------+-------------+------+-----+---------+----------------+
  5. | t_id     | int(24)     | NO   | PRI | NULL    | auto_increment |
  6. | username | varchar(32) | YES  |     | NULL    |                |
  7. | password | varchar(32) | YES  |     | NULL    |                |
  8. +----------+-------------+------+-----+---------+----------------+
  9. 3 rows in set (0.00 sec)

3.我这里命名shell文件名为:mysqltestshell,在windows上编辑后上传到linux服务器上,

修改权限:chmod +x mysqltestshell

执行./mysqltestshell,

报错:-bash: ./mysqltestshell: /bin/bash^M: bad interpreter: No such file or directory

解决办法:

vi mysqltestshell
然后用命令 :set ff?
可以看到dos或unix的字样. 如果的确是dos格式的, 那么你可以用set ff=unix把它强制为unix格式的, 然后存盘退出. 再运行一遍看.
4.运行结果
请自觉忽略乱码情况(此处只是测试),可以看到新增了一条记录

[html] view plaincopy
  1. mysql> select * from test;
  2. +------+----------+----------------------+
  3. | t_id | username | password             |
  4. +------+----------+----------------------+
  5. |    1 | 娴璇     | 娴璇瀵鐮             |
  6. |    2 | ??       | 娴璇瀵鐮             |
  7. |    3 | ??       | 忙碌?猫炉?氓炉?莽聽?         |
  8. |    4 | ??       | ????                 |
  9. |    5 | ??       | ????                 |
  10. |    6 | ??       | ????                 |
  11. |    7 | mike     | 123456               |
  12. +------+----------+----------------------+
  13. 7 rows in set (0.00 sec)

----------------------------------------------------------补充----------------------------------------------------------------
mysql  -hhostname -Pport -uusername -ppassword  -e  相关mysql的sql语句,不用在mysql的提示符下运行mysql,即可以在shell中操作mysql的方法。
#!/bin/bash
HOSTNAME="192.168.111.84"                                           #数据库信息
PORT="3306"
USERNAME="root"
PASSWORD=""
DBNAME="test_db_test"                                                       #数据库名称
TABLENAME="test_table_test"                                            #数据库中表的名称
#创建数据库
create_db_sql="create database IF NOT EXISTS ${DBNAME}"
mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} -e "${create_db_sql}"
#创建表
create_table_sql="create table IF NOT EXISTS ${TABLENAME} (  name varchar(20), id int(11) default 0 )"
mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${create_table_sql}"
#插入数据
insert_sql="insert into ${TABLENAME} values('billchen',2)"
mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${insert_sql}"
#查询
select_sql="select * from ${TABLENAME}"
mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"
#更新数据
update_sql="update ${TABLENAME} set id=3"
mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${update_sql}"
mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"
#删除数据
delete_sql="delete from ${TABLENAME}"
mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${delete_sql}"
mysql -h${HOSTNAME}  -P${PORT}  -u${USERNAME} -p${PASSWORD} ${DBNAME} -e "${select_sql}"
(4)mysql,test数据库的初始化
执行:/usr/bin/mysql_install_db,可以在/var/lib/mysql里看到数据库的目录。
(5)修改mysql登录密码
若忘记密码:
# /etc/init.d/mysqld stop
# mysqld_safe --user=mysql --skip-grant-tables --skip-networking &
# mysql -u root mysql
mysql> UPDATE user SET Password=PASSWORD(’newpassword’) where USER=’root’;
mysql> FLUSH PRIVILEGES;
mysql> quit
# /etc/init.d/mysqld restart
# mysql -uroot -p
Enter password: <输入新设的密码newpassword>
mysql>
若记得密码,重新设置密码:
#mysql -u root -p
登录后:
mysql> UPDATE user SET Password=PASSWORD(’newpassword’) where USER=’root’;
mysql> FLUSH PRIVILEGES;
mysql> quit
取消登录密码:
mysql> update user set password='' where user='root';
mysql> FLUSH PRIVILEGES;
mysql> quit
(6)普通用户无法登录
taiyang用户登录时,出现提示:ERROR 1045 (28000): Access denied for user 'taiyang'@'localhost' (using password: NO)

[html] view plaincopy
  1. service mysqld stop
  2. mysqld_safe --user=taiyang --skip-grant-tables --skip-networking &

然后taiyang用户就能正常登录了。

转载于:https://www.cnblogs.com/zzyoucan/p/7290034.html

linux下的shell操作mysql相关推荐

  1. linux下使用python操作mysql

    linux下使用python操作mysql 文章目录 linux下使用python操作mysql 一.Python 中MySQL的几个模块对象 1.模块 2.Connection 对象 3.Curso ...

  2. linux下使用C++操作mysql

    linux下使用C++操作mysql 文章目录 linux下使用C++操作mysql 一.常用类型介绍 1. MYSQL 2. MYSQL_ROW 3. MYSQL_FIELD 4. MYSQL_RE ...

  3. linux下c语言调用mysql,Linux下C语言操作MYSQL总结

    Linux下C语言操作MYSQL总结 发布时间:2006-12-17 00:40:00来源:红联作者:anciens 下文的用到的数据库表: 数据库中存在表table, 有name(varchar类型 ...

  4. Linux下使用OTL操作mysql数据库

    首先重点推荐介绍otl介绍及用法的文章:http://www.cnblogs.com/fnlingnzb-learner/p/5835560.html 一.编写代码 注:以下代码来自OTL示例,略有改 ...

  5. linux下c语言调用mysql,Linux下C语言连接MySQL

    首先保证安装: 1:安装MySQL:sudo apt-get install mysql-server mysql-client 2:安装MySQL开发包:sudo apt-get install l ...

  6. linux下使用的mysql数据库,Linux下安装以及使用MySQL数据库

    1.官网下载mysql数据库:https://dev.mysql.com/downloads/mysql/ 2.linux 下可直接下载:wget https://cdn.mysql.com//Dow ...

  7. linux shell操作mysql,Linux shell操作mysql数据库的方法

    摘要 腾兴网为您分享:Linux shell操作mysql数据库的方法,鱼乐贝贝,宜信,嘻嘻动漫,西餐菜谱等软件知识,以及包装效果图,德州人社,evasi0n.com,ios迅雷,民革e家,动态表情, ...

  8. linux python开发环境sql数据迁移到mysql_linux环境下python怎样操作mysql数据库

    展开全部 linux环境下python怎样操作mysql数据库呢?方法如下: 首先在Linux环境下安装mysql-python 1.下载mysql-python 打开终端: cd /usr/loca ...

  9. linux php mysql.so_在linux下php挂接mysql.so扩展的方法

    总结的方向:在linux下php挂接mysql.so扩展的方法 问题背景:平常我们都是先安装mysql,然后才能去安装php.假如先安装php,后安装mysql,由于php需要连接mysql,因而在p ...

最新文章

  1. java查看内存地址_Java内存机制和内存地址
  2. android中的定时任务一般有两种机制,android 定时任务
  3. 使用Lex和Yacc开发C语言的编译器
  4. ITK:将矢量图像投射为另一种类型
  5. Python视频编辑库:MoviePy
  6. 龙芯linux内核,龙芯的linux kernel,内核开发与编译
  7. 笔记 | 《机器学习》手推笔记更新集成学习(Boosting和随机森林)
  8. 一个网站大概多少钱_建一个外贸网站大概需要多少钱?角点科技总结建外贸网站的费用...
  9. MySQL Identifiers(标识符)
  10. linux里面的perl脚本怎么调用函数,如何在我的Perl脚本中包含另一个文件的函数?...
  11. Error Code : 1064 You have an error in your SQL syntax; check the manual that corresponds to your My
  12. ASP.NET站点性能提升-缩短首页生成时间
  13. 直播开发中关于三级分销功能源码的实现介绍
  14. 80286 与 80386,实模式与保护模式切换编程
  15. 自学-CAD零基础视频教程网站
  16. 什么是RC版本(转载)
  17. ブリアー / 三星枪
  18. WPS for Linux使用测评
  19. 混合App WebView自动化测试
  20. 抑郁症,莫要讳疾忌医。

热门文章

  1. linux ssh和sftp区别,Linux SSH和SFTP配置
  2. windows java配置_菜鸟教程 windows 配置java的环境变量
  3. 默认网关出现乱码_SpringCloudZuul服务网关
  4. KubeEdge 1.3.0 部署
  5. linux时区的几个代码片段
  6. 初识openwrt(下)
  7. maven build时报错Failed to execute goal org.apache.maven.plugins......
  8. Oracle数据库报错【ORA-12514 】TNS 监听程序当前无法识别连接描述符中请求服务
  9. 三人表决器_数电小实验之三人表决器
  10. 【clickhouse】Too many parts . Merges are processing significantly slower than inserts