SUBJECTS
|
BROWSE
|
CAREER CENTER
|
POPULAR
|
JOIN
|
LOGIN
Business Skills
|
Soft Skills
|
Basic Literacy
|
Certifications
About
|
Help
|
Privacy
|
Terms
|
Email
Search
Test your basic knowledge |
Django Queryset
Start Test
Study First
Subject
:
it-skills
Instructions:
Answer 50 questions in 15 minutes.
If you are not ready to take this test, you can
study here
.
Match each statement with the correct term.
Don't refresh. All questions and answers are randomly picked and ordered every time you load a test.
This is a study tool. The 3 wrong answers for each question are randomly chosen from answers to other questions. So, you might find at times the answers obvious, but you will see it re-enforces your understanding as you take the test each time.
1. Each one of these is a Python class that subclasses django.db.models.Model. Each attribute of one of these represents a database field.
model
Many-to-many relationship to self
Q()
Field lookups
2. This class type is useful when you just want to use the parent class to hold information that you don't want to have to type out for each child model. This class isn't going to ever be used in isolation. When it is used as a base class for other mode
dates(field - kind - order='ASC')
Abstract base class
lte
Entry.objects.filter(id__gt=4)
3. This object encapsulates a collection of keyword arguments - with the keys being field lookup types. These objects can be combined using the & and | operators - as well as negated with the ~ operator.
Q()
iexact
Entry.objects.filter(pub_date__range=(start_date - end_date))
null
4. In some complex data-modeling situations - your models might contain a lot of fields - some of which could contain a lot of data (for example - text fields) - or require expensive processing to convert them to Python objects. If you are using the res
Restrictions on field names
get_or_create(**kwargs)
month
defer(*fields)
5. Accomplish this by using the field name of related fields across models - separated by double underscores - until you get to the field you want. For example - to get all Entry objects with a Blog whose name is 'Beatles Blog': Entry.objects.filter(blo
annotate(args - *kwargs)
relationship spanning
when you add new apps to INSTALLED_APPS
get_or_create(**kwargs)
6. Returns True if the QuerySet contains any results - and False if not. This tries to perform the query in the simplest and fastest way possible - but it does execute nearly the same query. This means that calling this method on a queryset is faster th
Many-to-many relationship to self
search
pickling
exists()
7. Lookup type that returns results with a case-sensitive start sequence.
primary_key
iendswith
ForeignKey
startswith
8. If True - the table does not permit duplicate values for this field.
unique
iterator()
distinct()
year
9. Returns a DateQuerySet -- a QuerySet that evaluates to a list of datetime.datetime objects representing all available dates of a particular kind within the contents of the QuerySet.
Warning
: Invalid argument supplied for foreach() in
/var/www/html/basicversity.com/show_quiz.php
on line
183
10. A QuerySet is iterable - and it executes its database query the first time you iterate over it.
Entry.objects.filter(id__in=[1 - 3 - 4])
==
Entry.objects.filter(pub_date__year=2007).update(headline='Everything is the same')
iteration
11. Lookup type for date/datetime fields that finds an exact day match.
filter chaining
Many-to-many relationship to self
unique
day
12. To activate your models
iregex
get(**kwargs)
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
dates(field - kind - order='ASC')
13. Lookup type that returns results less than a given value.
in_bulk(id_list)
related_name
reverse()
lt
14. This query finds all entries between a start date of start_date and an end date of end_date.
__unicode__()
Entry.objects.filter(pub_date__range=(start_date - end_date))
filter(**kwargs)
reverse name
15. Keyword shortcut for looking up an object by primary key.
lt
iteration
none()
pk
16. These are specified as keyword arguments to the QuerySet methods filter() - exclude() and get(). These take the form field__lookuptype=value .
day
Field lookups
aggregate(args - *kwargs)
choices
17. Here - you can't use add - create - or assignment (i.e. - beatles.members = [...]) to create relationships. You need to specify all the detail for the relationship required by the intermediate model.
default
latest(field_name=None)
intermediate models
Many-to-many relationship through an intermediate model
18. Lookup type for date/datetime fields that finds a 'day of the week' match.
iterator()
select_related()
search
week_day
19. This method is more or less the opposite of defer(). You call it with the fields that should not be deferred when retrieving a model. If you have a model where almost all the fields need to be deferred - using this method to specify the complementary
only(*fields)
get_absolute_url()
filter(**kwargs)
istartswith
20. If True - this field is the primary key for the model.
primary_key
annotate(args - *kwargs)
Many-to-many relationship through an intermediate model
month
21. This method immediately deletes the object and has no return value.
Entry.objects.filter(id__in=[1 - 3 - 4])
delete()
endswith
related_name
22. If this option is True - the field is allowed to be blank. Default is False.
Q(question__startswith='Who') | ~Q(pub_date__year=2005)
regex
blank
count()
23. Operator for comparing two model instances for equality. Behind the scenes - it compares the primary key values of two models.
order_by(*fields)
day
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
==
24. Returns a dictionary of aggregate values (averages - sums - etc) calculated over the QuerySet. Each argument to this method specifies a value that will be included in the dictionary that is returned.
iterator()
reverse name
aggregate(args - *kwargs)
related_name
25. Takes the ouput of one filter and uses it as input for another filter. This works because a refinement of a QuerySet is itself a QuerySet.
filter chaining
&
add()
get(**kwargs)
26. The value given in the absence of a specified value for the field. This can be a value or a callable object. If callable it will be called every time a new object is created.
year
default
annotate(args - *kwargs)
when you add new apps to INSTALLED_APPS
27. This style of inheritanc is useful when you're subclassing an existing model (perhaps something from another application entirely) and want each model to have its own database table. Here - each model in the hierarchy is a model all by itself.
Multi-table inheritance
only(*fields)
startswith
Abstract base class
28. Returns a QuerySet that will automatically "follow" foreign-key relationships - selecting that additional related-object data when it executes its query. This is a performance booster which results in (sometimes much) larger queries but means later u
DoesNotExist
Model metadata
select_related()
Entry.objects.filter(pub_date__range=(start_date - end_date))
29. The database that will be used if this query is executed now
intermediate models
db
one-to-one relationship
year
30. Returns a copy of the current QuerySet (or QuerySet subclass you pass in). This can be useful in some situations where you might want to pass in either a model manager or a QuerySet and do further filtering on the result. You can safely call all() on
month
gte
class attributes
all()
31. Manager method used to retrieve every object in a model.
null
all()
values(*fields)
reverse name
32. Performs an SQL delete query on all rows in the QuerySet. This method is applied instantly. You cannot call this method on a QuerySet that has had a slice taken or can otherwise no longer be filtered.
delete()
Entry.objects.filter(pub_date__year=2005).delete()
MultipleObjectsReturned
clear() method
33. Returns a new QuerySet containing objects that match the given lookup parameters.
Proxy model
filter
filter(**kwargs)
year
34. Defines a one-to-one relationship. You use it just like any other Field type: by including it as a class attribute of your model.
startswith
OneToOneField
id field
unique
35. An iterable (e.g. - a list or tuple) of 2-tuples to use as options for this field. If this is given - Django's admin will use a select box instead of the standard text field and will limit options to those given.
select_related()
many-to-one relationship
choices
day
36. Specifies the model that will be used to govern the many-to-many relationship. You can then put extra fields on the intermediate model. The intermediate model is associated with the ManyToManyField using this to point to the model that will act as an
Custom model methods
through argument
Entry.objects.filter(pub_date__range=(start_date - end_date))
ManyToManyField
37. This query deletes all Entry objects with a pub_date year of 2005.
Entry.objects.filter(pub_date__year=2005).delete()
create(**kwargs)
Many-to-many relationship through an intermediate model
latest(field_name=None)
38. Defines a many-to-one relationship. ou use it just like any other Field type: by including it as a class attribute of your model.
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
Many-to-many relationship to self
ForeignKey
MultipleObjectsReturned
39. This query uses an F object to increment the pingback count for every entry in the blog.
Warning
: Invalid argument supplied for foreach() in
/var/www/html/basicversity.com/show_quiz.php
on line
183
40. Returns an EmptyQuerySet -- a QuerySet that always evaluates to an empty list. This can be used in cases where you know that you should return an empty result set and your caller is expecting a QuerySet object (instead of returning an empty list - fo
none()
values(*fields)
clear() method
iterator()
41. Exception raised by get(**kwargs) if no items match the query.
Many-to-many relationship through an intermediate model
save()
DoesNotExist
select_related()
42. A Python "magic method" that returns a unicode "representation" of any object.
default
MultipleObjectsReturned
pk
__unicode__()
43. Sometimes - the Django query syntax by itself can't easily express a complex WHERE clause. For these edge cases - Django provides this QuerySet modifier -- a hook for injecting specific clauses into the SQL generated by a QuerySet.
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
using(alias)
year
id field
44. A convenience method for constructing an object and saving it all in one step.
values(*fields)
Abstract base class
create(**kwargs)
db
45. Negation operator for Q objects.
range
~
get_absolute_url()
Restrictions on field names
46. (1) These cannot be Python reserved words - because that would result in a Python syntax error. (2) These cannot contain more than one underscore in a row - due to the way Django's query lookup syntax works.
Restrictions on field names
in_bulk(id_list)
through argument
only(*fields)
47. Lookup type for date/datetime fields that finds an exact year match. Takes a four-digit year.
lte
all()
order_by(*fields)
year
48. If you pickle a QuerySet - this will force all the results to be loaded into memory prior to pickling. When you unpickle a QuerySet - it contains the results at the moment it was pickled - rather than the results that are currently in the database.
pickling
get(**kwargs)
in
help_text
49. This model method saves a model instance to the database. This method has no return value.
dates(field - kind - order='ASC')
update()
save()
pk
50. Lookup type that returns results that fall into an inclusive date range.
range
annotate(args - *kwargs)
pickling
none()