django中有一套类似于hibernate的orm框架,方便来处理与数据库相关的事务。要使用这个orm框架,首先需要设置好mysql的连接参数,在settings.py中有一个DATABASES的配置项,详情如下:
DATABASES = {
'default': {
'ENGINE': 'django.db.backends.mysql', # Add 'postgresql_psycopg2', 'mysql', 'sqlite3' or 'oracle'.
'NAME': 'mysite', # Or path to database file if using sqlite3.
'USER': 'user', # Not used with sqlite3.
'PASSWORD': 'password', # Not used with sqlite3.
'HOST': '', # Set to empty string for localhost. Not used with sqlite3.
'PORT': '', # Set to empty string for default. Not used with sqlite3.
}
}
其中NAME后面填写的是数据库名称,在django中的一个表可以关联对应的一个model来管理,我们可以新建一个models.py,将所有的与数据库相关的model放到里面,假设我们要建一个user表,其中有name和password两个属性,则可以在models.py中加入如下代码:
from django.db import models
class User(models.Model):
name=models.CharField(max_length=255)
password=models.CharField(max_length=32)
然后将该models.py加入到settings.py中的数据库管理的配置项INSTALLED_APPS中:
INSTALLED_APPS = (
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.staticfiles',
'mysite',
# Uncomment the next line to enable the admin:
# 'django.contrib.admin',
# Uncomment the next line to enable admin documentation:
# 'django.contrib.admindocs',
)
由于models.py就在mysite的根目录下,因此只要这里配置一个mysite就行了,其他的app是django自带的。然后执行syncdb命令:
python manage.py syncdb
生成的mysite_user的表结构如下:
+----------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+----------+--------------+------+-----+---------+----------------+
| id | int(11) | NO | PRI | NULL | auto_increment |
| name | varchar(255) | NO | | NULL | |
| password | varchar(32) | NO | | NULL | |
+----------+--------------+------+-----+---------+----------------+
虽然在model中没有加入id,但是主键会自动添加。然后就可以通过对model的操作来进行数据的增改删查了,可以通过python manage.py shell来进行调试。
新增:
>>> from mysite.models import User
>>> u = User(name='hello',password='world')
>>> u.save()
修改:
>>> p = User.objects.filter(id=1)
>>> p.update(name='name2')
1L
查询:
>>> p = User.objects.get(id=1)
>>> p.name
u'name2'
删除:
>>> p = User.objects.get(id=1)
>>> p.delete()