Python --链接MYSQL数据库与简单操作 含SSH链接
项目是软硬件结合,在缺少设备的情况,需要通过接口来模拟实现与设备的交互,其中就需要通过从数据库读取商品的ID信息
出于安全考虑 现在很多数据库都不允许通过直接访问,大多数是通过SSH
SSH : 数据库开放哪台机器访问,就通过哪台机器的SSH跳过去
例如:数据库在A机器,只能通过B来访问,本机C来链接B链接A的数据库
链接数据库与简单操作:
链接数据库:
import MySQLdb
#打开数据库链接
lcDB = MySQLdb.connect("127.0.0.1", "%”,"","go" )
简单数据库操作:
创建数据库表:
import MySQLdb
#打开数据库链接
lcDB = MySQLdb.connect("127.0.0.1", "root","","test" )
#使用cursor()方法获取操作游标
cursor = lcDB.cursor() #使用execute方法执行SQL语句
cursor.execute('select version()') #查询MYSQL版本 #使用fetchone()方法获取一条数据
data = cursor.fetchone() print("Database version : %s"%data) #使用 execute()方法执行SQL,如果表存在则删除
cursor.execute("DROP TABLE if exists employee") #使用预处理语句创建表
sql = """create table employee(
first_name char(20) not null,
last_name char(20),
age int,
sex char(1),
income float
)""" cursor.execute(sql) #关闭数据库链接
lcDB.close()
执行结果:
Database version : 8.0.11
数据库:

插入数据:
import pymysql #打开数据库链接
lcDB = pymysql.connect("127.0.0.1", "root", "", "test") #使用cursor()方法创建一个游标对象cursor
cursor = lcDB.cursor() #SQL 插入语句
#此处可将SQL换位update, delete等语句
sql = "insert into employee(first_name,\
last_name, age, sex, income)\
values ('%s', '%s', '%s','%s', '%s')"% \
('li', 'Mohan', 20, 'M', 1000) try:
# 使用execute()方法执行sql,
cursor.execute(sql)
#提交到数据库执行sql语句
lcDB.commit() except:
#发生错误时回滚
lcDB.rollback() #关闭数据库
lcDB.close()
数据库查询操作
Python查询Mysql使用 fetchone() 方法获取单条数据, 使用fetchall() 方法获取多条数据。
- fetchone(): 该方法获取下一个查询结果集。结果集是一个对象
- fetchall():接收全部的返回结果行.
- rowcount: 这是一个只读属性,并返回执行execute()方法后影响的行数。
import pymysql #打开数据库链接
lcDB = pymysql.connect("127.0.0.1", "root", "", "test") #使用cursor()方法创建一个游标对象cursor
cursor = lcDB.cursor() #SQL 插入语句
#此处可将SQL换位update, delete等语句
sql = "select * from employee where income > %s"%(2000) try:
# 使用execute()方法执行sql,
cursor.execute(sql)
#获取所有记录列表
results = cursor.fetchall()
for row in results:
fname = row[0]
lname = row[1]
age = row[2]
sex = row[3]
income = row[4]
#打印结果
print("fname = %s, lname = %s, age = %s, sex = %s,income = %s" % \
(fname, lname,age, sex, income)) except:
print("ERROr: unable to fecth data") #关闭数据库
lcDB.close()
SSH链接:
-使用mysqldb模块通过ssh隧道连接mysql
import pymysql
from sshtunnel import SSHTunnelForwarder server = SSHTunnelForwarder(
("132.223.3.23", 19), #ssh IP和port
ssh_password = "",#ssh 密码
ssh_username = "root",#ssh账号
remote_bind_address = ("1.1.1.1", 3306)) #数据库所在的IP和端口 #启动服务
server.start()
#打印本地端口,已检查是否配置正确
print(server.local_bind_host) goDB = pymysql.connect(host = "127.0.0.1", #固定写法
port = server.local_bind_port,
user = "root", #数据库账号
passwd = "",#数据库密码
db = "指定数据库名字")# 可以限定,只访问特定的数据库,否则需要在mysql的查询或者操作语句中,指定好表名 cur = goDB.cursor()
sql = "select no from gds order by rand() limit 10" #限制每次随机查询10条数据 try:
#执行SQL语句检查是否连接成功
cur.execute("select version()")
result = cur.fetchone()
print("Database version: %s" % result)
cur.execute(sql)
data = cur.fetchall() for row in data:
good_no = row[0]
print(good_no) except:
print("Error") #关闭连接
goDB.close()
server.close()
Python --链接MYSQL数据库与简单操作 含SSH链接的更多相关文章
- 在php中需要用到的mysql数据库的简单操作
1.数据库连接 1.1用windows命令行链接数据库服务器 几个DOS命令 在DOS环境下命令后面没有分号,在MySQL环境下,命令后面有分号 进入盘符: 语法:盘符: 进入盘符下的某个文件夹 语法 ...
- Python 连接Mysql数据库执行语句操作
学习Mysql模块的使用,模块命名的坑,解决SHA加密错误无法连接
- Java连接MySQL数据库及简单操作代码
1.Java连接MySQL数据库 Java连接MySql需要下载JDBC驱动MySQL-connector-java-5.0.5.zip(举例,现有新版本).然后将其解压缩到任一目录.我是解压到D盘, ...
- python+mysql数据库的简单操作
最近接了一个任务,测试某项类似于收益情况报表的功能,因计算公式复杂,单纯手算过于复杂,所以想到写成脚本 根据python的分治原则,先整了几个函数用于实现计算逻辑,后发现数据输入过于繁琐,所以决定使用 ...
- mysql数据库的简单操作
首先进入mysql:mysql -u root -p 1.建库: create database 库名称; 例如:create database mydata;(创建一个名为“mydata”的库): ...
- Python学习笔记9-Python 链接MySql数据库
Python 链接MySql数据库,方法很简单: 首先需要先 安装一个MySql链接插件:MySQL-python-1.2.3.win-amd64-py2.7.exe 下载地址:http://dev. ...
- python连接mysql数据库简单例子
今天用pyhton2连接本地的mysql数据库,总的来说比较简单,但还是遇到一些小问题 代码如下: # -*- coding: utf-8 -*- import os import MySQLdb i ...
- 使用python读取mysql数据库并进行数据的操作
(一)环境的配置 使用python调用mysql数据库要引进一些库. 目前我使用的python版本是python3.6.引进库为pymysql 其他对应的库可以有以下选择: mysqldb,oursq ...
- 进击的Python【第十二章】:mysql介绍与简单操作,sqlachemy介绍与简单应用
进击的Python[第十二章]:mysql介绍与简单操作,sqlachemy介绍与简单应用 一.数据库介绍 什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的仓库,每个数 ...
随机推荐
- linux 读取文本的最后几行
tail -n 100 filename 读取file的最后100行 tail: n. 尾巴:踪迹:辫子:燕尾服 vt. 尾随:装上尾巴 vi. 跟踪:变少或缩小 adj. 从后面而来的:尾部的 ...
- 谈谈对AQS的一些理解
AQS的概念 AQS全称AbstractQueuedSynchronizer,是java并发包中的核心类,诸如ReentrantLock,CountDownLatch等工具内部都使用了AQS去维护锁的 ...
- pt-online-schema-change的用法
pt-online-schema-change的用法 环境: 10.192.30.53 主库 10.192.30.60 从库 mysql版本:8.0.17 为了方便操作,简单的写了如下的脚本. #!/ ...
- 关于AES加密CryptoJS
import * as CryptoJS from 'crypto-js'; let AuthTokenKey = "XXX"; //AES密钥let AuthTokenIv = ...
- 34 String、StringBuffer、StringBuilder
String的值是不可变的,这就导致每次对String的操作都会生成新的String对象,不仅效率低下,而且大量浪费有限的内存空间. StringBuffer是可变类,和线程安全的字符串操作类,任何对 ...
- 对js库的调研研究------引用
1. 引言 从以下几个方面来阐述这个问题: 特性. 稳定性. 性能. 包生态. 社区. 学习曲线. 文档. 工具. 发展历史. 团队. 兼容性. 趋势. 2.概述 & 精读 特性 当你调研一个 ...
- ETL工具之——kettle使用简介
ETL工具之——kettle使用简介 https://yq.aliyun.com/articles/157977?spm=5176.10695662.1996646101.searchclickres ...
- Python 爬虫十六式 - 第五式:BeautifulSoup-美味的汤
BeautifulSoup 美味的汤 学习一时爽,一直学习一直爽! Hello,大家好,我是Connor,一个从无到有的技术小白.上一次我们说到了 Xpath 的使用方法.Xpath 我觉得还是 ...
- js能否上传文件夹
文件夹上传:从前端到后端 文件上传是 Web 开发肯定会碰到的问题,而文件夹上传则更加难缠.网上关于文件夹上传的资料多集中在前端,缺少对于后端的关注,然后讲某个后端框架文件上传的文章又不会涉及文件夹. ...
- No 'Configuration' method was found in class 'WebApp.Startup
The following errors occurred while attempting to load the app.- No 'Configuration' method was found ...