當前位置: 首頁>>代碼示例>>Python>>正文


Python peewee.SQL屬性代碼示例

本文整理匯總了Python中peewee.SQL屬性的典型用法代碼示例。如果您正苦於以下問題:Python peewee.SQL屬性的具體用法?Python peewee.SQL怎麽用?Python peewee.SQL使用的例子?那麽, 這裏精選的屬性代碼示例或許可以為您提供幫助。您也可以進一步了解該屬性所在peewee的用法示例。


在下文中一共展示了peewee.SQL屬性的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: match_mysql

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def match_mysql(field, search_query):
    """
    Generates a full-text match query using a Match operation, which is needed for MySQL.
    """
    if field.name.find("`") >= 0:  # Just to be safe.
        raise Exception("How did field name '%s' end up containing a backtick?" % field.name)

    # Note: There is a known bug in MySQL (https://bugs.mysql.com/bug.php?id=78485) that causes
    # queries of the form `*` to raise a parsing error. If found, simply filter out.
    search_query = search_query.replace("*", "")

    # Just to be absolutely sure.
    search_query = search_query.replace("'", "")
    search_query = search_query.replace('"', "")
    search_query = search_query.replace("`", "")

    return NodeList(
        (fn.MATCH(SQL("`%s`" % field.name)), fn.AGAINST(SQL("%s", [search_query]))), parens=True
    ) 
開發者ID:quay,項目名稱:quay,代碼行數:21,代碼來源:text.py

示例2: count

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def count(query, clear_limit=False):
    """Perform *COUNT* aggregated query asynchronously.

    :return: number of objects in ``select()`` query
    """
    clone = query.clone()
    if query._distinct or query._group_by or query._limit or query._offset:
        if clear_limit:
            clone._limit = clone._offset = None
        sql, params = clone.sql()
        wrapped = 'SELECT COUNT(1) FROM (%s) AS wrapped_select' % sql
        raw = query.model.raw(wrapped, *params)
        return (await scalar(raw)) or 0
    else:
        clone._returning = [peewee.fn.Count(peewee.SQL('*'))]
        clone._order_by = None
        return (await scalar(clone)) or 0 
開發者ID:05bit,項目名稱:peewee-async,代碼行數:19,代碼來源:peewee_async.py

示例3: execute_sql

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def execute_sql(self, *args, **kwargs):
        """Sync execute SQL query, `allow_sync` must be set to True.
        """
        assert self._allow_sync, (
            "Error, sync query is not allowed! Call the `.set_allow_sync()` "
            "or use the `.allow_sync()` context manager.")
        if self._allow_sync in (logging.ERROR, logging.WARNING):
            logging.log(self._allow_sync,
                        "Error, sync query is not allowed: %s %s" %
                        (str(args), str(kwargs)))
        return super().execute_sql(*args, **kwargs)


##############
# PostgreSQL #
############## 
開發者ID:05bit,項目名稱:peewee-async,代碼行數:18,代碼來源:peewee_async.py

示例4: add_not_null

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def add_not_null(db, migrator, table, column_name, field):
    cmds = []
    compiler = db.compiler()
    if field.default is not None:
      # if default is a function, turn it into a value
      # this won't work on columns requiring uniquiness, like UUIDs
      # as all columns will share the same called value
      default = field.default() if hasattr(field.default, '__call__') else field.default
      op = pw.Clause(pw.SQL('UPDATE'), pw.Entity(table), pw.SQL('SET'), field.as_entity(), pw.SQL('='), default, pw.SQL('WHERE'), field.as_entity(), pw.SQL('IS NULL'))
      cmds.append(compiler.parse_node(op))
    if is_postgres(db) or is_sqlite(db):
      junk = migrator.add_not_null(table, column_name, generate=True)
      cmds += normalize_whatever_junk_peewee_migrations_gives_you(migrator, junk)
      return cmds
    elif is_mysql(db):
      op = pw.Clause(pw.SQL('ALTER TABLE'), pw.Entity(table), pw.SQL('MODIFY'), compiler.field_definition(field))
      cmds.append(compiler.parse_node(op))
      return cmds
    raise Exception('how do i add a not null for %s?' % db) 
開發者ID:keredson,項目名稱:peewee-db-evolve,代碼行數:21,代碼來源:peeweedbevolve.py

示例5: _execute

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def _execute(db, to_run, interactive=True, commit=True):
  if interactive: print()
  try:
    with db.atomic() as txn:
      for sql, params in to_run:
        if interactive or DEBUG: print_sql(' %s; %s' % (sql, params or ''))
        if sql.strip().startswith('--'): continue
        db.execute_sql(sql, params)
      if interactive:
        print()
        print(
          (colorama.Style.BRIGHT + 'SUCCESS!' + colorama.Style.RESET_ALL) if commit else 'TEST PASSED - ROLLING BACK',
          colorama.Style.DIM + '-',
          'https://github.com/keredson/peewee-db-evolve' + colorama.Style.RESET_ALL
        )
        print()
      if not commit:
        txn.rollback()
  except Exception as e:
    print()
    print('------------------------------------------')
    print(colorama.Style.BRIGHT + colorama.Fore.RED + ' SQL EXCEPTION - ROLLING BACK ALL CHANGES' + colorama.Style.RESET_ALL)
    print('------------------------------------------')
    print()
    raise e 
開發者ID:keredson,項目名稱:peewee-db-evolve,代碼行數:27,代碼來源:peeweedbevolve.py

示例6: prefix_search

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def prefix_search(field, prefix_query):
    """
    Returns the wildcard match for searching for the given prefix query.
    """
    # Escape the known wildcard characters.
    prefix_query = _escape_wildcard(prefix_query)
    return Field.__pow__(field, NodeList((prefix_query + "%", SQL("ESCAPE '!'")))) 
開發者ID:quay,項目名稱:quay,代碼行數:9,代碼來源:text.py

示例7: match_like

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def match_like(field, search_query):
    """
    Generates a full-text match query using an ILIKE operation, which is needed for SQLite and
    Postgres.
    """
    escaped_query = _escape_wildcard(search_query)
    clause = NodeList(("%" + escaped_query + "%", SQL("ESCAPE '!'")))
    return Field.__pow__(field, clause) 
開發者ID:quay,項目名稱:quay,代碼行數:10,代碼來源:text.py

示例8: count

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def count(self, database, clear_limit=False):
        clone = self.order_by().alias('_wrapped')
        if clear_limit:
            clone._limit = clone._offset = None
        try:
            if clone._having is None and clone._windows is None and \
                            clone._distinct is None and clone._simple_distinct is not True:
                clone = clone.select(SQL('1'))
        except AttributeError:
            pass
        return Select([clone], [fn.COUNT(SQL('1'))]).scalar(database) 
開發者ID:snower,項目名稱:torpeewee,代碼行數:13,代碼來源:query.py

示例9: exists

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def exists(self, database):
        clone = self.columns(SQL('1'))
        clone._limit = 1
        clone._offset = None
        return bool((await clone.scalar())) 
開發者ID:snower,項目名稱:torpeewee,代碼行數:7,代碼來源:query.py

示例10: _run_sql

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def _run_sql(database, operation, *args, **kwargs):
    """Run SQL operation (query or command) against database.
    """
    __log__.debug((operation, args, kwargs))

    with peewee.__exception_wrapper__:
        cursor = await database.cursor_async()

        try:
            await cursor.execute(operation, *args, **kwargs)
        except:
            await cursor.release()
            raise

        return cursor 
開發者ID:05bit,項目名稱:peewee-async,代碼行數:17,代碼來源:peewee_async.py

示例11: default_insert_clause

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def default_insert_clause(self, model_class):
        return SQL('DEFAULT VALUES') 
開發者ID:kszucs,項目名稱:aiopeewee,代碼行數:4,代碼來源:database.py

示例12: test_select_all

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def test_select_all(flushdb):
    await create_users_blogs(2, 2)
    all_cols = SQL('*')
    query = Blog.select(all_cols)
    blogs = [blog async for blog in query.order_by(Blog.pk)]
    assert [b.title for b in blogs] == ['b-0-0', 'b-0-1', 'b-1-0', 'b-1-1']
    assert [(await b.user).username for b in blogs] == ['u0', 'u0', 'u1', 'u1'] 
開發者ID:kszucs,項目名稱:aiopeewee,代碼行數:9,代碼來源:test_models.py

示例13: exists

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def exists(self):
        clone = self.paginate(1, 1)
        clone._select = [SQL('1')]
        return bool(await clone.scalar()) 
開發者ID:kszucs,項目名稱:aiopeewee,代碼行數:6,代碼來源:query.py

示例14: set_default

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def set_default(db, migrator, table_name, column_name, field):
    default = field.default
    if callable(default): default = default()
    migration = ( migrator.make_context()
      .literal('UPDATE ').sql(pw.Entity(table_name))
      .literal(' SET ').sql(pw.Expression(pw.Entity(column_name), pw.OP.EQ, field.db_value(default), flat=True))
      .literal(' WHERE ').sql(pw.Expression(pw.Entity(column_name), pw.OP.IS, pw.SQL('NULL'), flat=True))
    )
    return extract_query_from_migration(migration) 
開發者ID:keredson,項目名稱:peewee-db-evolve,代碼行數:11,代碼來源:peeweedbevolve.py

示例15: drop_table

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import SQL [as 別名]
def drop_table(migrator, table_name):
    compiler = migrator.database.compiler()
    return [compiler.parse_node(pw.Clause(pw.SQL('DROP TABLE'), pw.Entity(table_name)))] 
開發者ID:keredson,項目名稱:peewee-db-evolve,代碼行數:5,代碼來源:peeweedbevolve.py


注:本文中的peewee.SQL屬性示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。