version 1.109, 2007/04/03 14:44:24
|
version 1.112, 2007/04/19 20:29:59
|
Line 623 class ZSQLExtendFolder(Folder,Persistent
|
Line 623 class ZSQLExtendFolder(Folder,Persistent
|
return 1 |
return 1 |
return 0 |
return 0 |
|
|
|
def ZSQLMultiSearch(self,_table,_searchField,_value,_idField,_additionalStatement="",_select=None,_storename=None): |
|
""" |
|
Durchsucht in einer Tabelle "table" die Spalte "searchfield" nach dem allen Vorkommnissen |
|
von Worten in value und gibt alle Werte mit gleichem id field zurŸck, d.h. es wird die "und" suche realisiert, |
|
z.B. fŸr simplesearch ueber mehrere Felder |
|
""" |
|
if _storename: |
|
"""store""" |
|
else: |
|
_storename="foundCount" |
|
|
|
queries=[] |
|
#baue jede einzelne abfrage |
|
splitted=_value.split(" ") |
|
if not _select: |
|
_select=_idField |
|
|
|
queries.append("select %s from %s %s where %s like '%%%s%%'"%(_select,_table,_additionalStatement,_searchField,splitted[0])) |
|
|
|
if len(splitted)>1: |
|
for v in splitted[1:]: |
|
queries.append("select %s from %s where %s like '%%%s%%'"%(_idField,_table,_searchField,v)) |
|
|
|
q=" and %s in ("%_idField |
|
query=q.join(queries) # nun baue sie zusammen |
|
for i in range(len(queries)-1): |
|
query+=")" #noch die klammern schliessen |
|
|
|
|
|
if _additionalStatement: |
|
query=query+" " |
|
|
|
logging.info("ZSQLSimple: %s"%query) |
|
retT=self.ZSQLSimpleSearch(query) |
|
logging.info("ZSQLSimple: %s"%retT) |
|
|
|
retFinalT={} |
|
for x in retT: |
|
split=_idField.split(".") |
|
if len(split)>1: |
|
f=split[1] |
|
else: |
|
f=_idField |
|
|
|
retFinalT[getattr(x,f)]=x |
|
|
|
ret=list(retFinalT.values()) |
|
|
|
|
|
|
|
if not self.REQUEST.SESSION.has_key(_storename): |
|
self.REQUEST.SESSION[_storename]={} |
|
|
|
self.REQUEST.SESSION[_storename]['searchFieldsOnly']={} |
|
self.REQUEST.SESSION[_storename]['qs']=query |
|
return ret |
|
|
def ZSQLsearchOptions(self,fieldname=""): |
def ZSQLsearchOptions(self,fieldname=""): |
"""return HTML Fragment with search options""" |
"""return HTML Fragment with search options""" |
|
|
Line 691 class ZSQLExtendFolder(Folder,Persistent
|
Line 748 class ZSQLExtendFolder(Folder,Persistent
|
valueName=None,start=None, |
valueName=None,start=None, |
multiple='',startValue=None, |
multiple='',startValue=None, |
additionalSelect="",size=None, |
additionalSelect="",size=None, |
linelen=None,selected=None): |
linelen=None,selected=None, |
|
clear=False): |
"""generate select options form a search list |
"""generate select options form a search list |
es wird |
es wird |
<select name=fieldname mutiple> |
<select name=fieldname mutiple> |
Line 699 class ZSQLExtendFolder(Folder,Persistent
|
Line 757 class ZSQLExtendFolder(Folder,Persistent
|
<option value=result.fieldName>result.fieldValue</option> |
<option value=result.fieldName>result.fieldValue</option> |
erzeugt. |
erzeugt. |
|
|
@parameter fieldname: Name fuer name-wert im select-tag |
@param fieldname: Name fuer name-wert im select-tag |
@results results: Resultobject einer SQL-suche |
@param results: Resultobject einer SQL-suche |
@parameter fieldName: Name des Feldes, das als value in den option-tag geschrieben werden soll. |
@param fieldName: Name des Feldes, das als value in den option-tag geschrieben werden soll. |
@parameter valueName: (optional) Name des Feldes, dass als im option-tag ausgegeben wird, default wert ist valueName=fieldName |
@param valueName: (optional) Name des Feldes, dass als im option-tag ausgegeben wird, default wert ist valueName=fieldName |
@start: (optional) falls zusaetzliches option tag erzeugt werden soll, gibt start an was im option tag steht |
@param start: (optional) falls zusaetzliches option tag erzeugt werden soll, gibt start an was im option tag steht |
@startValue (optional): gibt den entsprechenden Wert an. |
@param startValue (optional): gibt den entsprechenden Wert an. |
@selected (optional): Wert der ausgewaehlt sein soll. |
@param selected (optional): Wert der ausgewaehlt sein soll. |
@linelen: (optional) maximale laenge eines Eintrages |
@param linelen: (optional) maximale laenge eines Eintrages |
der im Klappmenue noch angezeigt wird, laengeres wird abgeschnitten. |
der im Klappmenue noch angezeigt wird, laengeres wird abgeschnitten. |
@addionalSaelect (optional): zusaetzlicher text fuer den select tag |
@param addionalSaelect (optional): zusaetzlicher text fuer den select tag |
|
@param clear (optional): setze auf den startwert. |
""" |
""" |
if not valueName: |
if not valueName: |
valueName=fieldName |
valueName=fieldName |
Line 725 class ZSQLExtendFolder(Folder,Persistent
|
Line 784 class ZSQLExtendFolder(Folder,Persistent
|
if not startValue: |
if not startValue: |
startValue=start |
startValue=start |
|
|
|
if clear: |
|
ret+="""<option selected value="%s" >%s</option>"""%(startValue,start) |
|
else: |
ret+="""<option value="%s" >%s</option>"""%(startValue,start) |
ret+="""<option value="%s" >%s</option>"""%(startValue,start) |
|
|
for result in results: |
for result in results: |
Line 736 class ZSQLExtendFolder(Folder,Persistent
|
Line 798 class ZSQLExtendFolder(Folder,Persistent
|
else: |
else: |
displayValue = fieldValue |
displayValue = fieldValue |
|
|
|
if displayValue: #show only if value not none |
if field == selected: |
if field == selected: |
|
|
ret+="""<option value="%s" selected>%s</option>"""%(field,displayValue) |
ret+="""<option value="%s" selected>%s</option>"""%(field,displayValue) |
Line 824 class ZSQLExtendFolder(Folder,Persistent
|
Line 886 class ZSQLExtendFolder(Folder,Persistent
|
if x: |
if x: |
value=x |
value=x |
else: |
else: |
|
|
value=str(argTmp[a]) |
value=str(argTmp[a]) |
qs.append(aFiltered+"="+urllib.quote(value)) |
qs.append(aFiltered+"="+urllib.quote(value)) |
|
|
Line 853 class ZSQLExtendFolder(Folder,Persistent
|
Line 916 class ZSQLExtendFolder(Folder,Persistent
|
|
|
def ZSQLSimpleSearch(self,query=None,max_rows=1000000): |
def ZSQLSimpleSearch(self,query=None,max_rows=1000000): |
"""simple search""" |
"""simple search""" |
logging.error(query) |
logging.error("ZSQLSimpleSearch X %s"%query) |
#print query |
#print query |
if not query: |
if not query: |
query=self.query |
query=self.query |
Line 865 class ZSQLExtendFolder(Folder,Persistent
|
Line 928 class ZSQLExtendFolder(Folder,Persistent
|
|
|
self._v_searchSQL.max_rows_=max_rows |
self._v_searchSQL.max_rows_=max_rows |
try: |
try: |
return self._v_searchSQL.__call__(var=query) |
logging.error("I am here") |
|
t=self._v_searchSQL.__call__(var=query) |
|
logging.error("I am here %s"%t) |
|
return t |
except : |
except : |
|
logger("ZSQLSimpleSearch ERROR1",logging.ERROR, '%s %s'%sys.exc_info()[:2]) |
if sys.exc_info()[0]=="Database Error": |
if sys.exc_info()[0]=="Database Error": |
try: |
try: |
self.getConnectionObj().manage_open_connection() |
self.getConnectionObj().manage_open_connection() |
except: |
except: |
logger("ZSQLSimpleSearch",logging.ERROR, '%s %s'%sys.exc_info()[:2]) |
logger("ZSQLSimpleSearch ERROR2",logging.ERROR, '%s %s'%sys.exc_info()[:2]) |
else: |
else: |
try: |
try: |
|
|
Line 880 class ZSQLExtendFolder(Folder,Persistent
|
Line 946 class ZSQLExtendFolder(Folder,Persistent
|
|
|
return self._v_searchSQL.__call__(var=query) |
return self._v_searchSQL.__call__(var=query) |
except : |
except : |
|
logger("ZSQLSimpleSearch ERROR2",logging.ERROR, '%s %s'%sys.exc_info()[:2]) |
if sys.exc_info()[0]=="Database Error": |
if sys.exc_info()[0]=="Database Error": |
try: |
try: |
self.getConnectionObj().manage_open_connection() |
self.getConnectionObj().manage_open_connection() |
Line 1013 class ZSQLExtendFolder(Folder,Persistent
|
Line 1079 class ZSQLExtendFolder(Folder,Persistent
|
table=urllib.unquote(value) |
table=urllib.unquote(value) |
elif name=="-identify": |
elif name=="-identify": |
identify=urllib.unquote(value) |
identify=urllib.unquote(value) |
identify=identify.split("=")[0]+"="+sql_quote(identify.split("=")[1]) |
identify="lower("+identify.split("=")[0]+")="+sql_quote(identify.split("=")[1].lower()) |
elif name=="-format": |
elif name=="-format": |
format=urllib.unquote(value) |
format=urllib.unquote(value) |
#elif (not (name[0]=="-" or name[0]=="_")) and (not len(value)==0): |
#elif (not (name[0]=="-" or name[0]=="_")) and (not len(value)==0): |
Line 1124 class ZSQLExtendFolder(Folder,Persistent
|
Line 1190 class ZSQLExtendFolder(Folder,Persistent
|
|
|
|
|
#print "calling Query with",repr(NoQuery) |
#print "calling Query with",repr(NoQuery) |
|
|
ret=self.parseQueryString(qs,"-",select=select,storemax="yes",storename=storename,tableExt=tableExt,NoQuery=NoQuery,NoLimit=NoLimit,restrictField=restrictField,restrictConnect=restrictConnect,filter=filter) |
ret=self.parseQueryString(qs,"-",select=select,storemax="yes",storename=storename,tableExt=tableExt,NoQuery=NoQuery,NoLimit=NoLimit,restrictField=restrictField,restrictConnect=restrictConnect,filter=filter) |
#print self.REQUEST.SESSION["foundCount"] |
#print self.REQUEST.SESSION["foundCount"] |
|
|
|
|
|
|
return ret |
return ret |
|
|
def ZSQLFoundCountLen(self,var): |
def ZSQLFoundCountLen(self,var): |
Line 1174 class ZSQLExtendFolder(Folder,Persistent
|
Line 1242 class ZSQLExtendFolder(Folder,Persistent
|
for query in querys: |
for query in querys: |
arg=query.split("=")[0] |
arg=query.split("=")[0] |
if arg[0]=="_": arg="-"+arg[1:] # sicherstellen, dass an Anfang stets "_" |
if arg[0]=="_": arg="-"+arg[1:] # sicherstellen, dass an Anfang stets "_" |
|
try: |
queryList[arg]=query.split("=")[1] |
queryList[arg]=query.split("=")[1] |
|
except: |
|
queryList[arg]='' |
|
|
argList=[] |
argList=[] |
arg="" |
arg="" |
Line 1350 class ZSQLExtendFolder(Folder,Persistent
|
Line 1420 class ZSQLExtendFolder(Folder,Persistent
|
#something is defined by _op_TABELLE.SUCHFELD_IN_DIESER_TABELLE.SELECT_FIELD.IDENTIFIER_IN_TABELLE |
#something is defined by _op_TABELLE.SUCHFELD_IN_DIESER_TABELLE.SELECT_FIELD.IDENTIFIER_IN_TABELLE |
|
|
elif (not name[0]==iCT) and len(punktsplit)==4: |
elif (not name[0]==iCT) and len(punktsplit)==4: |
|
|
if opfields.has_key(name): |
if opfields.has_key(name): |
op=opfields[name] |
op=opfields[name] |
else: |
else: |
Line 1390 class ZSQLExtendFolder(Folder,Persistent
|
Line 1461 class ZSQLExtendFolder(Folder,Persistent
|
|
|
op="all" |
op="all" |
|
|
|
if value!='': #lehre Werte werde nicht hinzugefuegt |
searchTmp="""%s in (select %s from %s where %s)"""%(punktsplit[3],punktsplit[2],punktsplit[0],tmp) |
searchTmp="""%s in (select %s from %s where %s)"""%(punktsplit[3],punktsplit[2],punktsplit[0],tmp) |
|
|
queryTemplate.append(searchTmp) |
queryTemplate.append(searchTmp) |
Line 1440 class ZSQLExtendFolder(Folder,Persistent
|
Line 1511 class ZSQLExtendFolder(Folder,Persistent
|
|
|
op="all" |
op="all" |
|
|
if (not tableExt) or (namealt.split('.')[0]==tableExt): |
if (value!='') and ((not tableExt) or (namealt.split('.')[0]==tableExt)): #keine leeren werde und keine auschluss |
if searchFields.has_key(namealt): |
if searchFields.has_key(namealt): |
searchFields[namealt]+=lopfields.get(name,'OR')+" "+tmp |
searchFields[namealt]+=lopfields.get(name,'OR')+" "+tmp |
searchFieldsOnly[namealt]+=lopfields.get(name,'OR')+" "+value |
searchFieldsOnly[namealt]+=lopfields.get(name,'OR')+" "+value |