Django学习笔记3

上一个笔记写了怎么样把管理员模块给添加到网站管理里面,现在来说一下怎么样去建立一个自己的模块

在pydev中,选中项目。右键->Django->custom common, 在这里可以输入命令 等同于执行manager.py ...

输入startapp orders. 这样pydev就会自动在项目的源文件下面建一个包orders.下面会自动生成models.py,test.py,views.py

models.py 是和数据库映射的类,Django 的映射关系类似hibernate

test.py 单元测试用

views.py 接受视图请求和跳转 类似mvc模式中的c  注意 不是v.

在orders下面的models下面,添加2个类

from django.db import models

# Create your models here.

class Order(models.Model):
    order_creater = models.CharField(max_length=20)
    order_date = models.DateTimeField('order date')
    
class OrderDetail(models.Model):
    order = models.ForeignKey(Order)
    detail_lineNO = models.IntegerField()
    order_SKU = models.CharField(max_length=50)
 

这2个类都会被映射到数据库。要查看sql语句。manager,py sql orders.

可以看到这样的脚本

BEGIN;
CREATE TABLE "orders_order" (
    "id" integer NOT NULL PRIMARY KEY,
    "order_creater" varchar(20) NOT NULL,
    "order_date" datetime NOT NULL
)
;
CREATE TABLE "orders_orderdetail" (
    "id" integer NOT NULL PRIMARY KEY,
    "order_id" integer NOT NULL REFERENCES "orders_order" ("id"),
    "detail_lineNO" integer NOT NULL,
    "order_SKU" varchar(50) NOT NULL
)
;
COMMIT;

 然后执行

python manage.py syncdb

 这样就能建好表了。

然后我们现在可以测试我们的类。选择项目。右键。Django->shell with django environment. 就会出现命令行式的python窗口。会载入settings,py的设置

我们建一个类

>>>import datetime
>>>from DjangoTest.orders.models import Order
>>>o = Order(order_creater='ezio',order_date=datetime.datetime.now())
>>>o
<Order: Order object>

 可以看到默认的输出看不出来的。这个时候在类中加__unicode__的方法,类似java的tostring

def __unicode__(self):
        return '%s created at %s' % (self.order_creater,self.order_date)

 这样就可以看到比较清晰的输出

>>>>>>order.is_order_today()
true
  <Order: ruan created at 2011-03-10 16:28:26.059955>

但是我发现有个时间不对头,应该是时区设置的问题。

在settings,py 里面 将时区改成上海。默认是美国的

TIME_ZONE = 'Asia/Shanghai'

  也可以写一个方法。

def is_order_today(self):
        return self.order_date.date() == datetime.date.today()

 然后

>>>order.is_order_today()
true
 

这样是比较方便的一种

 

然后是关于主外建的关系。这里我们设置了order和orderdetail是一对多的关系。这个可以从建表语句看出来

默认的model保存,都会成成一个id。而如果是外建关联。这个外建就算model的名字_id。

那么怎么样去生成一个外建关联的实体呢?

#先通过主键获取到一个主model
>>>o = Order.objects.get(pk=1)
#建立2个实体
>>>o.orderdetail_set.create(detail_lineNO=1,order_SKU='gril')
>>>o.orderdetail_set.create(detail_lineNO=2,order_SKU='boy')
#输出
>>>OrderDetail.objects.all()
[<OrderDetail: OrderDetail object>, <OrderDetail: OrderDetail object>]
#这里没有写Orderdetail的__unicode__方法。但是可以看出来有2个实体
 

 

你可能感兴趣的:(sql,Hibernate,django,python,项目管理)