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. Defined by a ManyToManyField. You use it just like any other Field type: by including it as a class attribute of your model.
many-to-many relationship
Multi-table inheritance
range
save()
2. 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
latest(field_name=None)
Q()
defer(*fields)
Proxy model
3. Keyword shortcut for looking up an object by primary key.
annotate(args - *kwargs)
Manager methods
lt
pk
4. These are specified as keyword arguments to the QuerySet methods filter() - exclude() and get(). These take the form field__lookuptype=value .
Field lookups
create(**kwargs)
filter(**kwargs)
only(*fields)
5. This field is added automatically - but this behavior can be overridden
year
Meta class
id field
aggregate(args - *kwargs)
6. Lookup type for date/datetime fields that finds an exact year match. Takes a four-digit year.
ManyToManyField
annotate(args - *kwargs)
year
==
7. Can be used to remove all many-to-many relationships for an instance
range
clear() method
iendswith
delete()
8. 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.
OneToOneField
Meta class
default
none()
9. 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.
filter chaining
search
filter
iexact
10. This model method is used for updating a ManyToManyField.
istartswith
add()
null
QuerySet
11. The database that will be used if this query is executed now
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
db
gte
annotate(args - *kwargs)
12. 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()
get_or_create(**kwargs)
Entry.objects.all().update(n_pingbacks=F('n_pingbacks') + 1)
regex
13. 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
reverse()
startswith
using(alias)
exists()
14. 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.
help_text
regex
aggregate(args - *kwargs)
one-to-one relationship
15. 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.
regex
one-to-one relationship
Many-to-many relationship through an intermediate model
unique
16. (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
when you add new apps to INSTALLED_APPS
gte
lt
17. If you are using this attribute on a ForeignKey or ManyToManyField - you must always specify a unique reverse name for the field.
reverse()
select_related()
related_name
delete()
18. A convenience method for looking up an object with the given kwargs - creating one if necessary.
annotate(args - *kwargs)
Q()
aggregate(args - *kwargs)
get_or_create(**kwargs)
19. 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
Meta class
F()
20. 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.
search
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
choices
distinct()
21. Returns the most recent object in the table - by date - using the field_name provided as the date field.
blank
Manager
latest(field_name=None)
only(*fields)
22. This query finds all entries with an id greater than 4.
filter(**kwargs)
when you add new apps to INSTALLED_APPS
Entry.objects.filter(id__gt=4)
related_name
23. This method immediately deletes the object and has no return value.
only(*fields)
istartswith
delete()
get(**kwargs)
24. 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.
month
lte
gt
help_text
25. These add custom "row-level" functionality to your objects. These act on a particular model instance.
Custom model methods
Q(question__startswith='Who') | ~Q(pub_date__year=2005)
choices
OneToOneField
26. These methods are intended to do "table-wide" things.
all()
Manager methods
Manager
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
27. Operator for comparing two model instances for equality. Behind the scenes - it compares the primary key values of two models.
OneToOneField
only(*fields)
==
update()
28. 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
Q(question__istartswith='What')
range
istartswith
update(**kwargs)
29. 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.
model
exact
Many-to-many relationship to self
Restrictions on field names
30. A Manager method that returns a new QuerySet containing objects that match the given lookup parameters.
class attributes
Manager
Field lookups
filter(**kwargs)
31. Lookup type that returns results greater than or equal to a given value.
only(*fields)
intermediate models
gte
F()
32. a QuerySet can be sliced - using Python's array-slicing syntax.
id field
primary_key
exists()
slicing
33. Lookup type that returns results greater than a given value.
filter chaining
gt
using(alias)
one-to-one relationship
34. Each one of these is a Python class that subclasses django.db.models.Model. Each attribute of one of these represents a database field.
delete()
get_absolute_url()
model
update(**kwargs)
35. 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)
slicing
Model metadata
update()
related_name
36. 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.
exact
Entry.objects.all().update(n_pingbacks=F('n_pingbacks') + 1)
annotate(args - *kwargs)
pickling
37. Evaluates the QuerySet (by performing the query) and returns an iterator over the results. A QuerySet typically caches its results internally so that repeated evaluations do not result in additional queries; this method will instead read results dire
get_or_create(**kwargs)
iterator()
one-to-one relationship
dates(field - kind - order='ASC')
38. 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
39. This object allows you to compare the value of a model field with another field on the same model. Django supports the use of addition - subtraction - multiplication - division and modulo arithmetic with these objects - both with constants and with o
reverse()
get_absolute_url()
create(**kwargs)
F()
40. A manager method which returns a single object. If there are no results that match the query - this method will raise a DoesNotExist exception. If more than one item matches this query - the method will raise MultipleObjectsReturned.
class attributes
iterator()
get_or_create(**kwargs)
get(**kwargs)
41. 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
get(**kwargs)
class attributes
all()
blank
42. A QuerySet is iterable - and it executes its database query the first time you iterate over it.
iteration
values(*fields)
save()
in_bulk(id_list)
43. 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
clear() method
default
null
44. Returns a new QuerySet containing objects that match the given lookup parameters.
reverse name
choices
filter(**kwargs)
many-to-one relationship
45. 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
lte
MultipleObjectsReturned
&
46. 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.
Manager
filter chaining
defer(*fields)
pickling
47. 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.
search
update()
model
day
48. 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
related_name
ordered
annotate(args - *kwargs)
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
49. To activate your models
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
Entry.objects.filter(id__gt=4)
ForeignKey
one-to-one relationship
50. Lookup type that tests for inclusion in a case-sensitive fashion.
contains
id field
regex
day