码迷,mamicode.com
首页 > 数据库 > 详细

python环境下使用sqlalchemy和mysql搭建数据库环境及编码

时间:2014-12-30 11:51:10      阅读:258      评论:0      收藏:0      [点我收藏+]

标签:python   sqlalchemy编码   utf8   

为了兼容中文和其他国家的文字,我们将编码格式都设置为utf8

mysql设置utf8可以直接修改配置文件,或则通过命令行下的环境变量来进行设置

sqlalchemy设置编码字符集一定要在数据库访问的URL上增加charset=utf8,否则数据库的连接就不是utf8的编码格式

eng = create_engine(‘mysql://root:root@localhost:3306/test2?charset=utf8‘,echo=True)

注意URL的后面部分

charset=utf8

这个很关键,除了上述两处需要设置和修改的地方,另外python文件需要将编码格式设置为utf8(不带BOM)的,这样忘数据库

直接存储数据,就可以直接用‘中文‘ ,或则u‘中文‘来正确存储到mysql数据库中。

mysql数据库在dos命令窗口中不能正确显示中文,如果要查看utf8编码格式的中文,最好是下载一个mysql的可视化工具。

目前我感觉不错的mysql可视化工具是SQLyog。

下面是我写的使用sqlalchemy写入数据库的demo代码,可以参考参考。

#coding=utf-8

from sqlalchemy import Column, String, create_engine
from sqlalchemy.orm import sessionmaker
from sqlalchemy.ext.declarative import declarative_base

Base = declarative_base()

class User(Base):
	__tablename__ = 'user2'
	
	id = Column(String(20),primary_key=True)
	name = Column(String(20))
	
	
class School(Base):
	__tablename__ = 'school'
	id = Column(String(20), primary_key=True)
	name = Column(String(20))
	

#创建从Base派生的所有表
def createAll(eng):
	Base.metadata.create_all(eng)
	
#删除DB中所有的表	
def dropAll(eng):
	Base.metadata.drop_all(eng)

#删除数据库中从Base派生的所有表
	
#创建session对象
if __name__ == '__main__':
	#创建数据库引擎
	eng = create_engine('mysql://root:root@localhost:3306/test2?charset=utf8',echo=True)
	
	#设置回显
	#eng.echo = True
	
	#创建DBSession类型
	DBSession = sessionmaker(bind=eng)
	
	#创建session对象
	session = DBSession()
		
try:
	#创建表
	createAll(eng)

	#创建新User对象
	new_user = User(id='13', name='我еёжжщщщьфффтххмлл')
	
	print(u'你好吗')
	
	#添加到session
	session.add(new_user)
	
	#提交保存到数据库
	session.commit()
	
except BaseException,e:
	print('e.message=%s' % str(e.message))
	
finally:
	session.close()
	#eng.close()
	
	
	
	
	






	


python环境下使用sqlalchemy和mysql搭建数据库环境及编码

标签:python   sqlalchemy编码   utf8   

原文地址:http://blog.csdn.net/davidsu33/article/details/42262353

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!