[举重若轻]python+django+mysql web开发入门学习之orm

来源:互联网 发布:如何查看java字节码 编辑:程序博客网 时间:2024/04/30 00:59

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 modelsclass 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.nameu'name2'

删除:

>>> p = User.objects.get(id=1)>>> p.delete()


原创粉丝点击