python 简单数据库设计实例_Django连接MySQL数据库的简单例子

前面一小节我们介绍了用 Django 建造网站的基本途径: 建立视图和 URLConf。视图负责处理一些主观逻辑,然后返回响应结果。

但是这样的功能是远远不够的。大部分 Web 应用需要主观逻辑经常牵涉到与数据库的交互。数据库驱动网站在后台连接数据库服务器,从中取出一些数据,然后在 Web 页面用漂亮的格式展示这些数据。这个网站也可能会向访问者提供修改数据库数据的方法。

由于先天具备 Python 简单而强大的数据库查询执行方法,Django 非常适合开发数据库驱动网站。

在视图中进行数据库查询的笨方法

先上一个例子:

前面我们在视图中输出 HTML 的笨方法(通过在视图里对文本直接硬编码HTML),在视图中也有笨方法可以从数据库中获取数据。很简单: 用现有的任何 Python 类库执行一条 SQL 查询并对结果进行一些处理。

在本例的视图中,我们使用了 MySQLdb 类库来连接 MySQL 数据库,取回一些记录,将它们提供给模板以显示一个网页:

from django.shortcuts import render_to_response

import MySQLdb

def book_list(request):

db = MySQLdb.connect(user='root', db='nowamagic', passwd='', host='localhost')

cursor = db.cursor()

cursor.execute('SELECT title FROM chika ORDER BY id')

names = [row[0] for row in cursor.fetchall()]

db.close()

return render_to_response('list.html', {'names': names})

然后修改下 urls.py:

#from django.conf.urls import patterns, include, url

from django.conf.urls.defaults import *

from django.views.static import *

from django.conf import settings

from PythonProject.views import book_list

# Uncomment the next two lines to enable the admin:

from django.contrib import admin

admin.autodiscover()

urlpatterns = patterns('',

# Examples:

#url(r'^$', 'PythonProject.views.home', name='home'),

#url(r'^PythonProject/', include('PythonProject.foo.urls')),

# Uncomment the admin/doc line below to enable admin documentation:

url(r'^admin/doc/', include('django.contrib.admindocs.urls')),

# Uncomment the next line to enable the admin:

url(r'^admin/', include(admin.site.urls)),

('^book_list/$', book_list),

)

再简单设计一下模板文件 list.html:

简明现代魔法
{{names}}

现在我们访问 http://127.0.0.1:8000/book_list/,程序输出:

['chika']

如果你要测试,可以自己先建立一个测试用的数据表。

点评

这个方法虽然可用,但很快一些问题将出现在你面前:

我们将数据库连接参数硬行编码于代码之中。 理想情况下,这些参数应当保存在 Django 配置中。

我们不得不重复同样的代码: 创建数据库连接、创建数据库游标、执行某个语句、然后关闭数据库。 理想情况下,我们所需要应该只是指定所需的结果。

它把我们栓死在 MySQL 之上。 如果过段时间,我们要从 MySQL 换到 PostgreSQL,就不得不使用不同的数据库适配器(例如 psycopg 而不是 MySQLdb ),改变连接参数,根据 SQL 语句的类型可能还要修改SQL 。 理想情况下,应对所使用的数据库服务器进行抽象,这样一来只在一处修改即可变换数据库服务器。 (如果你正在建立一个开源的Django应用程序来尽可能让更多人使用的话,这个特性是非常适当的。)

这些都是存在的问题,后面我们会介绍如何解决这些问题。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值