2020实例时遇到哪些常见问题及解决方案-pymssql操作MSSQL

教程大全 2026-02-09 10:00:09 浏览

PyMSSQL数据库操作MSSQL 2012实例分析

简介

pymssql是一个纯Python编写的库,用于连接和操作Microsoft SQL Server数据库,本文将针对pymssql在MSSQL 2012实例上的操作进行详细分析,包括连接、查询、插入、更新和删除等基本操作。

连接MSSQL 2012实例

安装pymssql库

在Python环境中,首先需要安装pymssql库,可以使用pip命令进行安装:

pip install pymssql

连接MSSQL 2012实例

连接MSSQL 2012实例需要提供服务器地址、端口号、数据库用户名、密码等信息,以下是一个示例代码:

import pymssql# 连接MSSQL 2012实例conn = pymssql.connect(server='192.168.1.100', port=1433, user='username', password='password',)# 创建游标对象Cursor = conn.cursor()

查询操作

执行查询语句

使用游标对象执行查询语句,并获取查询结果,以下是一个示例代码:

# 执行查询语句cursor.execute("SELECT * From table_name")# 获取查询结果rows = cursor.fetchall()# 打印查询结果for row in rows:print(row)

使用参数化查询

为了防止SQL注入攻击,建议使用参数化查询,以下是一个示例代码:

# 执行参数化查询cursor.execute("SELECT * FROM table_name WHERE id = %s", (value,))# 获取查询结果rows = cursor.fetchall()# 打印查询结果for row in rows:print(row)

插入、更新和删除操作

插入操作

以下是一个示例代码,用于向表中插入一条数据:

# 插入数据cursor.execute("INSERT INTO table_name (column1, column2) VALUES (%s, %s)", (value1, value2))# 提交事务conn.commit()

更新操作

以下是一个示例代码,用于更新表中的一条数据:

# 更新数据cursor.execute("UPDATE table_name SET column1 = %s WHERE id = %s", (value1, value2))# 提交事务conn.commit()

删除操作

以下是一个示例代码,用于删除表中的一条数据:

# 删除数据cursor.execute("DELETE FROM table_name WHERE id = %s", (value,))# 提交事务conn.commit()

关闭连接

在完成数据库操作后,需要关闭游标和连接,释放资源,以下是一个示例代码:

# 关闭游标cursor.close()# 关闭连接conn.close()

问题:pymssql在连接MSSQL 2012实例时,出现“Cannot connect to server”错误。

MSSQL 解答:请检查以下问题:

(1)确保服务器地址、端口号、用户名、密码等信息正确无误;

(2)确保MSSQL 2012实例正在运行;

(3)确保防火墙设置允许连接到MSSQL 2012实例。

问题:在执行查询操作时,如何处理大量数据?

解答:在处理大量数据时,可以使用以下方法:

(1)使用分页查询,每次只查询一部分数据;

(2)使用游标逐行处理数据,避免一次性加载过多数据到内存中。


简述以太网和FDDI网的工作原理和数据传输过程

FDDI工作原理FDDI的工作原理主要体现在FDDI的三个工作过程中,这三个工作过程是:站点连接的建立、环初始化和数据传输。 1.站点连接的建立FDDI在正常运行时,站管理(SMT)一直监视着环路的活动状态,并控制着所有站点的活动。 站管理中的连接管理功能控制着正常站点建立物理连接的过程,它使用原始的信号序列在每对PHY/PMD之间的双向光缆上建立起端———端的物理连接,站点通过传送与接收这一特定的线路状态序列来辨认其相邻的站点,以此来交换端口的类型和连接规则等信息,并对连接质量进行测试。 在连接质量的测试过程中,一旦检测到故障,就用跟踪诊断的方法来确定故障原因,对故障事实隔离,并且在故障链路的两端重新进行网络配置。 2.环初始化在完成站点连接后,接下去的工作便是对环路进行初始化。 在进行具体的初始化工作之前,首先要确定系统的目标令牌循环时间(TTRT)。 各个站点都可借助请求帧(Claim Frame)提出各自的TTRT值,系统按照既定的竞争规则确定最终的TTRT值,被选中TTRT值的那个站点还要完成环初始化的具体工作。 确定TTRT值的过程通常称之为请求过程(Claim Process)。 (1) 请求过程请求过程用来确定TTRT值和具有初始化环权力的站点。 当一个或更多站点的媒体访问控制实体(MAC)进入请求状态时,就开始了请求过程。 在该状态下,每一个站点的MAC连续不断地发送请求帧(一个请求帧包含了该站点的地址和目标令牌循环时间的竞争值),环上其它站点接收到这个请求帧后,取出目标令牌循环时间竞争值并按如下规则进行比较:如果这个帧中的目标循环时间竞争值比自己的竞争值更短,该站点就重复这个请求帧,并且停止发送自己的请求帧;如果该帧中的TTRT值比自己的竞争值要长,该站点就删除这个请求帧,接着用自己的目标令牌循环时间作为新的竞争值发送请求帧。 当一个站点接受到自己的请求帧后,这个站点就嬴得了初始化环的权力。 如果两个或更多的站点使用相同的竞争值,那么具有最长源地址(48位地址与16位地址)的站点将优先嬴得初始化环的权力。 (2) 环初始化嬴得初始化环权力的站点通过发送一个令牌来初始化环路,这个令牌将不被网上其它站点捕获而通过环。 环上的其它站点在接收到该令牌后,将重新设置自己的工作参数,使本站点从初始化状态转为正常工作状态。 当该令牌回到源站点时,环初始化工作宣告结束,环路进入了稳定操作状态,各站点便可以进行正常的数据传送。 (3) 环初始化实例我们用图10-2来说明站点是如何通过协商来赢得对初始化环权力的。 在这个例子中,站点A、B、C、D协商决定谁赢得初始化环的权力。 ;图10-2 环初始化过程@@其协商过程如下:① 所有站点开始放出请求帧② 站点D收到目标令牌循环时间竞争值比它自己竞争值更短的站点C的请求帧,它停止发送自己的帧,向站点A转发站点C的请求帧。 与此同时:·站点B收到目标令牌循环时间竞争值比它自己竞争值更短的站点A的请求帧,停止发送自己的帧,向站点C发送站点A的请求帧。 ·站点C收到目标令牌循环时间竞争值比它自己竞争值更长的站点A的请求帧,继续发送自己的帧③ 站点A收到从站点D传过来的目标令牌循环时间竞争值比它自己竞争值更短的站点C的请求帧,它停止发送自己的帧,并发送站点D转发过来的站点C的请求帧给站点B④ 站点B收到从站点A传过来的目标令牌循环时间竞争值比它自己竞争值更短的站点C的请求帧,它停止发送自己的帧,并发送站点A转发过来的站点C的请求帧给站点C⑤ 站点C收到从站点B传过来的自己的请求帧,表示站点C已嬴得了初始化环的权力,请求过程宣告结束,站点C停止请求帧的传送,并产生一个初始化环的令令牌发送到环上,开始环初始化工作该协商过程以站点C赢得初始化环的权力而告终,网上其它站点A、B和D依据站点C的令牌初始化本站点的参数,待令牌回到站点C后,网络进入稳定工作状态,从此以后,网上各站点可以进行正常的数据传送工作。 以太网工作原理以太网是由Xeros公司开发的一种基带局域网技术,使用同轴电缆作为网络媒体,采用载波多路访问和碰撞检测(CSMA/CD)机制,数据传输速率达到10Mbps。 虽然以太网是由Xeros公司早在70年代最先研制成功,但是如今以太网一词更多的被用来指各种采用CSMA/CD技术的局域网。 以太网被设计用来满足非持续性网络数据传输的需要,而IEEE 802.3规范则是基于最初的以太网技术于1980年制定。 以太网版本2.0由Digital Equipment Corporation、Intel、和Xeros三家公司联合开发,与IEEE 802.3规范相互兼容。 以太网/IEEE 802.3通常使用专门的网络接口卡或通过系统主电路板上的电路实现。 以太网使用收发器与网络媒体进行连接。 收发器可以完成多种物理层功能,其中包括对网络碰撞进行检测。 收发器可以作为独立的设备通过电缆与终端站连接,也可以直接被集成到终端站的网卡当中。 以太网采用广播机制,所有与网络连接的工作站都可以看到网络上传递的数据。 通过查看包含在帧中的目标地址,确定是否进行接收或放弃。 如果证明数据确实是发给自己的,工作站将会接收数据并传递给高层协议进行处理。 以太网采用CSMA/CD媒体访问机制,任何工作站都可以在任何时间访问网络。 在发送数据之前,工作站首先需要侦听网络是否空闲,如果网络上没有任何数据传送,工作站就会把所要发送的信息投放到网络当中。 否则,工作站只能等待网络下一次出现空闲的时候再进行数据的发送。 作为一种基于竞争机制的网络环境,以太网允许任何一台网络设备在网络空闲时发送信息。 因为没有任何集中式的管理措施,所以非常有可能出现多台工作站同时检测到网络处于空闲状态,进而同时向网络发送数据的情况。 这时,发出的信息会相互碰撞而导致损坏。 工作站必须等待一段时间之后,重新发送数据。 补偿算法用来决定发生碰撞后,工作站应当在何时重新发送数据帧。

无法连接SQL server

/*引用*/ SQL Server连接中的四个最常见错误: 一 Server 不存在或访问被拒绝 这个是最复杂的,错误发生的原因比较多,需要检查的方面也比较多. 一般说来,有以下几种可能性: 1,SQL Server名称或IP地址拼写有误 2,服务器端网络配置有误 3,客户端网络配置有误 要解决这个问题,我们一般要遵循以下的步骤来一步步找出导致错误的原因. ============= 首先,检查网络物理连接 ============= ping <服务器ip地址 服务器名称> 如果 ping <服务器ip地址> 不成功,说明物理连接有问题,这时候要检查硬件设备,如网卡,HUB,路由器等. 还有一种可能是由于客户端和服务器之间安装有防火墙软件造成的,比如 ISA Server.防火墙软件可能会屏蔽对 ping,telnet 等的响应 因此在检查连接问题的时候,我们要先把防火墙软件暂时关闭,或者打开所有被封闭的端口. 如果ping <服务器ip地址> 成功而,ping <服务器名称> 失败 则说明名字解析有问题,这时候要检查 DNS 服务是否正常. 有时候客户端和服务器不在同一个局域网里面,这时候很可能无法直接使用服务器名称来标识该服务器,这时候我们可以使用hostS文件来进行名字解析, 具体的方法是: 1.使用记事本打开HOSTS文件(一般情况下位于C:\WINNT\system32\drivers\etc). 添加一条IP地址与服务器名称的对应记录,如: 172.168.10.24 myserver 2.或在 SQL Server 的客户端网络实用工具里面进行配置,后面会有详细说明. ============= 其次,使用 telnet 命令检查SQL Server服务器工作状态 ============= telnet <服务器ip地址> 1433 如果命令执行成功,可以看到屏幕一闪之后光标在左上角不停闪动,这说明 SQL Server 服务器工作正常,并且正在监听1433端口的 TCP/IP 连接 如果命令返回无法打开连接的错误信息,则说明服务器端没有启动 SQL Server 服务, 也可能服务器端没启用 TCP/IP 协议,或者服务器端没有在 SQL Server 默认的端口1433上监听. =============接着,我们要到服务器上检查服务器端的网络配置,检查是否启用了命名管道.是否启用了 TCP/IP 协议等等 ============= 可以利用 SQL Server 自带的服务器网络使用工具来进行检查. 点击:程序 -- Microsoft SQL Server -- 服务器网络使用工具 打开该工具后,在常规中可以看到服务器启用了哪些协议. 一般而言,我们启用命名管道以及 TCP/IP 协议. 点中 TCP/IP 协议,选择属性,我们可以来检查 SQK Server 服务默认端口的设置 一般而言,我们使用 SQL Server 默认的1433端口.如果选中隐藏服务器,则意味着客户端无法通过枚举服务器来看到这台服务器,起到了保护的作用,但不影响连接. ============= 接下来我们要到客户端检查客户端的网络配置 ============= 我们同样可以利用 SQL Server 自带的客户端网络使用工具来进行检查, 所不同的是这次是在客户端来运行这个工具. 点击:程序 -- Microsoft SQL Server -- 客户端网络使用工具 打开该工具后,在常规项中,可以看到客户端启用了哪些协议. 一般而言,我们同样需要启用命名管道以及 TCP/IP 协议. 点击 TCP/IP 协议,选择属性,可以检查客户端默认连接端口的设置,该端口必须与服务器一致. 单击别名选项卡,还可以为服务器配置别名.服务器的别名是用来连接的名称, 连接参数中的服务器是真正的服务器名称,两者可以相同或不同.别名的设置与使用HOSTS文件有相似之处. 通过以上几个方面的检查,基本上可以排除第一种错误. ----------------------------------------------------------------------------- 二.无法连接到服务器,用户xxx登陆失败 该错误产生的原因是由于SQL Server使用了仅 Windows的身份验证方式, 因此用户无法使用SQL Server的登录帐户(如 sa )进行连接.解决方法如下所示: 1.在服务器端使用企业管理器,并且选择使用 Windows 身份验证连接上 SQL Server 操作步骤: 在企业管理器中 --右键你的服务器实例(就是那个有绿色图标的) --编辑SQL Server注册属性 --选择使用windows身份验证 --选择使用SQL Server身份验证 --登录名输入sa,密码输入sa的密码 --确定 2.设置允许SQL Server身份登录 操作步骤: 在企业管理器中 --展开SQL Server组,鼠标右键点击SQL Server服务器的名称 --选择属性 --再选择安全性选项卡 --在身份验证下,选择SQL Server和 Windows . --确定,并重新启动SQL Server服务. 在以上解决方法中,如果在第 1 步中使用使用 Windows 身份验证连接 SQL Server 失败, 那就通过修改注册表来解决此问题: 1.点击开始-运行,输入regedit,回车进入注册表编辑器 2.依次展开注册表项,浏览到以下注册表键: [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLServer] 3.在屏幕右方找到名称LoginMode,双击编辑双字节值 4.将原值从1改为2,点击确定 5.关闭注册表编辑器 6.重新启动SQL Server服务. 也可用 USE [master] GO EXEC xp_instance_regwrite NHKEY_LOCAL_MACHINE, NSoftware\Microsoft\MSSQLServer\MSSQLServer, NLoginMode, REG_DWORD, 2 GO 再重新启动SQL Server服务. 此时,用户可以成功地使用sa在企业管理器中新建SQL Server注册, 但是仍然无法使用Windows身份验证模式来连接SQL Server. 这是因为在 SQL Server 中有两个缺省的登录帐户: BUILTIN\Administrators <机器名>\Administrator 被删除. 要恢复这两个帐户,可以使用以下的方法: 1.打开企业管理器,展开服务器组,然后展开服务器 2.展开安全性,右击登录,然后单击新建登录 3.在名称框中,输入 BUILTIN\Administrators 4.在服务器角色选项卡中,选择System Administrators 5.点击确定退出 6.使用同样方法添加 <机器名>\Administrator 登录. 说明: 以下注册表键: HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLServer\LoginMode 的值决定了SQL Server将采取何种身份验证模式. 1.表示使用Windows 身份验证模式 2.表示使用混合模式(Windows 身份验证和 SQL Server 身份验证). ----------------------------------------------------------------------------- 三.提示连接超时 如果遇到第三个错误,一般而言表示客户端已经找到了这台服务器,并且可以进行连接, 不过是由于连接的时间大于允许的时间而导致出错. 这种情况一般会发生在当用户在Internet上运行企业管理器来注册另外一台同样在Internet上的服务器, 并且是慢速连接时,有可能会导致以上的超时错误.有些情况下,由于局域网的网络问题,也会导致这样的错误. 要解决这样的错误,可以修改客户端的连接超时设置. 默认情况下,通过企业管理器注册另外一台SQL Server的超时设置是 4 秒, 而查询分析器是 15 秒(这也是为什么在企业管理器里发生错误的可能性比较大的原因). 具体步骤为: 企业管理器中的设置: 1.在企业管理器中,选择菜单上的工具,再选择选项 2.在弹出的SQL Server企业管理器属性窗口中,点击高级选项卡 3.在连接设置下的登录超时(秒)右边的框中输入一个比较大的数字,如 20. 查询分析器中的设置: 工具 -- 选项 -- 连接 -- 将登录超时设置为一个较大的数字 --------------------------------------------------------------------------------- 四.大部分机都用Tcp/ip才能成功,有次我发现用Named Pipes才可以? 这是因为在WINDOWS 2000以后的操作系统中,MS为解决SQL SERVER的安全问题将TCP/IP配置 为SQLSERVER的默认连接协议,你可以在CLIENT NETWORK UTILITY中看到TCP/IP和NAME PIPE 的顺序。 你也可以在: [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Client\SuperSocketNetLib] ProtocolOrder=hex(7):74,00,63,00,70,00,00,00,00,00 看到默认的协议。 2.怎么在程序中更改Named Pipes , Tcp/ip ,其sql语句怎么写? 你可以在上面提到的注册表的位置修改: CLIENT端: [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\Client\SuperSocketNetLib] ProtocolOrder=hex(7):74,00,63,00,70,00,00,00,00,00 SERVER端: [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\MSSQLServer\MSSQLServer\SuperSocketNetLib] ProtocolOrder=hex(7):74,00,63,00,70,00,00,00,00,00

网页制作相对路径绝对路径怎么回事

简单的说就是绝对路径换电脑后可能打不开网页,相对路径就是解决方法,用../代表上级文件夹

c:/website/web/xz/

c:/website/css/

联接文件 写作../../css/

本文版权声明本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请联系本站客服,一经查实,本站将立刻删除。

发表评论

热门推荐