求距离最小值的SQL语句
SQL 语句获取最值例子 最大 最小

+--------+----------+---------+----------+
| emp_id | emp_name | dept_id | emp_wage |
+--------+----------+---------+----------+
| 1007 | ad | 1 | 12000 |
--------------------------------------------------------------------------------
1:列出工资大于500,emp_wage,dept_name from employee as e inner join department as d on e.dept_id=d.dept_id where e.emp_wage>5000 group by e.emp_id;
| 软件开发部 | 10000.0000 |
| 销售部 | 3200.0000 |
+------------+------------+
SQL--Server--常用公式与函数整理

SQL--Server常用公式与函数整理一、算术运算符SQL*Server*支持基本的算术运算符,如加(+)、减(-)、乘()、除(/)和取余(%)等。
这些运算符可以直接在*SQL*查询中使用,用于数字和日期类型的数据计算。
示例:sqlSELECT*5+3AS加法结果;--输出结果为8SELECT*10-5AS减法结果;--输出结果为5SELECT*32AS乘法结果;--输出结果为6SELECT*10/2AS除法结果;--输出结果为5SELECT*11%2AS取余结果;--输出结果为1二、字符串函数字符串函数主要用于字符串的处理和操作,包括截取、连接、查找、替换、转换等。
常用的字符串函数有:*LEN(string_expression):返回字符串的长度。
*LEFT(string_expression,*number_of_chars):返回字符串最左侧的指定数量的字符。
*RIGHT(string_expression,*number_of_chars):返回字符串最右侧的指定数量的字符。
*SUBSTRING(string_expression,*start,*length):返回字符串的子字符串。
*CHARINDEX(substring,*expression*[,*start_location]):返回子字符串在表达式中的起始位置。
REPLACE(string_expression,*search_string,*replacement_string):在字符串中替换指定的子字符串。
*LOWER(string_expression):将字符串转换为小写。
*UPPER(string_expression):将字符串转换为大写。
示例:sqlSELECT*LEN('Hello*World')*AS*字符串长度;*--*输出结果为*11SELECT*LEFT('Hello*World',*5)*AS*左侧子串;*--*输出结果为*Hello三、日期函数日期函数用于日期和时间的处理和计算,常用的日期函数有:*GETDATE():返回当前日期和时间。
sql经纬度距离计算公式

sql经纬度距离计算公式
经纬度距离计算是一个地理坐标系统中非常常用的运算,而sql经纬度距离计算就是使用sql语句来实现计算两个经纬度点之间的距离的方法,一般都是使用haversine公式来实现的,这种公式是地理学家们发明出来的,计算方式如下:R = 6371 // 地球半径
lat1 = 维度1
lon1 = 经度1
lat2 = 维度2
lon2 = 经度2
dlon = 差值
dlat = 差值
a = (sin(dlat/2))^2 + cos(lat1) * cos(lat2) * (sin(dlon/2))^2
c = 2 *atan2(sqrt(a), sqrt(1-a))
d = R *c
其中R代表地球半径,lat1 、lon1和lat2、lon2为两个经纬度点的坐标,dlon和dlat为两个坐标的经纬度差值,最后得出的距离单位为千米(KM)。
它可以计算出相应的经纬度两地之间的实际距离,因此普遍应用于快递服务,比如计算两地货运距离。
在sql中还可以使用一些函数来实现这个计算公式:
(sin(dlat/2))^ 2 + cos(lat1) *cos(lat2) *
(sin(dlon/2))^ 2)
可以用
Pow(Sin(((lat2-lat1) / 2)), 2) + Cos(lat1) * Cos(lat2) * Pow(Sin(((lon2-lon1)/2)),2)
来表示,最后再用Sqrt函数求平方根,即可得到两个经纬度之间的距离,这种计算公式的精度可以达到10米,因此它比简单的估计算法更加精确。
SQL数据库语句大全大全(完全整理版)之欧阳引擎创编

SQL语句大全欧阳引擎(2021.01.01)--语句功能--数据操作SELECT --从数据库表中检索数据行和列INSERT --向数据库表添加新数据行DELETE --从数据库表中删除数据行UPDATE --更新数据库表中的数据-数据定义CREATE TABLE --创建一个数据库表DROP TABLE --从数据库中删除表ALTER TABLE --修改数据库表结构CREATE VIEW --创建一个视图DROP VIEW --从数据库中删除视图CREATE INDEX --为数据库表创建一个索引DROP INDEX --从数据库中删除索引CREATE PROCEDURE --创建一个存储过程DROP PROCEDURE --从数据库中删除存储过程CREATE TRIGGER --创建一个触发器DROP TRIGGER --从数据库中删除触发器CREATE SCHEMA --向数据库添加一个新模式DROP SCHEMA --从数据库中删除一个模式CREATE DOMAIN --创建一个数据值域ALTER DOMAIN --改变域定义DROP DOMAIN --从数据库中删除一个域--数据控制GRANT --授予用户访问权限DENY --拒绝用户访问REVOKE --解除用户访问权限--事务控制COMMIT --结束当前事务ROLLBACK --中止当前事务SET TRANSACTION --定义当前事务数据访问特征--程序化SQLDECLARE --为查询设定游标EXPLAN --为查询描述数据访问计划OPEN --检索查询结果打开一个游标FETCH --检索一行查询结果CLOSE --关闭游标PREPARE --为动态执行准备SQL 语句EXECUTE --动态地执行SQL 语句DESCRIBE --描述准备好的查询---局部变量declare @id char(10)--set @id = '10010001'select @id = '10010001' ---全局变量---必须以@@开头--IF ELSEdeclare @x int @y int @z intselect @x = 1 @y = 2 @z=3if @x > @yprint 'x > y' --打印字符串'x > y'else if @y > @zprint 'y > z'else print 'z > y'--CASEuse panguupdate employeeset e_wage =casewhen job_level = ’1’ then e_wage*1.08when job_level = ’2’ then e_wage*1.07when job_level = ’3’ then e_wage*1.06else e_wage*1.05end--WHILE CONTINUE BREAKdeclare @x int @y int @c intselect @x = 1@y=1while @x < 3beginprint @x --打印变量x 的值while @y <3beginselect @c = 100*@x + @yprint @c --打印变量c 的值select @y = @y + 1endselect @x = @x + 1select @y = 1end--WAITFOR--例等待1 小时2 分零3 秒后才执行SELECT 语句waitfordelay ’01:02:03’select * from employee--例等到晚上11 点零8 分后才执行SELECT 语句waitfor time ’23:08:00’select * from employee***SELECT***select *(列名) from table_name(表名) where column_name operator valueex:(宿主)select * fromstock_information where stockid = str(nid)stockname = 'str_name'stockname like '% find this %' stockname like '[a-zA-Z]%' --------- ([]指定值的范围)stockname like '[^F-M]%' --------- (^排除指定范围)--------- 只能在使用like关键字的where子句中使用通配符)or stockpath = 'stock_path'or stocknumber < 1000and stockindex =24not stock*** = 'man'stocknumber between 20 and100stocknumber in(10,20,30)order by stockid desc(asc) --------- 排序,desc-降序,asc-升序order by 1,2 --------- by列号stockname = (select stockname from stock_information where stockid = 4)--------- 子查询--------- 除非能确保内层select只返回一个行的值,--------- 否则应在外层where子句中用一个in限定符select distinct column_name form table_name --------- distinct指定检索独有的列值,不重复select stocknumber ,"stocknumber + 10" = stocknumber + 10 from table_nameselect stockname , "stocknumber" = count(*) from table_name group by stockname--------- group by 将表按行分组,指定列中有相同的值having count(*) = 2 --------- having选定指定的组select * from table1, table2 where table1.id *= table2.id -------- 左外部连接,table1中有的而table2中没有得以null表示table1.id =* table2.id -------- 右外部连接select stockname from table1union [all] ----- union合并查询结果集,all-保留重复行select stockname from table2***insert***insert into table_name (Stock_name,Stock_number) value ("xxx","xxxx")value (select Stockname , Stocknumber from Stock_table2)---value为select语句***update***update table_name set Stockname = "xxx" [where Stockid = 3]Stockname = defaultStockname = nullStocknumber = Stockname + 4***delete***delete from table_name where Stockid = 3truncate table_name ----------- 删除表中所有行,仍保持表的完整性drop table table_name --------------- 完全删除表***alter table*** --- 修改数据库表结构alter table database.owner.table_name add column_name char(2) null .....sp_help table_name ---- 显示表已有特征create table table_name (name char(20), age smallint, lname varchar(30))insert into table_name select ......... ----- 实现删除列的方法(创建新表)alter table table_name drop constraint Stockname_default ---- 删除Stockname的default约束***function(/*常用函数*/)***----统计函数----AVG --求平均值COUNT --统计数目MAX --求最大值MIN --求最小值SUM --求和--AVGuse panguselect avg(e_wage) as dept_avgWagefrom employeegroup by dept_id--MAX--求工资最高的员工姓名use panguselect e_namefrom employeewhere e_wage =(selectmax(e_wage)from employee)--STDEV()--STDEV()函数返回表达式中所有数据的标准差--STDEVP()--STDEVP()函数返回总体标准差--VAR()--VAR()函数返回表达式中所有值的统计变异数--VARP()--VARP()函数返回总体变异数----算术函数----/***三角函数***/SIN(float_expression) --返回以弧度表示的角的正弦COS(float_expression) --返回以弧度表示的角的余弦TAN(float_expression) --返回以弧度表示的角的正切COT(float_expression) --返回以弧度表示的角的余切/***反三角函数***/ASIN(float_expression) --返回正弦是FLOAT 值的以弧度表示的角ACOS(float_expression) --返回余弦是FLOAT 值的以弧度表示的角ATAN(float_expression) --返回正切是FLOAT 值的以弧度表示的角ATAN2(float_expression1,float_expression2) --返回正切是float_expression1 /float_expres-sion2的以弧度表示的角DEGREES(numeric_expression)--把弧度转换为角度返回与表达式相同的数据类型可为--INTEGER/MONEY/REAL/FLOAT 类型RADIANS(numeric_expression) --把角度转换为弧度返回与表达式相同的数据类型可为--INTEGER/MONEY/REAL/FLOAT 类型EXP(float_expression) --返回表达式的指数值LOG(float_expression) --返回表达式的自然对数值LOG10(float_expression)--返回表达式的以10 为底的对数值SQRT(float_expression) --返回表达式的平方根/***取近似值函数***/CEILING(numeric_expression) --返回>=表达式的最小整数返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型FLOOR(numeric_expression) --返回<=表达式的最小整数返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型ROUND(numeric_expression) --返回以integer_expression 为精度的四舍五入值返回的数据--类型与表达式相同可为INTEGER/MONEY/REAL/FLOAT 类型ABS(numeric_expression) --返回表达式的绝对值返回的数据类型与表达式相同可为--INTEGER/MONEY/REAL/FLOAT 类型SIGN(numeric_expression) --测试参数的正负号返回0 零值1 正数或-1 负数返回的数据类型--与表达式相同可为INTEGER/MONEY/REAL/FLOAT 类型PI() --返回值为π 即3.1415926535897936RAND([integer_expression]) --用任选的[integer_expression]做种子值得出0-1 间的随机浮点数----字符串函数----ASCII() --函数返回字符表达式最左端字符的ASCII 码值CHAR() --函数用于将ASCII 码转换为字符--如果没有输入0 ~ 255 之间的ASCII 码值CHAR 函数会返回一个NULL 值LOWER() --函数把字符串全部转换为小写UPPER() --函数把字符串全部转换为大写STR() --函数把数值型数据转换为字符型数据LTRIM() --函数把字符串头部的空格去掉RTRIM() --函数把字符串尾部的空格去掉LEFT(),RIGHT(),SUBSTRING() --函数返回部分字符串CHARINDEX(),PATINDEX() --函数返回字符串中某个指定的子串出现的开始位置SOUNDEX() --函数返回一个四位字符码--SOUNDEX函数可用来查找声音相似的字符串但SOUNDEX函数对数字和汉字均只返回0 值DIFFERENCE() --函数返回由SOUNDEX 函数返回的两个字符表达式的值的差异--0 两个SOUNDEX 函数返回值的第一个字符不同--1 两个SOUNDEX 函数返回值的第一个字符相同--2 两个SOUNDEX 函数返回值的第一二个字符相同--3 两个SOUNDEX 函数返回值的第一二三个字符相同--4 两个SOUNDEX 函数返回值完全相同QUOTENAME() --函数返回被特定字符括起来的字符串/*select quotename('abc', '{') quotename('abc')运行结果如下----------------------------------{{abc} [abc]*/REPLICATE() --函数返回一个重复character_expression 指定次数的字符串/*select replicate('abc', 3) replicate( 'abc', -2)运行结果如下----------- -----------abcabcabc NULL*/REVERSE() --函数将指定的字符串的字符排列顺序颠倒REPLACE() --函数返回被替换了指定子串的字符串/*select replace('abc123g', '123', 'def')运行结果如下----------- -----------abcdefg*/SPACE() --函数返回一个有指定长度的空白字符串STUFF() --函数用另一子串替换字符串指定位置长度的子串----数据类型转换函数----CAST() 函数语法如下CAST()(<expression> AS <data_ type>[ length ])CONVERT() 函数语法如下CONVERT() (<data_ type>[ length ], <expression> [, style])select cast(100+99 as char) convert(varchar(12), getdate())运行结果如下------------------------------ ------------199 Jan 15 2000----日期函数----DAY() --函数返回date_expression 中的日期值MONTH() --函数返回date_expression 中的月份值YEAR() --函数返回date_expression 中的年份值DATEADD(<datepart> ,<number> ,<date>) --函数返回指定日期date 加上指定的额外日期间隔number 产生的新日期DATEDIFF(<datepart> ,<number> ,<date>)--函数返回两个指定日期在datepart 方面的不同之处DATENAME(<datepart> , <date>) --函数以字符串的形式返回日期的指定部分DATEPART(<datepart> , <date>) --函数以整数值的形式返回日期的指定部分GETDATE() --函数以DATETIME 的缺省格式返回系统当前的日期和时间----系统函数----APP_NAME() --函数返回当前执行的应用程序的名称COALESCE() --函数返回众多表达式中第一个非NULL 表达式的值COL_LENGTH(<'table_name'>, <'column_name'>) --函数返回表中指定字段的长度值COL_NAME(<table_id>, <column_id>) --函数返回表中指定字段的名称即列名DATALENGTH() --函数返回数据表达式的数据的实际长度DB_ID(['database_name']) --函数返回数据库的编号DB_NAME(database_id) --函数返回数据库的名称HOST_ID() --函数返回服务器端计算机的名称HOST_NAME() --函数返回服务器端计算机的名称IDENTITY(<data_type>[, seed increment]) [AS column_name])--IDENTITY() 函数只在SELECT INTO 语句中使用用于插入一个identity column列到新表中/*select identity(int, 1, 1) as column_nameinto newtablefromoldtable*/ISDATE() --函数判断所给定的表达式是否为合理日期ISNULL(<check_expression>, <replacement_value>) --函数将表达式中的NULL 值用指定值替换ISNUMERIC() --函数判断所给定的表达式是否为合理的数值NEWID() --函数返回一个UNIQUEIDENTIFIER 类型的数值NULLIF(<expression1>,<expression2>)--NULLIF 函数在expression1 与expression2 相等时返回NULL 值若不相等时则返回expression1 的值sql中的保留字action add aggregate all alter after and as asc avgavg_row_length auto_increment between bigint bit binary blob bool both by cascade case char character change check checksum column columns comment constraint create cross current_date current_time current_timestamp data database databases date datetime dayday_hour day_minute day_second dayofmonth dayofweek dayofyear dec decimal default delayed delay_key_write delete desc describe distinct distinctrow double drop end else escape escaped enclosed enum explain exists fields file first float float4 float8 flush foreign from for full function global grant grants group having heaphigh_priority hour hour_minute hour_second hosts identified ignore in index infile inner insert insert_id int integer interval int1 int2 int3 int4 int8 into if is isam join key keys kill last_insert_id leading left length like lines limit load local lock logs long longblob longtext low_priority max max_rows match mediumblob mediumtext mediumint middleint min_rows minute minute_second modify month monthname myisam natural numeric no not null on optimize option optionally or order outer outfile pack_keys partial password precision primary procedure process processlist privileges read realreferences reload regexp rename replace restrict returns revoke rlike row rows second select set show shutdown smallint sonamesql_big_tables sql_big_selects sql_low_priority_updates sql_log_off sql_log_update sql_select_limit sql_small_result sql_big_resultsql_warnings straight_join starting status string table tables temporary terminated text then time timestamp tinyblob tinytext tinyint trailing to type use using unique unlock unsigned update usage values varchar variables varying varbinary with write when where year year_month zerofill查看全文常用SQL命令和ASP编程在进行数据库操作时,无非就是添加、删除、修改,这得设计到一些常用的SQL语句,如下:SQL常用命令使用方法:(1) 数据记录筛选:sql="select * from 数据表 where 字段名=字段值order by 字段名 [desc]"sql="select * from 数据表 where 字段名like %字段值% order by 字段名 [desc]"sql="select top 10 * from 数据表 where 字段名 order by 字段名 [desc]"sql="select * from 数据表 where 字段名 in (值1,值2,值3)"sql="select * from 数据表where 字段名 between 值1 and 值2"(2) 更新数据记录:sql="update 数据表 set 字段名=字段值 where 条件表达式"sql="update 数据表 set 字段1=值1,字段2=值2 …… 字段n=值n where 条件表达式"(3) 删除数据记录:sql="delete from 数据表where 条件表达式"sql="delete from 数据表" (将数据表所有记录删除)(4) 添加数据记录:sql="insert into 数据表 (字段1,字段2,字段3 …) valuess (值1,值2,值3 …)"sql="insert into 目标数据表select * from 源数据表" (把源数据表的记录添加到目标数据表)(5) 数据记录统计函数:AVG(字段名) 得出一个表格栏平均值COUNT(*|字段名) 对数据行数的统计或对某一栏有值的数据行数统计MAX(字段名) 取得一个表格栏最大的值MIN(字段名) 取得一个表格栏最小的值SUM(字段名) 把数据栏的值相加引用以上函数的方法:sql="select sum(字段名) as 别名 from 数据表where 条件表达式"set rs=conn.excute(sql)用 rs("别名") 获取统的计值,其它函数运用同上。
oracle最小函数

oracle最小函数一、概述Oracle是一款非常流行的关系型数据库管理系统,其强大的功能和可靠的性能使得它成为了众多企业和组织中首选的数据库解决方案。
在Oracle中,函数是一种非常重要的编程元素,可以让开发人员快速地实现各种复杂的数据处理和计算操作。
本文将介绍Oracle中最小函数的使用方法和注意事项。
二、最小函数概述最小函数(MIN)是Oracle中一种非常基础且常用的函数,用于返回指定列或表达式中最小值。
该函数可以用于任何数据类型,包括数值、日期、字符串等等。
下面是MIN函数的语法:MIN(expression)其中expression可以是一个列名、一个表达式或者一个子查询。
三、使用MIN函数1. 返回单个列的最小值如果要返回某个表格中某个列的最小值,可以使用以下语法:SELECT MIN(column_name) FROM table_name;例如,我们有一个students表格,其中有两个字段id和age:id age1 202 223 184 255 19如果我们想要获取age字段中最小值,则可以执行以下SQL语句:SELECT MIN(age) FROM students;结果将会是18。
2. 返回多个列的最小值如果要返回某个表格中多个列的最小值,则可以使用以下语法:SELECT MIN(column_name1), MIN(column_name2), ... FROM table_name;例如,我们有一个students表格,其中有三个字段id、age和score:id age score1 20 802 22 903 18 854 25 755 19 95如果我们想要获取age和score字段中的最小值,则可以执行以下SQL语句:SELECT MIN(age), MIN(score) FROM students;结果将会是18和75。
3. 使用子查询返回最小值如果要使用子查询返回某个表格中某个列的最小值,则可以使用以下语法:SELECT MIN(expression) FROM (subquery);例如,我们有一个students表格,其中有两个字段id和age,并且还有一个classes表格,其中有两个字段id和name。
mysql分组取出每组最小一条数据的函数

mysql分组取出每组最小一条数据的函数在MySQL中,可以使用子查询和JOIN语句来获取每个分组中的最小一条数据。
方法一:使用子查询可以使用子查询来获取每个分组中的最小值,然后将此查询结果与原始表进行JOIN操作,从而得到每个分组的最小一条数据。
下面是一个示例查询:sqlSELECT t1.*FROM your_table t1JOIN (SELECT group_id, MIN(value) AS min_valueFROM your_tableGROUP BY group_id) t2 ON t1.group_id = t2.group_id AND t1.value = t2.min_value;上述查询首先使用子查询获取每个分组(group_id)中的最小值(min_value),然后将结果与原始表进行JOIN操作,通过group_id和value进行连接,从而得到每个分组的最小一条数据。
方法二:使用NOT EXISTS子查询还可以使用NOT EXISTS子查询来获取每个分组中的最小一条数据。
下面是一个示例查询:sqlSELECT t1.*FROM your_table t1WHERE NOT EXISTS (SELECT 1FROM your_table t2WHERE t1.group_id = t2.group_id AND t2.value < t1.value);上述查询使用NOT EXISTS子查询来检查是否存在比当前行更小的值。
如果不存在,则说明当前行是该分组中的最小值,因此可以包含在结果中。
这两种方法都可以用于获取每个分组的最小一条数据,具体使用哪种方法取决于数据量和查询性能的需求。
在实际应用中,需要根据具体情况选择合适的方法。
需要注意的是,上述示例中的`your_table`是一个占位符,实际使用时需要将其替换为你自己的表名。
此外,还可以根据具体需求添加其他条件来进一步筛选数据。
mysql两个经纬度距离计算方法

mysql两个经纬度距离计算方法摘要:1.MySQL中计算两点经纬度距离的函数2.常用算法简介3.示例代码及说明正文:在MySQL中,我们可以通过一些常用函数来计算两个经纬度之间的距离。
本文将介绍两种常用的计算方法,并给出示例代码。
1.MySQL中计算两点经纬度距离的函数MySQL提供了`ACOS()`和`ATAN()`这两个函数,可以用来计算两点之间的距离。
此外,我们还需要用到`PI()`函数将结果转换为弧度。
2.常用算法简介(1)haversine算法Haversine算法是一种基于球面距离的计算方法,可以较为精确地计算两点之间的距离。
该算法通过计算两个经纬度之间的大圆距离来得到结果。
(2)Great-circle算法大圆算法是一种基于球面的最短路径算法,可以用来计算两点之间的大圆距离。
该算法使用球面三角公式进行计算。
3.示例代码及说明以下是一个使用MySQL计算两点经纬度距离的示例代码:```sqlSELECTFLOOR(6371 * ACOS(COS(RADIANS(lat1)) * COS(RADIANS(lat2)) *COS(RADIANS(lng1) - RADIANS(lng2)) +SIN(RADIANS(lat1)) * SIN(RADIANS(lat2)))) AS distanceFROMlocationsWHERElat1 = 31.230499999999996AND lng1 = 121.47379999999999AND lat2 = 31.230499999999996AND lng2 = 121.47379999999999;```在这个示例中,我们首先定义了两个经纬度坐标(31.230499999999996, 121.47379999999999)。
然后使用Haversine算法计算两点之间的距离。
最后,将结果四舍五入并返回。
注意:在实际应用中,可以根据需要对算法进行优化和调整。
sql 中distance用法

sql 中distance用法SQL中distance用法1. 简介在SQL中,distance是用来计算两个地理位置之间的距离的函数。
它可以用于判断附近的位置、计算两点之间的直线距离等等。
2. 使用方法下面列举了一些常见的distance函数的用法:•ST_Distance: 这个函数通常配合ST_GeographyFromText或ST_GeographyFromEwkt函数一起使用,用于计算两个地理位置之间的距离。
示例:SELECT ST_Distance(ST_GeographyFromText('POINT( -)'),ST_GeographyFromText('POINT( -)')) As distance;这个例子会计算出纬度为,经度为-的点到纬度为,经度为-的点之间的距离。
•ST_Distance_Sphere: 这个函数同样需要配合ST_GeographyFromText或ST_GeographyFromEwkt函数使用,用于计算两个地理位置之间的球面距离。
示例:SELECT ST_Distance_Sphere(ST_GeographyFromText('POINT( -)'),ST_GeographyFromText('POINT( -)')) As di stance;这个例子会计算出纬度为,经度为-的点到纬度为,经度为-的点之间的球面距离。
•ST_Distance_Spheroid: 这个函数的参数比较复杂,需要传入地球的长半径、短半径和椭球体的扁率(flattening),一般使用预定义的椭球体参数。
示例:SELECT ST_Distance_Spheroid(ST_GeographyFromText('POINT( -)'),ST_GeographyFromText('POINT( -)'),'SPHEROID["GRS 1980",,]') As distance;这个例子会计算出纬度为,经度为-的点到纬度为,经度为-的点之间的椭球体距离。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
求距离最小值的SQL语句
题目要求:数据库存储了位置信息(经度和纬度),现有某个位置,找出与数据库已有位置最近的位置。
题目限制,数据库中的位置信息特别多。
创建表:
但是当数据库中数据量很大时,效率会下降很多。
基于这数据量很大,可以预设一个阀值,在某个阀值范围内查找。
例如阀值设为2,即给定位置与数据库里位置经度或纬度之差不大于2时,再找出最小距离。
以上对距离的计算是基于范围较小的区域,并且假设地面是平的,而经度纬度是平面坐标的基础上。
事实上,基于经纬度计算距离的方法(C#实现)。