- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我正在尝试使用zxJDBC连接到在SQL Server 2008 R2(Express)上运行的数据库并调用存储过程,并向其传递单个参数。我正在使用jython-standalone 2.5.3,理想情况下,不想安装其他模块。
我的测试代码如下所示。
数据库名称为CSM
存储过程:
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
-- =============================================
-- Author: <Author,,Name>
-- Create date: <Create Date,,>
-- Description: <Description,,>
-- =============================================
CREATE PROCEDURE dbo.DUMMY
-- Add the parameters for the stored procedure here
@carrierId VARCHAR(50)
AS
BEGIN
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON;
-- Insert statements for procedure here
INSERT INTO dbo.carrier (carrierId, test)
VALUES (@carrierId, 'Success')
END
GO
from com.ziclix.python.sql import zxJDBC
conn = None
try :
conn = zxJDBC.connect('jdbc:sqlserver://localhost\SQLEXPRESS', 'sa', 'password', 'com.microsoft.sqlserver.jdbc.SQLServerDriver')
cur = conn.cursor()
cur.callproc(('CSM','dbo','DUMMY'), ['carrier1'])
conn.commit()
except Exception, err :
print err
if conn:
conn.rollback()
finally :
if conn :
conn.close()
cur.execute()
,我已经能够验证以上内容是否已成功连接到数据库,并且可以对其进行查询。但是,到目前为止,我一直无法成功调用带参数的存储过程。
callproc()
来标识过程。给出的示例-
c.callproc(("northwind", "dbo", "SalesByCategory"), ["Seafood", "1998"], maxrows=2)
Error("Could not find stored procedure 'CSM.DUMMY'. [SQLCode: 2812], [SQLState: S00062]",)
dbo
部分包括在内。
callproc
,那么我会收到此错误
Error('An object or column name is missing or empty. For SELECT INTO statements, verify each column has a name. For other statements, look for empty alias names. Aliases defined as "" or [] are not allowed. Change the alias to a valid name. [SQLCode: 1038], [SQLState: S0004]',)
use []
go
cur.callproc(('CSM', '', 'dbo.DUMMY'), ['carrier1'])
Error("Procedure or function 'DUMMY' expects parameter '@carrierId', which was not supplied. [SQLCode: 201], [SQLState: S0004]",)
sp_proc_columns
)来确定我要调用的存储过程所需的参数。我的猜测是,如果使用上面错误格式的过程标识符,zxJDBC将不会获得有效/正确的返回值,并且假定不需要任何参数。
cur.execute('EXEC CSM.dbo.DUMMY ?', ['carrier1'])
callproc()
是正确的解决方案,当我使用大量参数调用存储过程时,可能会生成更简洁的代码。
cur.execute('USE CSM')
(也从过程调用中删除了数据库名称)。不幸的是,这会产生与上述相同的“对象或列丢失”错误。探查器显示正在执行的
USE CSM
,然后显示
USE []
,因此似乎callproc()总是在过程本身之前触发
USE
语句。
;databaseName=CSM;
指定为here),并将其从callproc()调用中省略会导致原始错误,并触发USE []
语句。 callproc(('CSM', 'dbo', 'dbo.DUMMY'), ['carrier1'])
给了我一些进步,但会导致错误
use CSM
go
exec sp_sproc_columns_100 N'dbo.DUMMY',N'dbo',N'CSM',NULL,N'3'
go
exec sp_sproc_columns_100 N'DUMMY',N'dbo',N'CSM',NULL,N'3'
dbo
所有者,或者根本找不到该过程。
CREATE TABLE [dbo].[carrier](
[carrierId] [varchar](50) NOT NULL,
[test] [varchar](50) NULL
) ON [PRIMARY]
最佳答案
尽管完全不了解此处使用的技术(除非对SQL Server有一些了解),但我将尝试给出答案(如果我的jython语法不正确,请原谅我。我试图在此处概述不完全正确的代码的可能性)
我的第一种方法(位于this post)是尝试:
cur.execute("use CSM")
cur.callproc(("CSM","dbo","dbo.DUMMY"), ["carrier1"])
sa
用户始终将
dbo
作为默认模式有关(在
this SO post中进行了描述)。
CSM
数据库名称(在将JDBC用于其他数据库时,这是很常见的),然后简单地调用以下两个方法之一。
cur.callproc("DUMMY", ["carrier1"])
cur.callproc("dbo.DUMMY", ["carrier1"])
>> Program calls a Stored Procedure - master.dbo.xp_fixeddrives on MS SQL Server
from com.ziclix.python.sql import zxJDBC
def getConnection():
url = "${DBServer.Url}"
user= "${DBServer.User}"
password = "${DBServer.Password}"
driver = "${DBServer.Driver}"
con = zxJDBC.connect(url, user, password, driver)
return con
try:
conn = getConnection()
print 'Connection successful'
cur = conn.cursor()
cur.execute("use master")
cur.callproc(("master", "dbo", "dbo.xp_fixeddrives"))
print cur.description
for a in cur.fetchall():
print a
finally:
cur.close()
conn.close()
print 'Connection closed'
params = [None]
进行调用。如果您看到调用成功,那么就指定数据库而言,我们必须做的正确。
关于java - zxjdbc调用存储过程的正确用法是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18055993/
我从 http://www.jython.org/archive/21/docs/zxjdbc.html 获取官方示例: Oracle >>> c = db.cursor() # open the d
我正在使用 JDBC 将我的 jython 连接到一组异构数据库。使用游标我得到列表形式的行,和游标还知道元数据 (cursor.description)。 通常您会得到一行作为查询结果的列表: pr
因为我想将我最近的 Minecraft Python/Jython Bukkit 插件的数据存储从平面文件转换为 MySQL 数据库,所以我开始谷歌搜索。为 Python 尝试了 sqlite3 和
我正在尝试通过 netbeans IDE 中 jython 的 zxJDBC 包连接到数据库。我已经指定了 zxJDBC.jar 和驱动程序的路径: 并不断收到错误消息: zxJDBC.Databas
我使用 com.ziclix.python.sql 包在 Jython 中对 SQL 数据库进行编程。我想知道该包是否在其准备好的语句中支持 SQL INSERT/UPDATE 语句,您可以在其中传递
我是一名优秀的程序员,十分优秀!