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. Exception raised by get(**kwargs) if more than one item matches the query.
MultipleObjectsReturned
filter chaining
Q()
unique
2. (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.
reverse()
choices tuple
intermediate models
Restrictions on field names
3. 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)
Field lookups
Model metadata
all()
__unicode__()
4. If you are using this attribute on a ForeignKey or ManyToManyField - you must always specify a unique reverse name for the field.
choices
get_or_create(**kwargs)
related_name
startswith
5. This model method is used for updating a ManyToManyField.
add()
create(**kwargs)
many-to-one relationship
in
6. 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
defer(*fields)
Entry.objects.filter(id__gt=4)
through argument
Abstract base class
7. 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
Entry.objects.all().update(n_pingbacks=F('n_pingbacks') + 1)
Proxy model
get(**kwargs)
8. If True - this field is the primary key for the model.
primary_key
iteration
pickling
Restrictions on field names
9. This query updates all the headlines with pub_date in 2007 to read 'Everything is the same'.
Warning
: Invalid argument supplied for foreach() in
/var/www/html/basicversity.com/show_quiz.php
on line
183
10. Adds to each object in the QuerySet with the provided list of aggregate values (averages - sums - etc) that have been computed over the objects that are related to the objects in the QuerySet. Each argument to this is content that will be added to ea
all()
annotate(args - *kwargs)
null
select_related()
11. 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.
help_text
startswith
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
related_name
12. 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
13. If True - the table does not permit duplicate values for this field.
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
unique
using(alias)
update(**kwargs)
14. Returns a new QuerySet that uses SELECT DISTINCT in its SQL query. This eliminates duplicate rows from the query results.
all()
distinct()
select_related()
contains
15. 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.
istartswith
default
lte
QuerySet
16. This query finds all entries between a start date of start_date and an end date of end_date.
values_list(*fields)
Entry.objects.filter(pub_date__range=(start_date - end_date))
regex
many-to-many relationship
17. Conjuntion operator for Q objects.
lt
Entry.objects.all().update(n_pingbacks=F('n_pingbacks') + 1)
&
gt
18. 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.
exact
search
values(*fields)
values_list(*fields)
19. This query finds all entries with an id in the list [1 - 3 - 4]
reverse()
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
gte
Entry.objects.filter(id__in=[1 - 3 - 4])
20. 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()
evaluation
ManyToManyField
get_or_create(**kwargs)
F()
21. 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
QuerySet
update(**kwargs)
~
get_or_create(**kwargs)
22. restrictions on ________: (1) Your intermediate model must contain one - and only one - foreign key to the target model. (2) Your intermediate model must contain one - and only one - foreign key to the source model. (3) When defining a many-to-many r
regex
filter(**kwargs)
intermediate models
distinct()
23. Returns an integer representing the number of objects in the database matching the QuerySet. This never raises exceptions.
order_by(*fields)
count()
isnull
delete()
24. Exception raised by get(**kwargs) if no items match the query.
DoesNotExist
when you add new apps to INSTALLED_APPS
many-to-one relationship
class attributes
25. 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
Entry.objects.filter(id__gt=4)
none()
model
null
26. True if the QuerySet has an order_by() clause or a default ordering on the model. False otherwise.
unique
ordered
help_text
Entry.objects.filter(id__gt=4)
27. A Python "magic method" that returns a unicode "representation" of any object.
__unicode__()
QuerySet
delete()
Proxy model
28. Lookup type that returns results that fall into an inclusive date range.
through argument
evaluation
range
filter(**kwargs)
29. 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.
select_related()
many-to-one relationship
related_name
slicing
30. 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
31. Lookup type that returns results greater than a given value.
filter chaining
gt
istartswith
all()
32. Lookup type that finds a case-insensitive regular expression match.
iregex
delete()
lt
Entry.objects.filter(pub_date__year=2007).update(headline='Everything is the same')
33. 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.
using(alias)
ordered
Many-to-many relationship through an intermediate model
Q(question__istartswith='What')
34. 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.
latest(field_name=None)
in_bulk(id_list)
Abstract base class
ordered
35. Negation operator for Q objects.
~
Entry.objects.filter(pub_date__year=2005).delete()
defer(*fields)
latest(field_name=None)
36. A Q object that encapsulates queries for entries with a question value that starts with 'What' in a case-insensitive fashion.
Warning
: Invalid argument supplied for foreach() in
/var/www/html/basicversity.com/show_quiz.php
on line
183
37. These add custom "row-level" functionality to your objects. These act on a particular model instance.
&
delete()
defer(*fields)
Custom model methods
38. Lookup type for date/datetime fields that finds a 'day of the week' match.
Custom model methods
week_day
in_bulk(id_list)
Multi-table inheritance
39. Lookup type for date/datetime fields that finds an exact day match.
lte
Many-to-many relationship through an intermediate model
exists()
day
40. a QuerySet can be sliced - using Python's array-slicing syntax.
Manager
unique
ordered
slicing
41. 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
get_absolute_url()
select_related()
relationship spanning
blank
42. When to run syncdb
all()
class type
when you add new apps to INSTALLED_APPS
evaluation
43. These methods are intended to do "table-wide" things.
__unicode__()
Manager methods
week_day
update(**kwargs)
44. Lookup type that returns results less than a given value.
only(*fields)
Custom model methods
lt
id field
45. 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
46. 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)
exclude(**kwargs)
week_day
Entry.objects.filter(id__in=[1 - 3 - 4])
47. Lookup type that returns results greater than or equal to a given value.
unique
one-to-one relationship
gte
filter(**kwargs)
48. Defines a many-to-many relationship. You use it just like any other Field type: by including it as a class attribute of your model.
ManyToManyField
exact
Entry.objects.filter(pub_date__range=(start_date - end_date))
annotate(args - *kwargs)
49. 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()
F()
one-to-one relationship
select_related()
50. 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.
iendswith
filter(**kwargs)
DoesNotExist
filter chaining