1,针对mysql操作

 SET PASSWORD FOR 'root'@'localhost' = PASSWORD('newpass'); 设置密码
 update user set password=passworD("test") where user='root';修改密码
 flush privileges;
 grant all on *.* to root@'%' identified by 'your_password';
 mysql> select user,password,host from mysql.user;
 +------+-------------------------------------------+-----------+
 | user | password                                  | host      |
 +------+-------------------------------------------+-----------+
 | root | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | localhost |
 | root |                                           | 127.0.0.1 |
 | root |                                           | ::1       |
 |      |                                           | localhost |
 | repl | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | 10.0.5.44 |
 | root | *6BB4837EB74329105EE4568DDA7DC67ED2CA2AD9 | 10.0.5.44 |
 +------+-------------------------------------------+-----------+
 当设定密码后,如果要想更改密码如何操作呢?
 mysqladmin -u root -p password "
 Enter password:
 输入原来root的密码就可以更改密码了。
 【连接数据库】
 刚刚讲过通过使用mysql -u root -p 就可以连接数据库了,但这只是连接的本地的数据库’localhost’,然后有很多时候都是去连接网络中的某一个主机上的mysql。
 mysql -u user1 -p –P 3306 -h 10.0.2.69
 其中-P(大写)指定远程主机mysql的绑定端口,默认都是3306;-h指定远程主机的IP

 3. 查看某个表的字段
 mysql> desc func; //func 是表名
 +-------+------------------------------+------+-----+---------+-------+
 | Field | Type | Null | Key | Default | Extra |
 +-------+------------------------------+------+-----+---------+-------+
 | name | char(64) | NO | PRI | | |
 | ret | tinyint(1) | NO | | 0 | |
 | dl | char(128) | NO | | | |
 | type | enum('function','aggregate') | NO | | NULL | |
 +-------+------------------------------+------+-----+---------+-------+
 4. 查看某个表的表结构(创建表时的详细结构)
 mysql> show create table func;
 |Table | CreateTable |
 | func | CREATE TABLE `func` (
 `name` char(64) collate utf8_bin NOT NULL default '',
 `ret` tinyint(1) NOT NULL default ',
 `dl` char(128) collate utf8_bin NOT NULL default '',
 `type` enum('function','aggregate') character set utf8 NOT NULL,
 PRIMARY KEY (`name`)
 ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_bin COMMENT='User defined functions' |
 +-------+----------------------------------------------------------------------------------------------------------------------

 5. 查看当前是哪个用户
 mysql> select user();
 +----------------+
 | user() |
 +----------------+
 | root@localhost |
 +----------------+
 6. 查看当前所在数据库
 mysql> select database();
 +------------+
 | database() |
 +------------+
 | mysql |
 +------------+
 7. 创建一个新库
 mysql> create database db1;
 Query OK, 1 row affected (0.04 sec)
 8. 创建一个表
 mysql> create table t1 ( `id` int(4), `name` char(40));
 Query OK, 0 rows affected (0.02 sec)
 mysql> desc t1;
 +-------+----------+------+-----+---------+-------+
 | Field | Type | Null | Key | Default | Extra |
 +-------+----------+------+-----+---------+-------+
 | id | int(4) | YES | | NULL | |
 | name | char(40) | YES | | NULL | |
 +-------+----------+------+-----+---------+-------+
 9. 查看当前数据库版本
 mysql> select version();
 +-----------+
 | version() |
 +-----------+
 | 5.0.86 |
 +-----------+
 10. 查看当前系统时间
 mysql> select current_date, current_time;
 +--------------+--------------+
 | current_date | current_time |
 +--------------+--------------+
 | 2011-05-31 | 08:52:50 |
 +--------------+--------------+
 11. 查看当前mysql的状态
 mysql> show status;
 +-----------------------------------+----------+
 | Variable_name | Value |
 +-----------------------------------+----------+
 | Aborted_clients | 0 |
 | Aborted_connects | 1 |
 | Binlog_cache_disk_use | 0 |
 | Binlog_cache_use | 0 |
 | Bytes_received | 664 |
 | Bytes_sent | 6703 |
 这个命令打出很多东西,显示你的mysql状态。
 12. 查看mysql的参数
 mysql> show variables;
 很多参数都是可以在/etc/my.cnf中定义的。
 13. 创建一个普通用户并授权
 mysql> grant all on *.* to user1 identified by ';
 Query OK, 0 rows affected (0.01 sec)
 all 表示所有的权限(读、写、查询、删除等等操作),*.*前面的*表示所有的数据库,后面的*表示所有的表,identified by 后面跟密码,用单引号括起来。这里的user1指的是localhost上的user1,如果是给网络上的其他机器上的某个用户授权则这样:
 mysql> grant all on db1.* to ';
 Query OK, 0 rows affected (0.00 sec)
 用户和主机的IP之间有一个@,另外主机IP那里可以用%替代,表示所有主机。例如:
 mysql> grant all on db1.* to ';
 Query OK, 0 rows affected (0.00 sec)
 【一些常用的sql】
 1. 查询语句
 mysql> select count(*) from mysql.user;
 mysql.user表示mysql库的user表;count(*)表示表中共有多少行。
 mysql> select * from mysql.db;
 查询mysql库的db表中的所有数据
 mysql> select db from mysql.db;
 查询mysql库db表的db段。
 mysql> select * from mysql.db where host like '10.0.%';
 查询mysql库db表host字段like 10.0.% 的行,这里的%表示匹配所有,类似于前面介绍的通配符。
 2. 插入一行
 mysql> insert into db1.t1 values (1, 'abc');
 Query OK, 1 row affected (0.00 sec)
 t1表在前面已经创建过。
 mysql> select * from db1.t1;
 +------+------+
 | id | name |
 +------+------+
 | 1 | abc |
 +------+------+
 3. 更改某一行
 mysql> update db1.t1 set name='aaa' where id=1;
 Query OK, 1 row affected (0.02 sec)
 Rows matched: 1 Changed: 1 Warnings: 0
 这样就把原来id为1的那行中的name改成’aaa’
 4. 删除表
 mysql> drop table db1.t1;
 Query OK, 0 rows affected (0.01 sec)
 5. 删除数据库
 mysql> drop database db1;
 Query OK, 0 rows affected (0.07 sec)
 6. 备份与恢复库
 mysqldump -uroot -p mysql >mysql.sql
 这里的mysqldump 就是备份的工具了,-p后面的mysql指的是mysql库,把备份的文件重定向到mysql.sql。如果恢复的话,只要:
 mysql -uroot -p mysql < mysql.sql

2.python链接数据库并执行备份

 import pymysql
 import os, sys, tarfile, datetime, re, time, subprocess

 Date = time.strftime('%Y%m%d_%H-%M')
 print(Date)

 flage = None
 Flage = None

 class mysql_backup(object):
     def __init__(self,res,host,user,pwd,gamedb,path):
         self.res = res
         self.host = host
         self.user = user
         self.pwd = pwd
         self.gamedb = gamedb
         self.path = path

     def connect(self):
         f = open(self.path + "errlog_db.log","a+",encoding="utf-8")
         try:
             conn = pymysql.connect(host=self.host, user=self.user, passwd=self.pwd, db=self.gamedb)
             print("connect ok")
             global flage
             flage = True
         except Exception as e:
             f.write(Date + ':' + 'connect to mysqldb error!!!' + '\n')
             sys.exit()
         conn.close()
         f.close()

     def sqlfile(self):
         global flage, Flage
         if flage:
             f = open(self.path + "errlog_db.log", "a+", encoding="utf-8")
             try:
                 os.system('%s -u%s -p%s -h%s %s >> %sgamedb.sql' % (self.res,self.user,self.pwd,self.host,self.gamedb,self.path))
                 tarsql = tarfile.open( self.path + Date + '.tar', 'w')
                 tarsql.add(self.path + 'gamedb.sql',arcname= Date + ".gamedb.sql")
                 tarsql.close()
                 Flage = True
                 print("sqlfile ok %s" % self.user)
             except Exception as e:
                 f.write(Date + ':' + 'sqlfile to tar error!!!' + '\n')
                 sys.exit()
             f.close()

     def refile(self):
         global flage, Flage
         if flage and Flage:
             if os.path.isfile(self.path + 'gamedb.sql'):
                 os.system("rm -f" + " " + self.path + "gamedb.sql")
                 print("refiel ok")

     def errlog(self):
         if os.path.isdir(self.path) is False:
             os.makedirs(self.path)
             print("path ok")
         if os.path.isfile(self.path + 'errlog_db.log') is False:
             os.system("touch" + " " + self.path + "errlog_db.log")
             print("errlog ok")

     def oldfile(self):
         settime= (datetime.datetime.now() - datetime.timedelta(days=1)).strftime('%Y%m%d') #获取到30天前的时间
         settime = int(settime)

         for dirpath,dirnames,filenames in os.walk(self.path):
             for file in filenames:
                 if file != 'errlog_db.log':
                     filetime = time.strftime('%Y%m%d', time.localtime(os.stat(self.path + file).st_ctime))  #获取文件时间
                     filetime = int(filetime)
                     print(file)
                     if settime == filetime:
                         os.remove(self.path + file)

 #需要你手动更改打开的文件位置,注意#行需要更改
 def config():
     file = open("start", "r", encoding="utf-8")    #打开文件位置
     host = re.findall(r'-db_host="(\w.*?)"', file.read())
     str_host = ''.join(host)
     file.close()

     file = open("start","r",encoding="utf-8")
     dbname = re.findall(r'-db_name="(\w.*?)"',file.read())   #打开文件位置
     str_dbname = ''.join(dbname)
     file.close()

     res = subprocess.Popen("which mysqldump", shell=True, stdout=subprocess.PIPE)
     res = res.stdout.read().decode().strip()

     parameter = mysql_backup(res,str_host,',str_dbname,r'/data/backup_db/')   #用户,密码需要更改,路径
     parameter.errlog()
     parameter.connect()
     parameter.sqlfile()
     parameter.refile()
     parameter.oldfile()

 if __name__ == "__main__":
     config()

3.redis操作。。。。

python学习道路(day12note)(mysql操作,python链接mysql,redis)的更多相关文章

  1. Python学习入门基础教程(learning Python)--5.6 Python读文件操作高级

    前文5.2节和5.4节分别就Python下读文件操作做了基础性讲述和提升性介绍,但是仍有些问题,比如在5.4节里涉及到一个多次读文件的问题,实际上我们还没有完全阐述完毕,下面这个图片的问题在哪呢? 问 ...

  2. Python学习课程零基础学Python

    python学习课程,零基础Python初学者应该怎么去学习Python语言编程?python学习路线这里了解一下吧.想python学习课程?学习路线网免费下载海量python教程,上班族也能在家自学 ...

  3. Python学习系列(四)Python 入门语法规则2

    Python学习系列(四)Python 入门语法规则2 2017-4-3 09:18:04 编码和解码 Unicode.gbk,utf8之间的关系 2.对于py2.7, 如果utf8>gbk, ...

  4. 【Python学习之十】操作数据库

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 python3.6 操作mysql数据库 1.安装pymysql模块p ...

  5. [Python学习笔记][第七章Python文件操作]

    2016/1/30学习内容 第七章 Python文件操作 文本文件 文本文件存储的是常规字符串,通常每行以换行符'\n'结尾. 二进制文件 二进制文件把对象内容以字节串(bytes)进行存储,无法用笔 ...

  6. Python学习杂记_3_字符串操作的常用方法

    字符串操作 字符串是可以通过下标来进行取值的,但是由于字符串是不可变变量,不能通过下标来修改它的值(形式如 字符串[下标]),下标从0开始,最大下标值是字符串长度减1,即len(string)-1 P ...

  7. 【Python学习之六】文件操作

    环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 python3.6 一.文件的打开与关闭 使用open函数,可以打开一 ...

  8. python学习1-博客-DB操作类

    #学习python,准备写一个博客,第一天:在别人代码基础上写一个数据库操作的db.py1)python代码 #!/usr/bin/env python # -*- coding: UTF-8 -*- ...

  9. 【Python学习笔记】字符串操作

    字符串的表示 python中的字符串是一个常量,可以使用单引号'',双引号""或三引号""" """来创建一个字符串常量 ...

随机推荐

  1. oracle插入数据时解决和旧数据id的冲突

    我们在使用oracle创建一个主键的时候需要让他自增, 但是他跟mysql不同,需要创建序列,具体看下面: 可以删除之前创建的sequence,我们在重新创建一个: DROP SEQUENCE SJG ...

  2. python之路十

    协程协程,又称微线程,纤程.英文名Coroutine.一句话说明什么是线程:协程是一种用户态的轻量级线程.协程拥有自己的寄存器上下文和栈.协程调度切换时,将寄存器上下文和栈保存到其他地方,在切回来的时 ...

  3. HTML文档、javascript脚本的加载与解析

    1.onload事件 1.1 onload事件分类 a.文档加载完成事件(包括脚本.图片等资源都加载完),绑定方法:<body onload="doSomething()"& ...

  4. poj 3038

    http://poj.org/problem?id=3038 这个题我是在一个关于并查集的博客中找到的,结果我就觉得这个应该是个贪心,真想不出这个与并查集有什么鬼关系,看discuss里面也都是贪心, ...

  5. Unity3D LuaComponent(基于ulua)

    LuaComponent可以支持配一个需要执行在这个gameObject上的lua脚本,并且每个gameObject上的lua都是一个实例 using UnityEngine; using LuaIn ...

  6. Java、JVM模型

    程序计数器:记录当前线程的执行位置(便于CPU切换线程的时候执行) 虚拟机栈:Java方法,方法从调用到执行完成对应一个栈帧从虚拟机栈入栈到出栈的过程. 本地方法区:Native方法(C++) 方法区 ...

  7. NSString相关操作

    //创建一个字符串对象 NSString * str_1 = @"Hello"; //字面量方法 ; NSString * str_2 = [NSString stringWith ...

  8. ASP.NET 保存txt文件

    public void ProcessRequest(HttpContext context) { context.Response.Clear(); context.Response.Buffer ...

  9. PHP【函数】

    目录:[PHP函数].[PHP数组] 一.PHP常用函数(和JS一样)函数的四要素:①返回类型②函数名③参数类型④函数体因为PHP是弱类型语言,所以可以不用写返回类型,但是其他三个要素都是必须要写的. ...

  10. javaScript的call关键字

    function add(a, b) { alert(a + b); } function sub(a, b) { alert(a - b); } add.call(sub,3,1); //这个例子中 ...