Skip to main content

Geography Data Type – SQL Server

    Geography data type in SQL Server is a useful tool for storing and manipulating geographic data. It provides a set of functions and tools for working with geographical data, such as points, lines, and polygons. In this blog, we will explore the Geography data type in SQL Server with examples.

Introduction to Geography data type

Geography data type is a built-in data type in SQL Server that is designed to support the storage, manipulation, and analysis of geographic data. It is based on the Open Geospatial Consortium (OGC) Simple Feature Access specification, which provides a standard way to represent geographic data in a database.

The Geography data type in SQL Server stores data in a geographic coordinate system, allowing you to represent points on the surface of the earth using longitude and latitude coordinates. You can also represent lines and polygons by defining a series of points that define the shape of the line or polygon.

Creating a Geography data type in SQL Server

To create a Geography data type in SQL Server, you can use the "geography" keyword and specify the coordinate system you want to use. For example, to create a Geography data type with the WGS 84 coordinate system, you can use the following code:

CREATE TABLE MyGeographyData

(

  ID INT PRIMARY KEY,

  Location GEOGRAPHY

);

 

Inserting data into a Geography data type

To insert data into a Geography data type in SQL Server, you can use the "STGeomFromText" function to convert a string representation of the geographic data into a Geography data type. For example, to insert a point with the longitude -122.33 and latitude 47.61 into a Geography data type, you can use the following code:

INSERT INTO MyGeographyData (ID, Location)

VALUES (1, geography::STGeomFromText('POINT(-122.33 47.61)', 4326));

 

Querying data from a Geography data type

Once you have data stored in a Geography data type, you can use SQL Server's built-in spatial functions to query and manipulate the data. For example, you can use the "STDistance" function to calculate the distance between two points. The following code calculates the distance between the point stored in our MyGeographyData table and the point with the longitude -122.34 and latitude 47.62:

SELECT Location.STDistance(geography::STPointFromText('POINT(-122.34 47.62)', 4326)) AS Distance

FROM MyGeographyData;

 

This will return the distance between the two points in meters.

Conclusion

Geography data type in SQL Server is a powerful tool for working with geographic data. By using the Geography data type and the built-in spatial functions, you can store, manipulate, and analyze geographic data in your database. The examples provided in this blog are just a few examples of how you can use the Geography data type in your SQL Server applications.

Comments

Popular posts from this blog

Data type precedence - SQL Server

       In SQL Server, data type precedence determines which data type takes precedence over others when two or more data types are combined or compared. It is important to understand data type precedence to ensure that the correct data type is used and that data is not lost or truncated during operations. In this blog, we will discuss data type precedence in SQL Server with examples. Data type precedence levels SQL Server has 16 data type precedence levels, with the highest level being 1 and the lowest level being 16. The data type with the lowest precedence is considered to be the "weakest" data type and is most likely to be converted to a higher precedence data type during operations. Here is the list of data types in SQL Server, ordered by their precedence levels: user-defined data types (highest precedence) sql_variant xml datetimeoffset datetime2 datetime smalldatetime date time float real decimal/numeric money/smallmoney bigint/i...

Synonyms, Trigger & Sequences - SQL Server

  Synonyms In SQL Server, a synonym is an alternative name for a database object, such as a table, view, stored procedure, or function. Synonyms can be useful for simplifying complex object names, abstracting the underlying object structure, or providing a layer of indirection between objects and their callers. Creating a synonym in SQL Server is straightforward. Here's an example:               CREATE SYNONYM MyTable FOR AdventureWorks2019 . dbo . MyTable ; In this example, we're creating a synonym called MyTable that points to a table called MyTable in the AdventureWorks2019 database. Now, instead of referring to the table as AdventureWorks2019.dbo.MyTable, we can simply use the synonym name MyTable. To modify a synonym in SQL Server, you can use the ALTER SYNONYM statement. Here's an example:               ALTER SYNONYM MyTable RENA...

Table Data Type- SQL Server

       In SQL Server, the table data type is a structured data type that allows you to define a table as a variable. It can be useful in scenarios where you need to store data temporarily or pass data between stored procedures or functions. In this blog, we will explore the table data type in SQL Server and provide an example of how it can be used. Introduction to the table data type The table data type is a structured data type that allows you to define a table as a variable. It can be used to store data temporarily or pass data between stored procedures or functions. The table variable behaves like a regular table in SQL Server, but it is stored in memory rather than on disk. Creating a table variable in SQL Server To create a table variable in SQL Server, you need to declare the variable and define the table structure. The following code demonstrates how to declare a table variable and define the table structure: DECLARE @MyTable TABLE (   ...