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. Fields are specified by these
contains
class attributes
many-to-one relationship
Many-to-many relationship through an intermediate model
2. If True - the table does not permit duplicate values for this field.
Meta class
delete()
unique
annotate(args - *kwargs)
3. Keyword shortcut for looking up an object by primary key.
Restrictions on field names
pk
==
none()
4. 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.
update(**kwargs)
dates(field - kind - order='ASC')
create(**kwargs)
search
5. 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.
day
Many-to-many relationship to self
reverse name
ForeignKey
6. 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.
Custom model methods
Entry.objects.filter(pub_date__year=2007).update(headline='Everything is the same')
pickling
through argument
7. True if the QuerySet has an order_by() clause or a default ordering on the model. False otherwise.
aggregate(args - *kwargs)
many-to-many relationship
class type
ordered
8. This query finds all entries with an id greater than 4.
Entry.objects.filter(id__gt=4)
filter
iendswith
blank
9. Lookup type that finds a case-insensitive regular expression match.
filter(**kwargs)
&
iregex
reverse()
10. Lookup type that returns results with a case-sensitive end sequence.
&
add()
in
endswith
11. Can be used to remove all many-to-many relationships for an instance
regex
Q(question__startswith='Who') | ~Q(pub_date__year=2005)
clear() method
Multi-table inheritance
12. Lookup type for date/datetime fields that finds an exact day match.
__unicode__()
null
all()
day
13. If you are using this attribute on a ForeignKey or ManyToManyField - you must always specify a unique reverse name for the field.
reverse()
iregex
related_name
Q(question__startswith='Who') | ~Q(pub_date__year=2005)
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.
contains
in_bulk(id_list)
defer(*fields)
DoesNotExist
15. 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.
ForeignKey
order_by(*fields)
help_text
using(alias)
16. Returns a new QuerySet containing objects that match the given lookup parameters.
update(**kwargs)
filter(**kwargs)
iteration
get_absolute_url()
17. 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 name
QuerySet
db
exists()
18. A convenience method for looking up an object with the given kwargs - creating one if necessary.
filter
Proxy model
get_or_create(**kwargs)
iexact
19. Lookup type that yields a case-insensitive match.
MultipleObjectsReturned
iexact
filter(**kwargs)
pk
20. 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
class attributes
update()
exists()
select_related()
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
db
defer(*fields)
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
update(**kwargs)
22. Lookup type that returns results with a case-insensitive end sequence.
null
filter(**kwargs)
iendswith
db
23. If this option is True - the field is allowed to be blank. Default is False.
save()
gt
clear() method
blank
24. 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.
clear() method
|
in
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
25. 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
26. (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
exact
Entry.objects.filter(pub_date__year=2007).update(headline='Everything is the same')
order_by(*fields)
27. 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
exact
add()
all()
Manager methods
28. Lookup type that finds a case-sensitive regular expression match.
regex
iteration
get(**kwargs)
get(**kwargs)
29. Lookup type that returns results less than a given value.
delete()
month
lt
ForeignKey
30. Lookup type for date/datetime fields that finds an exact year match. Takes a four-digit year.
year
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
one-to-one relationship
Entry.objects.filter(pub_date__year=2005).delete()
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.
Q()
Entry.objects.filter(pub_date__range=(start_date - end_date))
filter chaining
none()
32. 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.
annotate(args - *kwargs)
using(alias)
evaluation
only(*fields)
33. This method returns tuples of values when iterated over. Each tuple contains the value from the respective field passed into the call to this method -- so the first item is the first field - etc.
evaluation
defer(*fields)
values_list(*fields)
lte
34. Returns a ValuesQuerySet -- a QuerySet that returns dictionaries when used as an iterable - rather than model-instance objects.
QuerySet
values(*fields)
order_by(*fields)
dates(field - kind - order='ASC')
35. Returns an integer representing the number of objects in the database matching the QuerySet. This never raises exceptions.
count()
pk
filter
add()
36. 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
37. This field is added automatically - but this behavior can be overridden
id field
unique
reverse name
QuerySet
38. 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
extra(select=None - where=None - params=None - tables=None - order_by=None - select_params=None)
lte
choices tuple
intermediate models
39. To activate your models
delete()
order_by(*fields)
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
in
40. This is a criterion that narrow down a QuerySet based on given parameters.
Entry.objects.all().update(n_pingbacks=F('n_pingbacks') + 1)
Q(question__istartswith='What')
exact
filter
41. Lookup type for date/datetime fields that finds an exact month match. Takes an integer 1 (January) through 12
many-to-one relationship
Entry.objects.filter(id__gt=4)
month
save()
42. Operator for comparing two model instances for equality. Behind the scenes - it compares the primary key values of two models.
class type
reverse()
lte
==
43. 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.
year
Many-to-many relationship to self
range
Q(question__istartswith='What')
44. Lookup type for date/datetime fields that finds a 'day of the week' match.
many-to-one relationship
Many-to-many relationship through an intermediate model
lte
week_day
45. 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.
all()
aggregate(args - *kwargs)
OneToOneField
gte
46. 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
choices tuple
Manager
47. 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.
pk
delete()
DoesNotExist
model
48. 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.
ordered
distinct()
Multi-table inheritance
relationship spanning
49. 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
F()
count()
using(alias)
day
50. Returns the object matching the given lookup parameters
get(**kwargs)
edit your settings file and change the INSTALLED_APPS setting to add the name of the module that contains your models.py.
iexact
&