如何用SQL Server 2005存储过程实现IP地址归属地查询
发表于:2025-11-07 作者:千家信息网编辑
千家信息网最后更新 2025年11月07日,这篇文章主要介绍"如何用SQL Server 2005存储过程实现IP地址归属地查询",在日常操作中,相信很多人在如何用SQL Server 2005存储过程实现IP地址归属地查询问题上存在疑惑,小编
千家信息网最后更新 2025年11月07日如何用SQL Server 2005存储过程实现IP地址归属地查询
这篇文章主要介绍"如何用SQL Server 2005存储过程实现IP地址归属地查询",在日常操作中,相信很多人在如何用SQL Server 2005存储过程实现IP地址归属地查询问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答"如何用SQL Server 2005存储过程实现IP地址归属地查询"的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
1、用C#来做DLL,代码如下:
usingSystem;usingSystem.Collections.Generic;usingSystem.Text;usingSystem.Data.SqlTypes;usingSystem.Data.SqlClient;usingMicrosoft.SqlServer.Server;publicclassAddrInfo[Microsoft.SqlServer.Server.SqlProcedure]publicstaticvoidgetAddrInfo(SqlStringip,outSqlStringinfo)using(SqlConnectionconnection=newSqlConnection("contextconnection=true"))//IP地址转为数字string[]tmp=ip.Value.Split(newstring[]{"."},StringSplitOptions.None);Int64ipn=ToInt(ToBinary(tmp[0])+ToBinary(tmp[1])+ToBinary(tmp[2])+ToBinary(tmp[3]));connection.Open();SqlCommandcmd=newSqlCommand();cmd.Connection=connection;cmd.CommandType=System.Data.CommandType.Text;cmd.CommandText="selectaddr_infofromCZIPwhereipn1<="+ipn.tostring()+"andipn2>="+ipn.ToString();SqlDataReaderdr=cmd.ExecuteReader();using(dr)if(dr.Read())info=dr.GetString(0);elseinfo="<无归属地数据>";}}//////INT32转为二进制字符串/////////privatestaticStringToBinary(stringnum)intpiNumber=Int32.Parse(num);stringstrBinary="";intiTmp;doiTmp=piNumber%2;strBinary=iTmp.ToString()+strBinary;piNumberpiNumber=piNumber/2;}while(piNumber!=0);returnstrBinary.PadLeft(8,'0');}////////////privatestaticlongToInt(stringpStrBinary)char[]charArr=pStrBinary.ToCharArray();longiReturnValue=0;intiPow=0;for(inti=0;i怎样用SQLServer2005存储过程实现IP地址归属地查询
2、将编译后的DLL放到SQLSERVER2005所在的服务器上,假设路径为c:\clr\ipLib.dll以下方法注册程序集。
CREATEASSEMBLY[ipLib]FROM'c:\clr\ipLib.dll'
3、创建存储过程
CREATEPROCEDUREget_ip_addr_info@ipnvarchar(20),@infonvarchar(500)OUTPUTASEXTERNALNAMEipLib.AddrInfo.getAddrInfo
之后你就可以看到名为get_ip_addr_info的存储过程,调用方法与普通T/SQL存储过程相同。
到此,关于"如何用SQL Server 2005存储过程实现IP地址归属地查询"的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注网站,小编会继续努力为大家带来更多实用的文章!
过程
存储
地址
归属
查询
学习
方法
更多
帮助
实用
普通
相同
接下来
二进制
代码
字符
字符串
所在
数字
文章
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
检测重点人群数据库多久更新一次
scie数据库怎么翻译成中文
服务器清扫
网络安全的单选题
服务器系统不激活会影响使用吗
武汉电商erp软件开发
网络安全案例演讲
启明星网络安全学院
网络技术攻防技术认知
qt增删sqlsever数据库
找到程序调用的数据库表名字
光遇怎么总是弹出服务器错误
选择题网络安全性划分abcd
学好数据库可以做什么
软件开发风险登记册
糖醋鱼小说软件开发
软件开发行业中美对比
海致网络技术有限公司靠谱吗
分型线app提示连接服务器失败
软件开发服务合同6
湖北美彼互联网科技有限公司
软件开发精益改善点
联想sr588服务器管理界面
平台服务器维护升级费用
非关系型数据库 特点
数据库2000英文版新建表
上海数据网络技术分类技术
江西标准软件开发批发
北京金弘博软件开发有限公司
深圳知之为网络技术有限公司