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


Golang LimitedTx.Query方法代碼示例

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


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

示例1: ReplaceBuildEventsIDWithEventID

func ReplaceBuildEventsIDWithEventID(tx migration.LimitedTx) error {
	_, err := tx.Exec(`ALTER TABLE build_events ADD COLUMN event_id integer`)
	if err != nil {
		return err
	}

	startIDs := map[int]int{}

	rows, err := tx.Query(`
		SELECT build_id, min(id)
		FROM build_events
		GROUP BY build_id
	`)
	if err != nil {
		return err
	}

	for rows.Next() {
		var buildID, id int
		err := rows.Scan(&buildID, &id)
		if err != nil {
			return err
		}

		startIDs[buildID] = id
	}

	err = rows.Close()
	if err != nil {
		return err
	}

	for buildID, id := range startIDs {
		_, err := tx.Exec(`
			UPDATE build_events
			SET event_id = id - $2
			WHERE build_id = $1
		`, buildID, id)
		if err != nil {
			return err
		}
	}

	_, err = tx.Exec(`ALTER TABLE build_events DROP COLUMN id`)
	if err != nil {
		return err
	}

	_, err = tx.Exec(`ALTER TABLE build_events ALTER COLUMN event_id SET NOT NULL`)
	if err != nil {
		return err
	}

	_, err = tx.Exec(`CREATE UNIQUE INDEX build_events_build_id_event_id ON build_events (build_id, event_id)`)
	if err != nil {
		return err
	}

	return nil
}
開發者ID:utako,項目名稱:atc,代碼行數:60,代碼來源:12_replace_build_events_id_with_event_id.go

示例2: AddNameToBuildInputs

func AddNameToBuildInputs(tx migration.LimitedTx) error {
	_, err := tx.Exec(`ALTER TABLE build_inputs ADD COLUMN name text`)
	if err != nil {
		return err
	}

	names := map[int]string{}

	rows, err := tx.Query(`
    SELECT i.versioned_resource_id, v.resource_name
    FROM build_inputs i, versioned_resources v
    WHERE v.id = i.versioned_resource_id
  `)
	if err != nil {
		return err
	}

	defer rows.Close()

	for rows.Next() {
		var vrID int
		var name string
		err := rows.Scan(&vrID, &name)
		if err != nil {
			return err
		}

		names[vrID] = name
	}

	for vrID, name := range names {
		_, err := tx.Exec(`
      UPDATE build_inputs
      SET name = $2
      WHERE versioned_resource_id = $1
    `, vrID, name)
		if err != nil {
			return err
		}
	}

	_, err = tx.Exec(`ALTER TABLE build_inputs ALTER COLUMN name SET NOT NULL`)
	if err != nil {
		return err
	}

	return nil
}
開發者ID:utako,項目名稱:atc,代碼行數:48,代碼來源:16_add_name_to_build_inputs.go

示例3: AddPipelineBuildEventsTables

func AddPipelineBuildEventsTables(tx migration.LimitedTx) error {

	_, err := tx.Exec(`
		ALTER TABLE build_events
		DROP CONSTRAINT build_events_build_id_fkey
	`)
	if err != nil {
		return fmt.Errorf("failed to update build events foreign key: %s", err)
	}

	rows, err := tx.Query(`SELECT id FROM pipelines`)
	if err != nil {
		return err
	}

	defer rows.Close()

	var pipelineIDs []int

	for rows.Next() {
		var pipelineID int
		err = rows.Scan(&pipelineID)
		if err != nil {
			return fmt.Errorf("failed to scan pipeline ID: %s", err)
		}

		pipelineIDs = append(pipelineIDs, pipelineID)
	}

	for _, pipelineID := range pipelineIDs {
		err = createBuildEventsTable(tx, pipelineID)
		if err != nil {
			return fmt.Errorf("failed to create build events table: %s", err)
		}

		err = populateBuildEventsTable(tx, pipelineID)
		if err != nil {
			return fmt.Errorf("failed to populate build events: %s", err)
		}
	}

	_, err = tx.Exec(`
		CREATE INDEX build_events_build_id_idx ON build_events (build_id);
		CREATE INDEX build_outputs_build_id_idx ON build_outputs (build_id);
		CREATE INDEX build_inputs_build_id_idx ON build_inputs (build_id);
		CREATE INDEX build_outputs_versioned_resource_id_idx ON build_outputs (versioned_resource_id);
		CREATE INDEX build_inputs_versioned_resource_id_idx ON build_inputs (versioned_resource_id);

		CREATE INDEX image_resource_versions_build_id_idx ON image_resource_versions (build_id);
		CREATE INDEX pipelines_team_id_idx ON pipelines (team_id);
		CREATE INDEX resources_pipeline_id_idx ON resources (pipeline_id);
		CREATE INDEX jobs_pipeline_id_idx ON jobs (pipeline_id);
		CREATE INDEX jobs_serial_groups_job_id_idx ON jobs_serial_groups (job_id);
		CREATE INDEX builds_job_id_idx ON builds (job_id);
		CREATE INDEX versioned_resources_resource_id_idx ON versioned_resources (resource_id);
	`)
	if err != nil {
		return fmt.Errorf("failed to create indexes: %s", err)
	}

	_, err = tx.Exec(`
		DELETE FROM ONLY build_events
		WHERE build_id IN (SELECT id FROM builds WHERE job_id IS NOT NULL)
	`)
	if err != nil {
		return fmt.Errorf("failed to clean up build events: %s", err)
	}

	return nil
}
開發者ID:pcfdev-forks,項目名稱:atc,代碼行數:70,代碼來源:80_add_pipeline_build_events_tables.go


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