mysql数据库with ur_Python使用MySQL数据库(新)

一,安装mysql

如果是windows用户,mysql的安装非常简单,直接下载安装文件,双击安装文件一步一步进行操作即可。

Linux 下的安装可能会更加简单,除了下载安装包进行安装外,一般的linux仓库中都会有mysql,我们只需要通过一个命令就可以下载安装:

Ubuntu\deepin

>>sudo apt-get install mysql-server

>>Sudo apt-get install  mysql-client

centOS/redhat

>>yum install mysql

二,安装MySQL-python

要想使python可以操作mysql就需要MySQL-python驱动,它是python操作mysql必不可少的模块。

下载MySQL-python-1.2.5.zip 文件之后直接解压。进入MySQL-python-1.2.5目录:

>>python setup.py install

三,测试

测试非常简单,检查MySQLdb模块是否可以正常导入。

fnngj@fnngj-H24X:~/pyse$ python

Python 2.7.4 (default, Sep 26 2013, 03:20:56)

[GCC 4.7.3] on linux2

Type "help", "copyright", "credits" or "license" for more information.

>>> import MySQLdb

没有报错提示MySQLdb模块找不到,说明安装OK,下面开始使用python操作数据库之前,我们有必要来回顾一下mysql的基本操作:

四,mysql的基本操作

$ mysql -u root -p  (有密码时)

$ mysql -u root     (无密码时)

copycode.gifmysql> show databases;  // 查看当前所有的数据库

+--------------------+

| Database           |

+--------------------+

| information_schema |

| csvt               |

| csvt04             |

| mysql              |

| performance_schema |

| test               |

+--------------------+

6 rows in set (0.18 sec)

mysql> use test;   //作用与test数据库

Database changed

mysql> show tables;   //查看test库下面的表

Empty set (0.00 sec)

//创建user表,name 和password 两个字段

mysql> CREATE  TABLE  user (name VARCHAR(20),password VARCHAR(20));  Query OK, 0 rows affected (0.27 sec)

//向user表内插入若干条数据

mysql> insert into user values('Tom','1321');Query OK, 1 row affected (0.05 sec)

mysql> insert into user values('Alen','7875');Query OK, 1 row affected (0.08 sec)

mysql> insert into user values('Jack','7455');Query OK, 1 row affected (0.04 sec)

//查看user表的数据

mysql> select * from user;+------+----------+

| name | password |

+------+----------+

| Tom  | 1321     |

| Alen | 7875     |

| Jack | 7455     |

+------+----------+

3 rows in set (0.01 sec)

//删除name 等于Jack的数据

mysql> delete from user where name = 'Jack';Query OK, 1 rows affected (0.06 sec)

//修改name等于Alen 的password 为 1111

mysql> update user set password='1111' where name = 'Alen';Query OK, 1 row affected (0.05 sec)

Rows matched: 1  Changed: 1  Warnings: 0

//查看表内容

mysql> select * from user;+--------+----------+

| name   | password |

+--------+----------+

| Tom    | 1321     |

| Alen   | 1111     |

+--------+----------+

3 rows in set (0.00 sec)

copycode.gif

五,python操作mysql数据库基础

copycode.gif#coding=utf-8import MySQLdb

conn= MySQLdb.connect(

host='localhost',

port = 3306,

user='root',

passwd='123456',

db ='test',

)

cur = conn.cursor()#创建数据表#cur.execute("create table student(id int ,name varchar(20),class varchar(30),age varchar(10))")#插入一条数据#cur.execute("insert into student values('2','Tom','3 year 2 class','9')")#修改查询条件的数据#cur.execute("update student set class='3 year 1 class' where name = 'Tom'")#删除查询条件的数据#cur.execute("delete from student where age='9'")cur.close()

conn.commit()

conn.close()

copycode.gif

>>> conn = MySQLdb.connect(host='localhost',port = 3306,user='root', passwd='123456',db ='test',)

Connect() 方法用于创建数据库的连接,里面可以指定参数:用户名,密码,主机等信息。

这只是连接到了数据库,要想操作数据库需要创建游标。

>>> cur = conn.cursor()

通过获取到的数据库连接conn下的cursor()方法来创建游标。

>>> cur.execute("create table student(id int ,name varchar(20),class varchar(30),age varchar(10))")

通过游标cur操作execute()方法可以写入纯sql语句。通过execute()方法中写如sql语句来对数据进行操作。

>>>cur.close()

cur.close() 关闭游标

>>>conn.commit()

conn.commit()方法在提交事物,在向数据库插入一条数据时必须要有这个方法,否则数据不会被真正的插入。

>>>conn.close()

Conn.close()关闭数据库连接

六,插入数据

通过上面execute()方法中写入纯的sql语句来插入数据并不方便。如:

>>>cur.execute("insert into student values('2','Tom','3 year 2 class','9')")

我要想插入新的数据,必须要对这条语句中的值做修改。我们可以做如下修改:

copycode.gif#coding=utf-8import MySQLdb

conn= MySQLdb.connect(

host='localhost',

port = 3306,

user='root',

passwd='123456',

db ='test',

)

cur = conn.cursor()#插入一条数据sqli="insert into student values(%s,%s,%s,%s)"cur.execute(sqli,('3','Huhu','2 year 1 class','7'))

cur.close()

conn.commit()

conn.close()

copycode.gif

假如要一次向数据表中插入多条值呢?

copycode.gif#coding=utf-8import MySQLdb

conn= MySQLdb.connect(

host='localhost',

port = 3306,

user='root',

passwd='123456',

db ='test',

)

cur = conn.cursor()#一次插入多条记录sqli="insert into student values(%s,%s,%s,%s)"cur.executemany(sqli,[

('3','Tom','1 year 1 class','6'),

('3','Jack','2 year 1 class','7'),

('3','Yaheng','2 year 2 class','7'),

])

cur.close()

conn.commit()

conn.close()

copycode.gif

executemany()方法可以一次插入多条值,执行单挑sql语句,但是重复执行参数列表里的参数,返回值为受影响的行数。

七,查询数据

也许你已经尝试了在python中通过

>>>cur.execute("select * from student")

来查询数据表中的数据,但它并没有把表中的数据打印出来,有些失望。

来看看这条语句获得的是什么

>>>aa=cur.execute("select * from student")

>>>print aa

5

它获得的只是我们的表中有多少条数据。那怎样才能获得表中的数据呢?进入python shell

copycode.gif>>> import MySQLdb>>> conn = MySQLdb.connect(host='localhost',port = 3306,user='root',    passwd='123456',db ='test',)>>> cur = conn.cursor()>>> cur.execute("select * from student")5L

>>> cur.fetchone()

(1L, 'Alen', '1 year 2 class', '6')>>> cur.fetchone()

(3L, 'Huhu', '2 year 1 class', '7')>>> cur.fetchone()

(3L, 'Tom', '1 year 1 class', '6')

...>>>cur.scroll(0,'absolute')

copycode.gif

fetchone()方法可以帮助我们获得表中的数据,可是每次执行cur.fetchone() 获得的数据都不一样,换句话说我没执行一次,游标会从表中的第一条数据移动到下一条数据的位置,所以,我再次执行的时候得到的是第二条数据。

scroll(0,'absolute') 方法可以将游标定位到表中的第一条数据。

还是没解决我们想要的结果,如何获得表中的多条数据并打印出来呢?

copycode.gif#coding=utf-8import MySQLdb

conn= MySQLdb.connect(

host='localhost',

port = 3306,

user='root',

passwd='123456',

db ='test',

)

cur = conn.cursor()#获得表中有多少条数据aa=cur.execute("select * from student")print aa#打印表中的多少数据info = cur.fetchmany(aa)for ii in info:    print ii

cur.close()

conn.commit()

conn.close()

copycode.gif

通过之前的print aa我们知道当前的表中有5条数据,fetchmany()方法可以获得多条数据,但需要指定数据的条数,通过一个for循环就可以把多条数据打印出啦!执行结果如下:

copycode.gif5(1L, 'Alen', '1 year 2 class', '6')

(3L, 'Huhu', '2 year 1 class', '7')

(3L, 'Tom', '1 year 1 class', '6')

(3L, 'Jack', '2 year 1 class', '7')

(3L, 'Yaheng', '2 year 2 class', '7')

[Finished in 0.1s]

copycode.gif

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/416463.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

洛谷——P1067 多项式输出

https://www.luogu.org/problem/show?pid1067#sub 题目描述 一元 n 次多项式可用如下的表达式表示: 其中,aixi称为 i 次项,ai 称为 i 次项的系数。给出一个一元多项式各项的次数和系数,请按照如下规定的格式要求输出该多项式&…

前端学习(2466):在前端页面中引入百度地图

1.配置你需要的地图效果百度地图生成器 可选配置:位置、宽高、缩放、标注样式 2.导出导入地图代码点击获取代码,将代码引入到你的html、js、vue等文件中 ps:标注不显示的解决方法:将图标链接换成: var icon new BMap.Icon("…

$动态规划系列(2)——找零钱问题

refer:http://interactivepython.org/courselib/static/pythonds/index.html 1. 问题描述 Tom在自动售货机上买了一瓶饮料,售价37美分,他投入了1美元(1美元 100美分),现在自动售货机需要找钱给他。售货机中现在只有四…

前端学习(2467):在前端页面中引入百度地图

走在前端的大道上 插槽,也就是slot,是组件的一块HTML模板,这块模板显示不显示、以及怎样显示由父组件来决定。 实际上,一个slot最核心的两个问题在这里就点出来了,是显示不显示和怎样显示。 由于插槽是一块模板&…

pm961 mysql_Oracle GoldenGate学习之--异构平台同步(Mysql到Oracle)

Oracle GoldenGate学习之--异构平台同步(Mysql到Oracle)如图所示:源端采用Mysql库,目标端采用Oracle库一、OGG安装配置(源端)1、OGG下载https://edelivery.oracle.com/EPD/Download/get_form?egroup_aru_number14841438https://edelivery.oracle.com/EP…

错误记录

1.Soap 1.1 endpoint already registered on address /cxfService答案&#xff1a;web.xml中多配置了 <init-param> <param-name>config-location</param-name> <param-value>classpath:cxf.xml</param-value> </init-param> 2.The serve…

sqlalchemy mysql配置中怎么设置utf8_在SqlAlchemy中,我想要一个列是UTF8?

我注意到我的MySQL数据库在默认情况下没有设置为UTF-8。改为选择latin1_swedish_ci排序规则。在所以我很自然地遇到了一个用户报告的错误&#xff0c;我的应用程序不支持特殊字符。我去确保我的应用程序正确地处理了UTF-8&#xff0c;编写了一个测试&#xff0c;很肯定它可以很…

ado.net mysql 连接池_ADO.NET数据库连接池的介绍 | 学步园

摘录自MSDN&#xff1a;建立池连接可以显著提高应用程序的性能和可缩放性。SQL Server .NET Framework 数据提供程序自动为 ADO.NET客户端应用程序提供连接池。您也可以提供几个连接字符串修饰符来控制连接池行为&#xff0c;请参见本主题内下文中“使用连接字符串关键字控制连…

转:在csv中维护变量参数

问题&#xff1a; 1、我的变量表多&#xff0c;通过之前的csv获取的方式&#xff0c;或者用户变量来维护&#xff0c;比较麻烦 2、我想在脚本之外维护我的变量数据&#xff0c;脱离脚本 解决方案&#xff1a; 1、csv的配置如图&#xff0c;队列是变量名称&#xff0c;第二列是变…

前端学习(2471):vue-echarts和echarts的区别:

vue-echarts和echarts的区别&#xff1a; vue-echarts是封装后的vue插件&#xff0c; 基于 ECharts v4.0.1 开发&#xff0c;依赖 Vue.js v2.2.6&#xff0c;功能一样的只是把它封装成vue插件 这样更方便以vue的方式去使用它。echarts就是普通的js库&#xff0c; vue-echarts特…

python 零代码快速开发平台_现在低代码开发平台和零代码平台区别是什么?

低代码与零代码&#xff0c;可参考一下开发平台在国内已经发展了很久了&#xff0c;从有代码到低代码&#xff0c;甚至有些厂家声称可以无代码&#xff0c;当然无代码只是一个噱头。低代码开发可以解决传统的开发方式的复杂方式&#xff0c;提高开发效率&#xff0c;节省时间成…

JSON.parse()、eval()和JSON.stringify()

1.什么是JSON&#xff1f; JSON全称是JavaScript Object Notation,是一种轻量级的数据交换格式。JSON 与XML具有相同的特性&#xff0c;是一种数据存储格式&#xff0c;但是JSON相比XML 更易于人编写和阅读&#xff0c;更易于生成和解析。 2.json对象和json字符串 json对象可以…

rust edition python3_PyO3首页、文档和下载 - Python 解释器的 Rust 绑定

PyO3 是 Python 的 Rust 绑定&#xff0c;可以用 Rust 语言对 Python 加速。这包括用 Rust 语言运行 Python 代码并与之交互&#xff0c;以及直接编写原生 Python 模块。PyO3 一开始只是作为 rust-cpython 的分支出现, 后来由于 rust-cpython 缺乏维护, PyO3 开始在 Rust 社区流…

solr 配置中文分词器

ik转载于:https://www.cnblogs.com/javabigdata/p/7127639.html

前端学习(2474):页面布局

request.js <template> <div class"artical-container"><!--卡片--><el-card class"filter-card"><div slot"header" class"clearfix"><!--面包屑导航--><el-breadcrumb separator-class&quo…