• linux下的shell操作mysql


    (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 plain copy
     
    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 plain copy
     
    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 plain copy
     
    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 plain copy
     
    1. service mysqld stop  
    2. mysqld_safe --user=taiyang --skip-grant-tables --skip-networking &  

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

  • 相关阅读:
    java 实现敏感词(sensitive word)工具详解使用说明
    一键自动生成 java junit 测试代码神器 gen-test-plugin 入门介绍
    基于 asm 实现比 spring BeanUtils 性能更好的属性拷贝框架
    java 反射借助 asm 获取参数名称最优雅简单的方式
    xml-mapping xml 与 java 对象转换映射框架,像 XStream 一样优雅地读写xml
    从零开始手写 spring ioc 框架,深入学习 spring 源码
    java property 配置文件管理工具框架,避免写入 property 乱序
    从零开始手写 dubbo rpc 框架
    java bean 属性验证框架 valid
    vue安装及测试mockjs
  • 原文地址:https://www.cnblogs.com/zzyoucan/p/7290034.html
Copyright © 2020-2023  润新知