You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I'm listing the following table in my datatable (simplified version):
class MainTerm(db.Model):
__tablename__ = 'main_term'
id = db.Column(db.Integer, primary_key=True)
text = db.Column(db.String)
Further I have gazetteers that I would like to use for filtering:
terms_in_gzt = db.Table('terms_in_gzt',
db.Column('gzt_term_id', db.Integer, db.ForeignKey('gzt_term.id')),
db.Column('gazetteer_id', db.Integer, db.ForeignKey('gazetteer.id')),
)
class Gazetteer(db.Model):
__tablename__ = 'gazetteer'
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String)
terms = db.relationship('GztTerm', secondary=terms_in_gzt, backref='gazetteers', lazy='dynamic')
class GztTerm(db.Model):
__tablename__ = 'gzt_term'
id = db.Column(db.Integer, primary_key=True)
text = db.Column(db.String)
I would like to be able to show or excludeMainTerm entries that share the same text attribute with GztTerm given a certain Gazetteer.
So, when having Gazetteer with id 1. I want to be able to exclude or show all MainTerms that share the same text attribute with one of the GztTerms in Gazetteer.query.get(1).terms. In short: Filter all MainTerm entries with MainTerm.text == GztTerm.text for all GztTerm in Gazetteer.query.get(1).terms
What I have tried so far is creating a "custom"-filter:
def gzt_filter(expr, value):
if value == "show":
return expr == GztTerm.text
elif value == "exclude":
return expr != GztTerm.text
return expr
from datatables import search_methods
search_methods.SEARCH_METHODS['gzt_filter'] = gzt_filter
columns = [
...
ColumnDT(MainTerm.text, search_method='gzt_filter'),
...
]
This works for the show part in that sense that only those MainTerms are shown that share the text attribute with anyGztTerm. But it does not enable me to filter GztTerm in a certain Gazetteer instance.
Another problem with the above shown example is that when using exclude, the MainTerm entries that are shown in the table are multiplied with the number of GztTerm entries. So, when having 5 GztTerm entries, then each MainTerm entry is duplicated 5 times in the table (except those that were filtered out). Which of course is not desired.
The respective queries for the result that I desire would be:
Hi,
I'm listing the following table in my datatable (simplified version):
Further I have gazetteers that I would like to use for filtering:
I would like to be able to show or exclude
MainTerm
entries that share the sametext
attribute withGztTerm
given a certainGazetteer
.So, when having
Gazetteer
with id1
. I want to be able to exclude or show allMainTerm
s that share the sametext
attribute with one of theGztTerm
s inGazetteer.query.get(1).terms
.In short: Filter all
MainTerm
entries withMainTerm.text == GztTerm.text
for allGztTerm
inGazetteer.query.get(1).terms
What I have tried so far is creating a "custom"-filter:
This works for the show part in that sense that only those
MainTerm
s are shown that share thetext
attribute with anyGztTerm
. But it does not enable me to filterGztTerm
in a certainGazetteer
instance.Another problem with the above shown example is that when using exclude, the
MainTerm
entries that are shown in the table are multiplied with the number ofGztTerm
entries. So, when having 5GztTerm
entries, then eachMainTerm
entry is duplicated 5 times in the table (except those that were filtered out). Which of course is not desired.The respective queries for the result that I desire would be:
Where
search_value
is given by the user and handed over toColumnDT
.Is there any way to archive this filtering behaviour with datatables?
Thanks a lot!
The text was updated successfully, but these errors were encountered: