MongoDB
 sql >> Cơ Sở Dữ Liệu >  >> NoSQL >> MongoDB

MongoDB $ acosh

Trong MongoDB, $acosh toán tử đường ống tổng hợp trả về arccosine hyperbol (cosin hyperbol nghịch đảo) của một giá trị, được đo bằng radian.

$acosh chấp nhận bất kỳ biểu thức hợp lệ nào phân giải thành một số giữa 1+Infinity .

$acosh toán tử đã được giới thiệu trong MongoDB 4.2.

Ví dụ

Giả sử chúng ta có một bộ sưu tập được gọi là test với tài liệu sau:

{ "_id" : 1, "data" : 3 }

Chúng ta có thể sử dụng $acosh toán tử để trả về arccosine hyperbolic của data lĩnh vực:

db.test.aggregate(
  [
    { $project: { 
        _id: 0,
        hyperbolicArccosine: { $acosh: "$data" }
      }
    }
  ]
)

Kết quả:

{ "hyperbolicArccosine" : 1.762747174039086 }

Theo mặc định, $acosh toán tử trả về các giá trị dưới dạng double , nhưng nó cũng có thể trả về giá trị dưới dạng số thập phân 128 bit miễn là biểu thức phân giải thành giá trị thập phân 128 bit.

Chuyển đổi sang độ

Như đã đề cập, $acosh trả về kết quả của nó theo đơn vị radian. Bạn có thể sử dụng $radiansToDegrees nếu bạn muốn kết quả bằng độ.

Ví dụ:

db.test.aggregate(
  [
    { $project: { 
        _id: 0,
        radians: { $acosh: "$data" },
        degrees: { $radiansToDegrees: { $acosh: "$data" } }
      }
    }
  ]
)

Kết quả:

{ "radians" : 1.762747174039086, "degrees" : 100.99797342105244 }

Trong ví dụ này, trường đầu tiên trình bày kết quả bằng radian và trường thứ hai trình bày kết quả bằng độ.

Giá trị ngoài phạm vi

Cung cấp giá trị nằm ngoài phạm vi cho $acosh sẽ dẫn đến lỗi.

Giả sử chúng ta thêm tài liệu sau vào bộ sưu tập:

{ "_id" : 2, "data" : 0 }

Bây giờ chúng ta hãy chạy $acosh chống lại dữ liệu data lĩnh vực:

db.test.aggregate(
  [
    { $match: { _id: 2 } },
    { $project: { 
        _id: 0,
        radians: { $acosh: "$data" }
      }
    }
  ]
)

Kết quả:

uncaught exception: Error: command failed: {
	"ok" : 0,
	"errmsg" : "cannot apply $acosh to 0, value must in [1,inf]",
	"code" : 50989,
	"codeName" : "Location50989"
} : aggregate failed :
[email protected]/mongo/shell/utils.js:25:13
[email protected]/mongo/shell/assert.js:18:14
[email protected]/mongo/shell/assert.js:618:17
[email protected]/mongo/shell/assert.js:708:16
[email protected]/mongo/shell/db.js:266:5
[email protected]/mongo/shell/collection.js:1046:12
@(shell):1:1

Như thông báo lỗi cho biết, giá trị phải nằm trong khoảng 1+Infinity .

Giá trị rỗng

Giá trị rỗng trả về null khi sử dụng $acosh nhà điều hành.

Giả sử chúng ta thêm tài liệu sau vào bộ sưu tập của mình:

{ "_id" : 3, "data" : null }

Hãy chạy $acos toán tử đối với tài liệu đó:

db.test.aggregate(
  [
    { $match: { _id: 3 } },
    { $project: { 
        _id: 0,
        result: { $acosh: "$data" }
      }
    }
  ]
)

Kết quả:

{ "result" : null }

Chúng ta có thể thấy rằng kết quả là null .

Giá trị NaN

Nếu đối số phân giải thành NaN , $acosh trả về NaN .

Ví dụ:

db.test.aggregate(
  [
    { $match: { _id: 3 } },
    { $project: { 
        _id: 0,
        result: { $acosh: 1 * "string" }
      }
    }
  ]
)

Kết quả:

{ "result" : NaN }

Trong trường hợp này, tôi đã cố gắng nhiều một số với một chuỗi, dẫn đến NaN được trả lại.

Vô cực

Nếu đối số phân giải thành Infinity , $acosh toán tử trả về Infinity .

Ví dụ:

db.test.aggregate(
  [
    { $match: { _id: 3 } },
    { $project: { 
        _id: 0,
        result: { $acosh: Infinity }
      }
    }
  ]
)

Kết quả:

{ "result" : Infinity }

Tuy nhiên, -Infinity sẽ trả về một lỗi.

Các trường không tồn tại

Nếu $acosh toán tử được áp dụng cho một trường không tồn tại, null được trả lại.

Ví dụ:

db.test.aggregate(
  [
    { $match: { _id: 3 } },
    { $project: { 
        _id: 0,
        result: { $acosh: "$wrongField" }
      }
    }
  ]
)

Kết quả:

{ "result" : null }

  1. Redis
  2.   
  3. MongoDB
  4.   
  5. Memcached
  6.   
  7. HBase
  8.   
  9. CouchDB
  1. MongoDB find ()

  2. MongoDB $ setIsSubset

  3. Cách kết nối Robomongo với MongoDB

  4. Các chế độ nhập của mongoimport

  5. Kết nối với MongoDB Atlas bằng Golang mgo:Liên tục không có máy chủ nào có thể truy cập được để đặt bản sao