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


Python peewee.IntegrityError方法代碼示例

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


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

示例1: put

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def put(self, rasp_result_ins):
        """
        將rasp_result_ins序列化並插入數據表

        Returns:
            插入成功返回True, 重複返回False

        Raises:
            exceptions.DatabaseError - 數據庫錯誤引發此異常
        """
        try:
            data = {
                "data": rasp_result_ins.dump(),
                "data_hash": rasp_result_ins.get_hash()
            }
            await peewee_async.create_object(self.ResultList, **data)
        except peewee.IntegrityError as e:
            return False
        except asyncio.CancelledError as e:
            raise e
        except Exception as e:
            Logger().critical("DB error in method put!", exc_info=e)
        else:
            return True 
開發者ID:baidu-security,項目名稱:openrasp-iast,代碼行數:26,代碼來源:new_request_model.py

示例2: test_unique_pairs

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def test_unique_pairs(add_doc, add_institution):

    """
    Don't allow duplicate links between the same doc -> inst pair.
    """

    inst = add_institution()

    doc = add_doc()

    Institution_Document.create(
        institution=inst,
        document=doc,
    )

    with pytest.raises(IntegrityError):

        Institution_Document.create(
            institution=inst,
            document=doc,
        ) 
開發者ID:davidmcclure,項目名稱:open-syllabus-project,代碼行數:23,代碼來源:test_indexes.py

示例3: test_unique_pairs

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def test_unique_pairs(add_subfield, add_doc):

    """
    Don't allow duplicate links between the same field -> document.
    """

    s = add_subfield()
    d = add_doc()

    Subfield_Document.create(
        subfield=s,
        document=d,
        offset=1,
        snippet='abc'
    )

    with pytest.raises(IntegrityError):

        Subfield_Document.create(
            subfield=s,
            document=d,
            offset=2,
            snippet='def'
        ) 
開發者ID:davidmcclure,項目名稱:open-syllabus-project,代碼行數:26,代碼來源:test_indexes.py

示例4: find_or_create_derived_storage

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def find_or_create_derived_storage(
    source_image, transformation_name, preferred_location, varying_metadata=None
):
    existing = find_derived_storage_for_image(source_image, transformation_name, varying_metadata)
    if existing is not None:
        return existing

    uniqueness_hash = _get_uniqueness_hash(varying_metadata)
    trans = ImageStorageTransformation.get(name=transformation_name)
    new_storage = storage.create_v1_storage(preferred_location)

    try:
        derived = DerivedStorageForImage.create(
            source_image=source_image,
            derivative=new_storage,
            transformation=trans,
            uniqueness_hash=uniqueness_hash,
        )
    except IntegrityError:
        # Storage was created while this method executed. Just return the existing.
        ImageStoragePlacement.delete().where(ImageStoragePlacement.storage == new_storage).execute()
        new_storage.delete_instance()
        return find_derived_storage_for_image(source_image, transformation_name, varying_metadata)

    return derived 
開發者ID:quay,項目名稱:quay,代碼行數:27,代碼來源:image.py

示例5: post

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def post(self):
        """
        Star a repository.
        """
        user = get_authenticated_user()
        req = request.get_json()
        namespace = req["namespace"]
        repository = req["repository"]
        repo = model.repository.get_repository(namespace, repository)

        if repo:
            try:
                model.repository.star_repository(user, repo)
            except IntegrityError:
                pass

            return {"namespace": namespace, "repository": repository,}, 201 
開發者ID:quay,項目名稱:quay,代碼行數:19,代碼來源:user.py

示例6: _attach_service

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def _attach_service(login_service, user_obj, lid, lusername):
    """
    Attaches the given user account to the given service, with the given service user ID and service
    username.
    """
    metadata = {
        "service_username": lusername,
    }

    try:
        model.user.attach_federated_login(
            user_obj, login_service.service_id(), lid, metadata=metadata
        )
        return _oauthresult(user_obj=user_obj)
    except IntegrityError:
        err = "%s account %s is already attached to a %s account" % (
            login_service.service_name(),
            lusername,
            app.config["REGISTRY_TITLE_SHORT"],
        )
        return _oauthresult(service_name=login_service.service_name(), error_message=err) 
開發者ID:quay,項目名稱:quay,代碼行數:23,代碼來源:login.py

示例7: get_or_create

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def get_or_create(cls, **kwargs):
        defaults = kwargs.pop('defaults', {})
        query = cls.select()
        for field, value in kwargs.items():
            query = query.where(getattr(cls, field) == value)

        try:
            result = await query.get(), False
        except cls.DoesNotExist:
            try:
                if defaults:
                    kwargs.update(defaults)
                with cls._meta.database.atomic():
                    result = await cls.create(**kwargs), True
            except IntegrityError as exc:
                try:
                    result = await query.get(), False
                except cls.DoesNotExist:
                    raise exc
        return result 
開發者ID:snower,項目名稱:torpeewee,代碼行數:22,代碼來源:model.py

示例8: write

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def write(self, stories, team=None):
        # TODO
        # this should be abstracted here and in spreadsheet.py
        new_stories = []
        for story in stories:
            try:
                story = Story.create(
                    name = story['name'],
                    slug = story['slug'],
                    date = story['date'],
                    url = story['url'],
                    team = team
                )
                new_stories.append(story)
            except IntegrityError:
                # Story probably already exists.
                logger.info('Not adding %s to database: probably already exists' % (story['name']))


        return new_stories 
開發者ID:thecarebot,項目名稱:carebot,代碼行數:22,代碼來源:rss.py

示例9: write

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def write(self, stories, team=None):
        """
        Save rows to the database
        """
        new_stories = []
        for story in stories:
            slug = story['official flavor description'] + ' - ' + story['taster']

            try:
                story = Story.create(
                    name=story['name'].strip(),
                    slug=slug,
                    date=PockyScraper.parse_date(story['date tasted']),
                    story_type='pocky',
                    team=team,
                )
                logger.info('Added {0}'.format(story.name))
                new_stories.append(story)
            except IntegrityError:
                # Story probably already exists.
                logger.info('Not adding %s to database: probably already exists' % (slug))
                pass

        return new_stories 
開發者ID:thecarebot,項目名稱:carebot,代碼行數:26,代碼來源:npr_pocky.py

示例10: get_or_create

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def get_or_create(cls, **kwargs):
        defaults = kwargs.pop('defaults', {})
        query = cls.select()
        for field, value in kwargs.items():
            if '__' in field:
                query = query.filter(**{field: value})
            else:
                query = query.where(getattr(cls, field) == value)

        try:
            return await query.get(), False
        except cls.DoesNotExist:
            try:
                params = dict((k, v) for k, v in kwargs.items()
                              if '__' not in k)
                params.update(defaults)

                async with cls._meta.database.atomic():
                    return await cls.create(**params), True
            except IntegrityError as exc:
                try:
                    return await query.get(), False
                except cls.DoesNotExist:
                    raise exc 
開發者ID:kszucs,項目名稱:aiopeewee,代碼行數:26,代碼來源:model.py

示例11: sync

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def sync(cls):
        """Sync cache by latest data"""

        def sync_tables(tables):
            for table in tables:
                table.sync()
                click.echo(".", nl=False, err=True)

        cache_table_map = cls.get_cache_tables()
        tables = list(cache_table_map.values())

        # Inserting version table at start
        tables.insert(0, Version)

        try:
            LOG.info("Updating cache", nl=False)
            sync_tables(tables)

        except (OperationalError, IntegrityError):
            click.echo(" [Fail]")
            # init db handle once (recreating db if some schema changes are there)
            LOG.info("Removing existing db and updating cache again")
            init_db_handle()
            LOG.info("Updating cache", nl=False)
            sync_tables(tables)
            click.echo(" [Done]", err=True) 
開發者ID:nutanix,項目名稱:calm-dsl,代碼行數:28,代碼來源:cache.py

示例12: create_single

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def create_single(self, model, kwargs):
    model = self.get_model(model)

    try:
      item = model.create(**kwargs)
    except IntegrityError:
      item = None

    return item 
開發者ID:jonian,項目名稱:kickoff-player,代碼行數:11,代碼來源:data.py

示例13: update_single

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def update_single(self, model, item, kwargs):
    model = self.get_model(model)

    try:
      kwargs['updated'] = now()

      query = model.update(**kwargs).where(model.id == item.id)
      query.execute()
    except IntegrityError:
      item = None

    return item 
開發者ID:jonian,項目名稱:kickoff-player,代碼行數:14,代碼來源:data.py

示例14: create

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def create(self, key, value, ttl=0):
    try:
      item = Cacheable.create(key=key, value=value.strip(), ttl=ttl)
    except IntegrityError:
      item = None

    return item 
開發者ID:jonian,項目名稱:kickoff-player,代碼行數:9,代碼來源:cache.py

示例15: update

# 需要導入模塊: import peewee [as 別名]
# 或者: from peewee import IntegrityError [as 別名]
def update(self, item, value, ttl=0):
    kwargs = {
      'value':   value.strip(),
      'ttl':     ttl,
      'updated': now()
    }

    try:
      query = Cacheable.update(**kwargs).where(Cacheable.key == item.key)
      query.execute()
    except IntegrityError:
      pass

    return item 
開發者ID:jonian,項目名稱:kickoff-player,代碼行數:16,代碼來源:cache.py


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