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. The database that will be used if this query is executed now
Model metadata
db
~
get_or_create(**kwargs)
2. Defined by a OneToOneField. You use it just like any other Field type: by including it as a class attribute of your model.
clear() method
~
one-to-one relationship
exclude(**kwargs)
3. Negation operator for Q objects.
none()
==
~
delete()
4. Evaluation happens upon use the "step" parameter of slice syntax - the first time you iterate over it - when pickling or caching results - upon calling repr() - upon calling len() - upon calling list() - upon calling bool()
order_by(*fields)
relationship spanning
&
evaluation
5. This model type is useful if you only want to modify the Python-level behavior of a model - without changing the models fields in any way. This creates a stand-in for the original model. You can create - delete and update instances of this new model
range
Q(question__istartswith='What')
null
Proxy model
6. 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
relationship spanning
through argument
update(**kwargs)
create(**kwargs)
7. Performs an SQL update query for the specified fields - and returns the number of rows affected. This method is applied instantly and the only restriction on the QuerySet that is updated is that it can only update columns in the model's main table. F
update(**kwargs)
defer(*fields)
DoesNotExist
Custom model methods
8. Defined by a ManyToManyField. You use it just like any other Field type: by including it as a class attribute of your model.
DoesNotExist
many-to-many relationship
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
9. 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.
reverse()
one-to-one relationship
isnull
get_or_create(**kwargs)
10. Returns the object matching the given lookup parameters
MultipleObjectsReturned
Entry.objects.filter(pub_date__range=(start_date - end_date))
Field lookups
get(**kwargs)
11. 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.
12. Can be used to remove all many-to-many relationships for an instance
endswith
clear() method
Entry.objects.filter(pub_date__range=(start_date - end_date))
day
13. A manager method that returns a new QuerySet containing objects that do not match the given lookup parameters.
one-to-one relationship
only(*fields)
search
exclude(**kwargs)
14. 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.
isnull
help_text
default
db
15. A Manager method that returns a new QuerySet containing objects that match the given lookup parameters.
values_list(*fields)
week_day
none()
filter(**kwargs)
16. If you are using this attribute on a ForeignKey or ManyToManyField - you must always specify a unique reverse name for the field.
|
Many-to-many relationship through an intermediate model
related_name
blank
17. Keyword shortcut for looking up an object by primary key.
get_absolute_url()
select_related()
pk
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
18. Fields are specified by these
OneToOneField
day
class attributes
all()
19. This is a criterion that narrow down a QuerySet based on given parameters.
Meta class
Manager methods
aggregate(args - *kwargs)
filter
20. 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.
filter(**kwargs)
slicing
relationship spanning
exact
21. Returns the most recent object in the table - by date - using the field_name provided as the date field.
istartswith
Manager methods
delete()
latest(field_name=None)
22. Manager method used to retrieve every object in a model.
all()
model
filter(**kwargs)
startswith
23. This gives your model metadata.
QuerySet
day
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
Meta class
24. 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.
class type
update()
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
in_bulk(id_list)
25. 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
model
all()
iexact
F()
26. a QuerySet can be sliced - using Python's array-slicing syntax.
clear() method
Manager methods
default
slicing
27. This query finds all entries with an id in the list [1 - 3 - 4]
year
Many-to-many relationship through an intermediate model
exists()
Entry.objects.filter(id__in=[1 - 3 - 4])
28. Lookup type that takes either True or False and corresponds to SQL queries of IS NULL and IS NOT NULL - respectively.
isnull
exact
week_day
delete()
29. This method is for controlling which database the QuerySet will be evaluated against if you are using more than one database. The only argument this method takes is the alias of a database - as defined in DATABASES.
pk
using(alias)
filter(**kwargs)
primary_key
30. 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.
null
Multi-table inheritance
delete()
values_list(*fields)
31. 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.
default
filter chaining
using(alias)
filter(**kwargs)
32. This represents a collection of objects from your database. It can have zero - one or many filters.
iendswith
QuerySet
get_absolute_url()
delete()
33. 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.
update()
slicing
range
delete()
34. 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()
model
gt
Entry.objects.filter(pub_date__range=(start_date - end_date))
35. Lookup type for date/datetime fields that finds a 'day of the week' match.
all()
week_day
distinct()
primary_key
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
when you add new apps to INSTALLED_APPS
through argument
month
class type
37. This query uses an F object to increment the pingback count for every entry in the blog.
38. Lookup type that returns results with a case-insensitive start sequence.
iexact
reverse name
istartswith
QuerySet
39. Each one of these is a Python class that subclasses django.db.models.Model. Each attribute of one of these represents a database field.
in
id field
model
Q(question__istartswith='What')
40. Lookup type that corresponds to a boolean full-text search - taking advantage of full-text indexing. This is like contains but is significantly faster due to full-text indexing.
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
search
gte
Model metadata
41. If this option is True - Django will store empty values as NULL in the database. Default is False.
null
search
id field
create(**kwargs)
42. Lookup type that finds a case-insensitive regular expression match.
Multi-table inheritance
iregex
in
distinct()
43. These methods are intended to do "table-wide" things.
Manager methods
add()
dates(field - kind - order='ASC')
MultipleObjectsReturned
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.
45. 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
latest(field_name=None)
all()
when you add new apps to INSTALLED_APPS
exists()
46. Returns a new QuerySet containing objects that match the given lookup parameters.
aggregate(args - *kwargs)
filter(**kwargs)
db
QuerySet
47. Lookup type that yields a case-insensitive match.
exact
iexact
Entry.objects.filter(id__gt=4)
day
48. (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.
Model metadata
relationship spanning
Restrictions on field names
QuerySet
49. Lookup type that returns results less than a given value.
add()
unique
lt
gt
50. 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.
annotate(args - *kwargs)
ordered
class type
delete()