[举重若轻]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()
- [举重若轻]python+django+mysql web开发入门学习之orm
- [举重若轻]python+django+mysql web开发入门学习之环境搭建
- [举重若轻]python+django+mysql web开发入门学习之hello world
- [举重若轻]python+django+mysql web开发入门学习之动态模板
- Python Web开发:Django入门学习笔记(1)
- Python Web开发:Django入门学习笔记(2)
- python web开发--Django 学习
- python web开发之django
- python-orm django学习-脑图
- python之web开发1:Eclipse+PyDev+Django+Mysql搭建Python web开发环境
- 【python】Django web应用开发入门
- python web开发——Django入门
- Python Web开发 之Django框架入门学习笔记(一)——安装和初步使用
- Python学习二:Django Web入门
- Python Web开发之Django环境搭建
- python web开发框架 - 之 Django Request
- Python Web开发Django、Flask之Templates
- python django web开发之准备
- javascript根据鼠标和键盘复制页面内容验证是否登录
- 新建ArcGIS Project for Android项目失败解决方案
- 静态成员变量和静态成员函数(static)
- Perl调试
- How to do Photoshop-like effects in SVG
- [举重若轻]python+django+mysql web开发入门学习之orm
- Apache无法启动报 the requested operationhas failed 错误
- java中unicode和中文相互转换
- 开门人和关门人 hdu1234 水题
- MySQL外键:数据库新手入门之MySQL中如何定义外键
- CCLableTTF 文字描边
- 关于商业的视频聊天开发SDK包
- Android Broadcast机制深入解析
- 往数据库里面写blob字段数据