Python Django 数据库操作
1. 建立app
在自己的工程项目目录下输入:
python manage.py startapp myapp(你想建立的app名称)
建立一个叫myapp的app
这样,在你的工程项目目录下会出现一个叫myapp的目录
2. 创建Model
在app目录下进入models.py
输入类似下面的代码:
|
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 |
|
上面的每个class相当于一个新的table
例外是Many to Many 关系
(注:The exception to the one-class-per-database-table rule is the case ofmany-to-many relationships. In our example models, Book has aManyToManyField called authors. This designates that a book has one ormany authors, but the Bookdatabase table doesn’t get an authorscolumn. Rather, Django creates an additional table – a many-to-many “jointable” – that handles the mapping of books to authors.)
django会自动给每个model配置一个名为id的primary key
(Finally, note we haven’t explicitly defined a primary key in any of thesemodels. Unless you instruct it otherwise, Django automatically gives everymodel an auto-incrementing integer primary key field called id. Each Djangomodel is required to have a single-column primary key.)
3. 安装model
在最初的配置文件settings.py中找到
INSTALLED_APPS
加入自己的app名称,比如'myapp'
用下面的命令验证model的有效性:
python manage.py validate
如果一切正常,你会看到 0errorsfound 消息。如果出错,请检查你输入的模型代码。 错误输出会给出非常有用的错误信息来帮助你修正你的模型。一旦你觉得你的模型可能有问题,运行 pythonmanage.pyvalidate 。 它可以帮助你捕获一些常见的模型定义错误。
4. (真正在DB创建我们设定好的table)create table:
在shell中输入
python manage.py sqlall myapp(步骤1中你创建的app名称)
然后你就可以看见各种SQL语句了,嗯,看上去不错。但是……坑爹的是“sqlall 命令并没有在数据库中真正创建数据表,只是把SQL语句段打印出来,这样你可以看到Django究竟会做些什么。”
所以说下面这个才是真正建表的语句:
python manage.py syncdb
之后你应该能看到诸如:
Creating tables ...
Creating table books_publisher
Creating table books_author
Creating table books_book_authors
Creating table books_book
Installing custom SQL ...
Installing indexes ...
Installed 0 object(s) from 0 fixture(s)
这样的信息
值得注意的是,syncdb 命令是同步你的模型到数据库的一个简单方法。 它会根据 INSTALLED_APPS 里设置的app来检查数据库, 如果表不存在,它就会创建它。 需要注意的是, syncdb 并 不能将模型的修改或删除同步到数据库;如果你修改或删除了一个模型,并想把它提交到数据库,syncdb并不会做出任何处理。
5. (插入一个新的对象) insert:
>>> from books.models import Publisher
>>> p1 = Publisher(name='Apress', address='2855 Telegraph Avenue',
... city='Berkeley', state_province='CA', country='U.S.A.',
... website='http://www.apress.com/')
>>> p1.save()
查看:
>>> publisher_list = Publisher.objects.all()
>>> publisher_list
6. 额外问题:为model加入字符串表现形式
在每个model里加入:
|
1 2 |
|
return 处写上你想要的字符串
7. (选择对象)select:
Publisher.objects.all()
——相当于 select from
Publisher.objects.filter(name='Apress')
——相当于 select from ... where name = 'Apress'
Publisher.objects.filter(name__contains="press")
——相当于 select from ... where name LIKE '%press%';
以上方法,返回的都是一个list (其实是query set)
想直接获取单个对象?用get 方法!
Publisher.objects.get(name="Apress")
8. (对结果排序) order:
Publisher.objects.order_by("name")
——相当于 select from ... ORDER BY name;
多项排序:
Publisher.objects.order_by("state_province", "address")
逆向排序:
Publisher.objects.order_by("-name")
连锁查询:
Publisher.objects.filter(country="U.S.A.").order_by("-name")
9. (更新对象)update:
1)使用save()方法:
|
1 2 3 |
|
——相当于
|
1 2 3 4 5 6 7 8 |
|
!!所有的列都被更新了!这也太naive了吧!
2)用update() 方法才比较好:
Publisher.objects.filter(id=52).update(name='Apress Publishing')
——相当于
|
1 2 3 |
|
可以对多行同时进行更新:
Publisher.objects.all().update(country='USA')
update()方法会返回一个整型数值,表示受影响的记录条数
10. (删除对象)delete:调用该对象的delete()方法即可:
p = Publisher.objects.get(name="O'Reilly")
p.delete()
一旦使用all()方法,所有数据将会被删除:
Publisher.objects.all().delete()
参考:http://www.djangobook.com/en/2.0/chapter05.html
http://djangobook.py3k.cn/2.0/chapter05/
Python Django 数据库操作的更多相关文章
- 从命令行运行django数据库操作
从命令行运行django数据库操作,报错: django.core.exceptions.ImproperlyConfigured: Requested setting DEFAULT_INDEX_T ...
- python之数据库操作(sqlite)
python之数据库操作(sqlite) 不像常见的客户端/服务器结构范例,SQLite引擎不是个程序与之通信的独立进程,而是连接到程序中成为它的一个主要部分.所以主要的通信协议是在编程语言内的直接A ...
- Django数据库操作(增删改查)
Django数据库操作(增删改查) 创建数据库中的一个表 class Business(models.Model): #自动创建ID列 caption = models.CharField(max_l ...
- python sqlite3 数据库操作
python sqlite3 数据库操作 SQLite3是python的内置模块,是一款非常小巧的嵌入式开源数据库软件. 1. 导入Python SQLite数据库模块 import sqlite3 ...
- Django 数据库操作
Django 数据库操作 Django运算表达式与Q对象/F对象 1 模型查询 概述: 1 查询集:表示从数据库中获取的对象的集合 2 查询集可以有多个过滤器,通过 逻辑运算符连接 3 过滤器就是一个 ...
- django数据库操作和中间件
数据库配置 django的数据库相关表配置在models.py文件中,数据库的连接相关信息配置在settings.py中 models.py相关相关参数配置 from django.db import ...
- python之数据库操作
数据库操作 Python 操作 Mysql 模块的安装 1 2 3 4 5 linux: yum install MySQL-python window: http://files ...
- Django数据库操作
刚学到Django的数据库操作,把它记录下来,方便以后查看: 在Django中定义数据库表,并使用Django提供的方法来对数据库进行操作(增.删.改.查) 1.定义3个数据库表: class Gro ...
- Python的数据库操作(Sqlalchemy)
ORM 全称 Object Relational Mapping, 翻译过来叫对象关系映射.简单的说,ORM 将数据库中的表与面向对象语言中的类建立了一种对应关系.这样,我们要操作数据库,数据库中的表 ...
随机推荐
- Codeforces Round #373 (Div. 2) E. Sasha and Array
题目链接 分析:矩阵快速幂+线段树 斐波那契数列的计算是矩阵快速幂的模板题,这个也没什么很多好解释的,学了矩阵快速幂应该就知道的东西= =这道题比较巧妙的在于需要用线段树来维护矩阵,达到快速查询区间斐 ...
- 关于博弈论中的一硬币正反问题的分析<二>
昨天分析了一下硬币正反的问题,其中说到一点是求美女收益期望E(女)=-8xy+3y+3x-1 最大化,当然结果我们是说的一个范围内的变化以及可以针对性的调整.这里再次说明一下,不是简单的求二元函数的最 ...
- JS学习笔记01
文章转载pigpigpig4587 的 1.Javascript是区分大小写的语言.也就是说.关键字.变量,函数和所有的标识符都必须采取一致的大小写形式.因为html不严格区分大小写,所以在html中 ...
- 基于事件的异步模式(EAP)
什么是EAP异步编程模式 EAP基于事件的异步模式是.net 2.0提出来的,实现了基于事件的异步模式的类将具有一个或者多个以Async为后缀的方法和对应的Completed事件,并且这些类都支持异步 ...
- 关于RequireJS与AngularJS的集成文档
为什么要整合RequireJS RequireJS是一个Javascript 文件和模块框架,通过模块的方式来配置js文件之间的依赖关系,遵守的是CommonJS的AMD标准. 在开发的时候则无需关注 ...
- spark示例
1)java(App.java) package com.ejiajie.bi.hello; import org.apache.spark.api.java.JavaSparkContext; im ...
- Java如何解决脆弱基类(基类被冻结)问题
概述 大多数好的设计者象躲避瘟疫一样来避免使用实现继承(extends 关系).实际上80%的代码应该完全用interfaces写,而不是通过extends.“JAVA设计模式”一书详细阐述了怎样用 ...
- ssh 注解写法
弄了半天 (好久哦) 首先 applicationContext-db.xml <?xml version="1.0" encoding="UTF-8" ...
- ES6模块加载
两种加载方式 加载方式 规范 命令 特点 运行时加载 CommonJS/AMD require 社区方案,提供了服务器/浏览器的模块加载方案 非语言层面的标准 只能在运行时确定模块的依赖关系及输入/输 ...
- 场景7 Data Guard
场景7 Data Guard 官方文档 :Oracle Data Guard Concepts and Administration 用于数据容灾,通过主备库同步(主库将redo日志传送到备库,一个 ...