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. (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
select_related()
search
count()
2. These are "anything that's not a field" - such as ordering options (ordering) - database table name (db_table) - or human-readable singular and plural names (verbose_name and verbose_name_plural)
none()
blank
aggregate(args - *kwargs)
Model metadata
3. 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.
default
week_day
Entry.objects.filter(pub_date__year=2005).delete()
&
4. Exception raised by get(**kwargs) if no items match the query.
only(*fields)
DoesNotExist
none()
choices
5. Returns a new QuerySet containing objects that match the given lookup parameters.
filter(**kwargs)
annotate(args - *kwargs)
all()
in_bulk(id_list)
6. 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
7. Lookup type for date/datetime fields that finds an exact year match. Takes a four-digit year.
exclude(**kwargs)
year
defer(*fields)
exists()
8. Lookup type that finds a case-insensitive regular expression match.
one-to-one relationship
iregex
contains
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
9. 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
clear() method
Q(question__istartswith='What')
defer(*fields)
one-to-one relationship
10. Use this method to reverse the order in which a queryset's elements are returned. Calling this method a second time restores the ordering back to the normal direction.
ForeignKey
reverse()
regex
class attributes
11. This query deletes all Entry objects with a pub_date year of 2005.
filter(**kwargs)
Many-to-many relationship to self
related_name
Entry.objects.filter(pub_date__year=2005).delete()
12. To activate your models
clear() method
ordered
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
delete()
13. Manager method used to retrieve every object in a model.
all()
Many-to-many relationship to self
exists()
Abstract base class
14. Takes a list of primary-key values and returns a dictionary mapping each primary-key value to an instance of the object with the given ID.
endswith
in_bulk(id_list)
latest(field_name=None)
OneToOneField
15. Defined by django.db.models.ForeignKey. You use it just like any other Field type: by including it as a class attribute of your model.
lte
many-to-one relationship
lt
iterator()
16. Returns the object matching the given lookup parameters
latest(field_name=None)
get(**kwargs)
Q(question__istartswith='What')
Manager
17. When to run syncdb
Entry.objects.all().update(n_pingbacks=F('n_pingbacks') + 1)
aggregate(args - *kwargs)
when you add new apps to INSTALLED_APPS
Many-to-many relationship to self
18. Returns the most recent object in the table - by date - using the field_name provided as the date field.
Q(question__startswith='Who') | ~Q(pub_date__year=2005)
when you add new apps to INSTALLED_APPS
db
latest(field_name=None)
19. Used to get a QuerySet for a model. This is called 'objects' by default.
gte
Manager
exclude(**kwargs)
many-to-many relationship
20. Returns a ValuesQuerySet -- a QuerySet that returns dictionaries when used as an iterable - rather than model-instance objects.
values(*fields)
all()
Q(question__startswith='Who') | ~Q(pub_date__year=2005)
update()
21. 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
regex
Manager
all()
__unicode__()
22. This field is added automatically - but this behavior can be overridden
count()
Manager
id field
defer(*fields)
23. These add custom "row-level" functionality to your objects. These act on a particular model instance.
only(*fields)
Entry.objects.filter(pub_date__year=2007).update(headline='Everything is the same')
get_absolute_url()
Custom model methods
24. Lookup type that returns results with a case-insensitive start sequence.
reverse()
unique
istartswith
&
25. Lookup type that finds a case-sensitive regular expression match.
get(**kwargs)
regex
add()
Entry.objects.filter(pub_date__range=(start_date - end_date))
26. 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.
through argument
Abstract base class
Model metadata
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
27. A Python "magic method" that returns a unicode "representation" of any object.
through argument
__unicode__()
istartswith
DoesNotExist
28. A Manager method that returns a new QuerySet containing objects that match the given lookup parameters.
reverse name
|
iterator()
filter(**kwargs)
29. These methods are intended to do "table-wide" things.
in
filter(**kwargs)
Manager methods
delete()
30. Operator for comparing two model instances for equality. Behind the scenes - it compares the primary key values of two models.
primary_key
delete()
==
defer(*fields)
31. Defined by a OneToOneField. You use it just like any other Field type: by including it as a class attribute of your model.
help_text
one-to-one relationship
istartswith
Meta class
32. a QuerySet can be sliced - using Python's array-slicing syntax.
one-to-one relationship
slicing
create(**kwargs)
using(alias)
33. Extra text to be displayed under the field on the object's admin form to provide assistance to users. It's useful for documentation even if your object doesn't have an admin form.
delete()
&
null
help_text
34. By default - results returned by a QuerySet are ordered by the ordering tuple given by the ordering option in the model's Meta. You can override this on a per-QuerySet basis by using the this method.
unique
order_by(*fields)
iteration
filter(**kwargs)
35. True if the QuerySet has an order_by() clause or a default ordering on the model. False otherwise.
save()
ForeignKey
ordered
create(**kwargs)
36. Lookup type that returns results less than a given value.
ordered
MultipleObjectsReturned
lt
search
37. 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
filter(**kwargs)
create(**kwargs)
~
exists()
38. 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(question__startswith='Who') | ~Q(pub_date__year=2005)
default
db
Q()
39. Conjuntion operator for Q objects.
&
latest(field_name=None)
iterator()
range
40. The database that will be used if this query is executed now
in
db
none()
latest(field_name=None)
41. If True - the table does not permit duplicate values for this field.
unique
get(**kwargs)
all()
reverse()
42. 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.
pk
distinct()
pickling
Many-to-many relationship through an intermediate model
43. Lookup type that yields an "exact" match. If you don't provide a lookup type -- that is - if your keyword argument doesn't contain a double underscore -- the lookup type is assumed to be of this sort.
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
exact
filter(**kwargs)
exists()
44. A Q object that asks for entries with a question value that start with 'Who' or do not have a publication date of 2005.
Warning
: Invalid argument supplied for foreach() in
/var/www/html/basicversity.com/show_quiz.php
on line
183
45. This sets a field to a particular value for all the objects in a QuerySet. You can only set non-relation fields and ForeignKey fields using this method.
reverse()
choices
Custom model methods
update()
46. Negation operator for Q objects.
count()
save()
delete()
~
47. If you are using this attribute on a ForeignKey or ManyToManyField - you must always specify a unique reverse name for the field.
related_name
Entry.objects.all().update(n_pingbacks=F('n_pingbacks') + 1)
get_or_create(**kwargs)
all()
48. Fields are specified by these
clear() method
one-to-one relationship
&
class attributes
49. 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
reverse name
Field lookups
none()
values(*fields)
50. In this case - an intermediate model can have multiple foreign keys to the source model. Here - two foreign keys to the same model are permitted - but they will be treated as the two (different) sides of the many-to-many relation.
lt
Many-to-many relationship to self
in
Manager