当前位置: 首页 > news >正文

网站建设中长出现的问题普洱市住房和城乡建设局网站

网站建设中长出现的问题,普洱市住房和城乡建设局网站,推广网站最有效方法,建设网站西安在Windows平台上安装mysql模块用于Python开发 用python连接mysql的时候#xff0c;需要用的安装版本#xff0c;源码版本容易有错误提示。下边是打包了32与64版本。 MySQL-python-1.2.3.win32-py2.7.exe MySQL-python-1.2.3.win-amd64-py2.7.exe 实例 1、取得 MYSQL 的版本 #…在Windows平台上安装mysql模块用于Python开发 用python连接mysql的时候需要用的安装版本源码版本容易有错误提示。下边是打包了32与64版本。 MySQL-python-1.2.3.win32-py2.7.exe MySQL-python-1.2.3.win-amd64-py2.7.exe 实例 1、取得 MYSQL 的版本 # -*- coding: UTF-8 -*- #安装 MYSQL DB for python import MySQLdb as mdb con None try: #连接 mysql 的方法 connect(ip,user,password,dbname) con mdb.connect(localhost, root,root, test); #所有的查询都在连接 con 的一个模块 cursor 上面运行的 cur con.cursor() #执行一个查询 cur.execute(SELECT VERSION()) #取得上个查询的结果是单个结果 data cur.fetchone() print Database version : %s % data finally: if con: #无论如何连接记得关闭 con.close() 实例 2、创建一个表并且插入数据 import MySQLdb as mdb import sys #将 con 设定为全局连接 con mdb.connect(localhost, root, root, test); with con: #获取连接的 cursor只有获取了 cursor我们才能进行各种操作 cur con.cursor() #创建一个数据表 writers(id,name) cur.execute(CREATE TABLE IF NOT EXISTS \ Writers(Id INT PRIMARY KEY AUTO_INCREMENT, Name VARCHAR(25))) #以下插入了 5 条数据 cur.execute(INSERT INTO Writers(Name) VALUES(Jack London)) cur.execute(INSERT INTO Writers(Name) VALUES(Honore de Balzac)) cur.execute(INSERT INTO Writers(Name) VALUES(Lion Feuchtwanger)) cur.execute(INSERT INTO Writers(Name) VALUES(Emile Zola)) cur.execute(INSERT INTO Writers(Name) VALUES(Truman Capote)) 实例 3、 python 使用 slect 获取 mysql 的数据并遍历 import MySQLdb as mdb import sys #连接 mysql获取连接的对象 con mdb.connect(localhost, root, root, test); with con: #仍然是第一步要获取连接的 cursor 对象用于执行查询 cur con.cursor() #类似于其他语言的 query 函数 execute 是 python 中的执行查询函数 cur.execute(SELECT * FROM Writers) #使用 fetchall 函数将结果集多维元组存入 rows 里面 rows cur.fetchall() #依次遍历结果集发现每个元素就是表中的一条记录用一个元组来显示 for row in rows: print row 运行结果 (1L, ‘Jack London) (2L, ‘Honore de Balzac) (3L, ‘Lion Feuchtwanger) (4L, ‘Emile Zola) (5L, ‘Truman Capote) 上面的代码用来将所有的结果取出不过打印的时候是每行一个元祖打印现在我们使用方法取出其中的单个数据 import MySQLdb as mdb import sys #获取 mysql 的链接对象 con mdb.connect(localhost, root, root, test); with con: #获取执行查询的对象 cur con.cursor() #执行那个查询这里用的是 select 语句 cur.execute(SELECT * FROM Writers) #使用 cur.rowcount 获取结果集的条数 numrows int(cur.rowcount) #循环 numrows 次每次取出一行数据 for i in range(numrows): #每次取出一行放到 row 中这是一个元组(id,name) row cur.fetchone() #直接输出两个元素 print row[0], row[1] 运行结果 1 Jack London 2 Honore de Balzac 3 Lion Feuchtwanger 4 Emile Zola 5 Truman Capote 实例 4、使用字典 cursor 取得结果集可以使用表字段名字访问值 import MySQLdb as mdb import sys #获得 mysql 查询的链接对象 con mdb.connect(localhost, root, root, test) with con: #获取连接上的字典 cursor注意获取的方法 #每一个 cursor 其实都是 cursor 的子类 cur con.cursor(mdb.cursors.DictCursor) #执行语句不变 cur.execute(SELECT * FROM Writers) #获取数据方法不变 rows cur.fetchall() #遍历数据也不变比上一个更直接一点 for row in rows: #这里可以使用键值对的方法由键名字来获取数据 print %s %s % (row[Id], row[Name]) 实例 5、获取单个表的字段名和信息的方法 import MySQLdb as mdb import sys #获取数据库的链接对象 con mdb.connect(localhost, root, root, test) with con: #获取普通的查询 cursor cur con.cursor() cur.execute(SELECT * FROM Writers) rows cur.fetchall() #获取连接对象的描述信息 desc cur.description print cur.description:,desc #打印表头就是字段名字 print %s %3s % (desc[0][0], desc[1][0]) for row in rows: #打印结果 print %2s %3s % row 运行结果 cur.description: ((‘Id, 3, 1, 11, 11, 0, 0), (‘Name, 253, 17, 25, 25, 0, 1)) Id Name 1 Jack London 2 Honore de Balzac 3 Lion Feuchtwanger 4 Emile Zola 5 Truman Capote 实例 6、使用 Prepared statements 执行查询更安全方便 import MySQLdb as mdb import sys con mdb.connect(localhost, root, root, test) with con: cur con.cursor() #我们看到这里可以通过写一个可以组装的 sql 语句来进行 cur.execute(UPDATE Writers SET Name %s WHERE Id %s, (Guy de Maupasant, 4)) #使用 cur.rowcount 获取影响了多少行 print Number of rows updated: %d % cur.rowcount 结果 Number of rows updated: 1 实例 7、把图片用二进制存入 MYSQL 有人喜欢把图片存入 MYSQL这种做法貌似很少吧我看大部分的程序图片都是存放在服务器上的文件数据库中存的只是图片的地址而已不过 MYSQL 是支持把图片存入数据库的也相应的有一个专门的字段 BLOB (Binary Large Object)即较大的二进制对象字段请看如下程序注意测试图片自己随便找一个地址要正确 首先在数据库中创建一个表用于存放图片 CREATE TABLE Images(Id INT PRIMARY KEY AUTO_INCREMENT, Data MEDIUMBLOB); 然后运行如下 PYTHON 代码进行 import MySQLdb as mdb import sys try: #用读文件模式打开图片 fin open(../web.jpg) #将文本读入 img 对象中 img fin.read() #关闭文件 fin.close() except IOError, e: #如果出错打印错误信息 print Error %d: %s % (e.args[0],e.args[1]) sys.exit(1) try: #链接 mysql获取对象 conn mdb.connect(hostlocalhost,userroot,passwdroot, dbtest) #获取执行 cursor cursor conn.cursor() #直接将数据作为字符串插入数据库 cursor.execute(INSERT INTO Images SET Data%s % mdb.escape_string(img)) #提交数据 conn.commit() #提交之后再关闭 cursor 和链接 cursor.close() conn.close() except mdb.Error, e: #若出现异常打印信息 print Error %d: %s % (e.args[0],e.args[1]) sys.exit(1)实例 8、从数据库中把图片读出来 import MySQLdb as mdb import sys try: #连接 mysql获取连接的对象 conn mdb.connect(localhost, root, root, test); cursor conn.cursor() #执行查询该图片字段的 SQL cursor.execute(SELECT Data FROM Images LIMIT 1) #使用二进制写文件的方法打开一个图片文件若不存在则自动创建 fout open(image.png,wb) #直接将数据如文件 fout.write(cursor.fetchone()[0]) #关闭写入的文件 fout.close() #释放查询数据的资源 cursor.close() conn.close() except IOError, e: #捕获 IO 的异常 主要是文件写入会发生错误 print Error %d: %s % (e.args[0],e.args[1]) sys.exit(1) 实例 9、使用 Transaction 即事务手动提交自动回滚 import MySQLdb as mdb import sys try: #连接 mysql获取连接的对象 conn mdb.connect(localhost, root, root, test); cursor conn.cursor() #如果某个数据库支持事务会自动开启 #这里用的是 MYSQL所以会自动开启事务若是 MYISM 引擎则不会 cursor.execute(UPDATE Writers SET Name %s WHERE Id %s, (Leo Tolstoy, 1)) cursor.execute(UPDATE Writers SET Name %s WHERE Id %s, (Boris Pasternak, 2)) cursor.execute(UPDATE Writer SET Name %s WHERE Id %s, (Leonid Leonov, 3)) #事务的特性 1、原子性的手动提交 conn.commit() cursor.close() conn.close() except mdb.Error, e: #如果出现了错误那么可以回滚就是上面的三条语句要么执行要么都不执行 conn.rollback() print Error %d: %s % (e.args[0],e.args[1]) 结果 1、因为不存在 writer 表 SQL 第三条语句所以出现错误Error 1146: Table ‘test.writer doesnt exist 2、出现错误出发异常处理 3 条语句的前两条会自动变成了没有执行结果不变 3、如果本代码放到一个 MyISAM 引擎表前两句会执行第三句不会如果是 INNDB 引擎则都不会执行。 更多关于python安装教程的文章请参考《python各版本安装教程》 以上就是为大家分享的9个实用的Python操作MySQL数据库实例希望对大家的学习有所帮助。
http://www.huolong8.cn/news/115075/

相关文章:

  • 芜湖网站建设兼职电商行业网站建设及维护
  • 个人网站有什么缺点自贸区注册公司有什么优势
  • 简述dw网站开发流程佛山网站建设 合优
  • 网站开发需求文档模板带er图万能短视频素材库
  • 淘宝有WordPress网站搭建吗微信服务市场
  • 遵义建立公司网站的步骤郑州百度网站优化
  • 青岛做网站eoe石家庄最新今天的消息
  • 专业网站建设费用包括哪些7k7k网页游戏官网
  • 电子商务网站建设的目的和作用如何做品牌网站设计
  • 网站建设的基本要素有建设网站应该加什么服务器
  • 展示性公司网站html内蒙古seo
  • 网站上搜索的动图怎么做壁纸工厂办公室简单装修
  • 网站着陆页 推荐建站快车是什么
  • 宁国市网站建设网络营销的特点包括哪些
  • 萍乡网站开发给自己的网站做关键词流程
  • 视频网站开发的难点网站建设公司 选中企动力公司
  • 网站开发到上线 多久河南科兴建设有限公司网站
  • 安徽建网站实时热榜
  • 怎么建设域名和网站彩票网站招代理广告怎么做
  • 免费海报在线制作网站麻章网站建设公司
  • 网站h标签网站系统方案设计
  • 模板建站优缺点windows2012做网站
  • 仙游县住房和城乡建设局网站市场营销考研可以考哪些专业
  • 手机网站开发步骤软件wordpress新网站
  • 个人网站免费模板网站做多个镜像
  • 商家在携程旅游网站怎样做宣传网站建设方案范文1000字
  • 电子商务网站开发合同qq代刷网站社区建设
  • 昆山建设局图审中心网站溧阳做网站哪家好
  • 杭州有没有专业做网站的公司wordpress怎么上传插件
  • 网站工商备案查询网页制作教程和流程