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


Golang rebecca.Context類代碼示例

本文整理匯總了Golang中github.com/waterlink/rebecca.Context的典型用法代碼示例。如果您正苦於以下問題:Golang Context類的具體用法?Golang Context怎麽用?Golang Context使用的例子?那麽, 這裏精選的類代碼示例或許可以為您提供幫助。


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

示例1: ExampleContext_All

func ExampleContext_All() {
	type Person struct {
		// ...
	}

	ctx := rebecca.Context{Limit: 20, Skip: 40}
	people := []Person{}
	if err := ctx.All(&people); err != nil {
		panic(err)
	}
	// At this point people contains 20 Person records starting from 41th from
	// the database.
	fmt.Print(people)
}
開發者ID:23inhouse,項目名稱:rebecca,代碼行數:14,代碼來源:context_test.go

示例2: ExampleContext_Where

func ExampleContext_Where() {
	type Person struct {
		// ...
	}

	ctx := rebecca.Context{Order: "age DESC"}
	teenagers := []Person{}
	if err := ctx.Where(&teenagers, "age < $1", 21); err != nil {
		panic(err)
	}
	// At this point teenagers will contain a list of Person records sorted by
	// age in descending order and where age < 21.
	fmt.Print(teenagers)
}
開發者ID:23inhouse,項目名稱:rebecca,代碼行數:14,代碼來源:context_test.go

示例3: ExampleContext_First

func ExampleContext_First() {
	type Person struct {
		// ...
	}

	ctx := rebecca.Context{Order: "age DESC"}
	oldestTeenager := &Person{}
	if err := ctx.First(oldestTeenager, "age < $1", 21); err != nil {
		panic(err)
	}
	// At this point oldestTeenager will contain a Person record that is of
	// maximum age and that is of age < 21.
	fmt.Print(oldestTeenager)
}
開發者ID:23inhouse,項目名稱:rebecca,代碼行數:14,代碼來源:context_test.go

示例4: TestGroup

func TestGroup(t *testing.T) {
	setup(t)

	p1 := &Person{Name: "John", Age: 9}
	p2 := &Person{Name: "Sarah", Age: 27}
	p3 := &Person{Name: "Bruce", Age: 27}
	p4 := &Person{Name: "James", Age: 11}
	p5 := &Person{Name: "Monika", Age: 11}
	p6 := &Person{Name: "Peter", Age: 21}
	p7 := &Person{Name: "Brad", Age: 11}
	people := []*Person{p1, p2, p3, p4, p5, p6, p7}

	for _, p := range people {
		if err := rebecca.Save(p); err != nil {
			t.Fatal(err)
		}
	}

	type PersonByAge struct {
		rebecca.ModelMetadata `tablename:"people"`

		Age   int `rebecca:"age" rebecca_primary:"true"`
		Count int `rebecca:"count(distinct(id))"`
	}

	ctx := rebecca.Context{Group: "age"}
	expected := []PersonByAge{
		{Age: 9, Count: 1},
		{Age: 11, Count: 3},
		{Age: 21, Count: 1},
		{Age: 27, Count: 2},
	}
	actual := []PersonByAge{}
	if err := ctx.All(&actual); err != nil {
		t.Fatal(err)
	}

	if !reflect.DeepEqual(actual, expected) {
		t.Errorf("Expected %+v to equal %+v", actual, expected)
	}
}
開發者ID:23inhouse,項目名稱:rebecca,代碼行數:41,代碼來源:pgdriver_test.go

示例5: ExampleModelMetadata

func ExampleModelMetadata() {
	type Person struct {
		// ModelMetadata allows to provide table name for the model
		rebecca.ModelMetadata `tablename:"people"`

		ID   int    `rebecca:"id" rebecca_primary:"true"`
		Name string `rebecca:"name"`
		Age  int    `rebecca:"age"`
	}

	type PostsOfPerson struct {
		// Additionally you can have any expression as a table name, that your
		// driver will allow, for example, simple join:
		rebecca.ModelMetadata `tablename:"people JOIN posts ON posts.author_id = people.id"`

		// .. fields are defined here ..
	}

	type PersonCountByAge struct {
		rebecca.ModelMetadata `tablename:"people"`

		// Additionally you can use any expressions as a database mapping for
		// fields, that your driver will allow, for example,
		// count(distinct(field_name)):
		Count int `rebecca:"count(distinct(id))"`
		Age   int `rebecca:"age"`
	}

	// PersonCountByAge is useful, because it can be nicely used with
	// aggregation:
	byAge := []PersonCountByAge{}
	ctx := rebecca.Context{Group: "age"}
	if err := ctx.All(&byAge); err != nil {
		panic(err)
	}

	// At this point byAge contains counts of people per each distinct age.
	// Ordering depends on your chosen driver and database.
	fmt.Print(byAge)
}
開發者ID:23inhouse,項目名稱:rebecca,代碼行數:40,代碼來源:metadata_test.go


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