我编写了一个服务,它从目录中读取XML文件,从数据中创建对象并将数据传递到数据库中。我之前有这个工作,但由于某种原因,该服务现在创建一个表行,但它自动插入0到数据库而不是XML文件中的数据。我的代码如下:
此Web服务方法触发XMLloader
类:
[WebMethod]
public void RunService()
{
//Call XML loader to get collection of XML documents
foreach (GamePlay value in XMLLoader.Start())
{
value.addNewGamePlay();
}
//call inject data method for each collection
}
此XMLLoader
类返回GamePlay
个对象的数组:
public static Array Start()
{
string[] filePaths = Directory.GetFiles(@"C:\Users\bradleya\Desktop\XML\");
List<GamePlay> gameObj = new List<GamePlay>();
foreach (string value in filePaths)
{
XmlDocument xd = new XmlDocument();
xd.Load(value);
XmlNode documentNode = xd.SelectSingleNode("/GamePlayData/GamePlay");
GamePlay newGame = new GamePlay();
newGame.setType(Convert.ToString(documentNode.SelectSingleNode("type").InnerText));
newGame.setGamePlayID(Convert.ToInt32(documentNode.SelectSingleNode("GamePlayID").InnerText));
newGame.setParticipantID(Convert.ToInt32(documentNode.SelectSingleNode("ParticipantID").InnerText));
newGame.setGameVersionID(Convert.ToInt32(documentNode.SelectSingleNode("GameVersionID").InnerText));
newGame.setGameID(Convert.ToInt32(documentNode.SelectSingleNode("GameID").InnerText));
newGame.setGameScenarioID(Convert.ToInt32(documentNode.SelectSingleNode("GameScenarioID").InnerText));
newGame.setStartDateTime(Convert.ToDateTime(documentNode.SelectSingleNode("Start").InnerText));
newGame.setEndDateTime(Convert.ToDateTime(documentNode.SelectSingleNode("End").InnerText));
newGame.setSuccess(Convert.ToBoolean(documentNode.SelectSingleNode("Success").InnerText));
gameObj.Add(new GamePlay(gameObj));
}
return gameObj.ToArray();
}
在将对象变量传递给数据访问层的对象类中触发此方法:
public void addNewGamePlay()
{
// dataaccess method call to add GamePlay
// (from the DB) is then set for the object
DataAccessConn.createNewGamePlay(this.ParticipantID, this.GameVersionID, this.GameID, this.GameScenarioID, this.StartDateTime, this.EndDateTime, this.success);
}
最后,数据通过数据访问层方法传递到数据库中:
public static void createNewGamePlay(int ParticipantID, int GameVersionID,int GameID,int GameSenarioID,DateTime Start,DateTime End,Boolean success)
{
SqlConnection oConn = new SqlConnection();
oConn.ConnectionString = @"Data Source=SNICKERS\SQLEXPRESS;Initial Catalog=VervePhaseOne;Integrated Security=True";
oConn.Open();
SqlCommand cmd = new SqlCommand();
cmd.Connection = oConn;
cmd.CommandType = CommandType.StoredProcedure;
cmd.CommandText = "addGamePlay";
cmd.Parameters.Add(new SqlParameter("@ParticipantID", SqlDbType.Int));
cmd.Parameters["@ParticipantID"].Value = ParticipantID;
cmd.Parameters.Add(new SqlParameter("@GameVersionID", SqlDbType.Int));
cmd.Parameters["@GameVersionID"].Value = GameVersionID;
cmd.Parameters.Add(new SqlParameter("@GameID", SqlDbType.Int));
cmd.Parameters["@GameID"].Value = GameID;
cmd.Parameters.Add(new SqlParameter("@GameScenarioID", SqlDbType.Int));
cmd.Parameters["@GameScenarioID"].Value = GameSenarioID;
cmd.Parameters.Add(new SqlParameter("@Start", SqlDbType.DateTime));
cmd.Parameters["@Start"].Value = DateTime.Now;
cmd.Parameters.Add(new SqlParameter("@End", SqlDbType.DateTime));
cmd.Parameters["@End"].Value = DateTime.Now;
cmd.Parameters.Add(new SqlParameter("@success", SqlDbType.Bit));
cmd.Parameters["@success"].Value = success;
cmd.ExecuteNonQuery();
}
我试图传递的XML文件是:
<?xml version="1.0" encoding="utf-8" ?>
<GamePlayData>
<GamePlay>
<type>add</type>
<GamePlayID>1</GamePlayID>
<ParticipantID>1</ParticipantID>
<GameVersionID>1</GameVersionID>
<GameID>1</GameID>
<GameScenarioID>1</GameScenarioID>
<Start>22/01/2012 23:59:59</Start>
<End>22/01/2012 23:59:59</End>
<Success>False</Success>
</GamePlay>
</GamePlayData>
只是为了澄清 - 我的问题是我的服务是创建一个表行但是变量自动设置为0.任何人都知道为什么这将来自代码?
提前致谢。
编辑 - 添加了请求的商店程序,谢谢
CREATE PROCEDURE [dbo].[addGamePlay]
@ParticipantID int,
@GameVersionID int,
@GameID int,
@GameScenarioID int,
@Start dateTime,
@End dateTime,
@Success varchar(10)
AS
INSERT INTO GamePlay(ParticipantID,GameVersionID,GameID,GameScenarioID,StartDateTime,EndDateTime,Success)
VALUES (@ParticipantID,@GameVersionID,@GameID,@GameScenarioID,@Start,@End,@Success)
return @@identity
答案 0 :(得分:1)
在您从XML文件中保存后,您似乎没有将newGame
添加到列表中:
gameObj.Add(new GamePlay(gameObj));
我认为应该是:
gameObj.Add(newGame);
答案 1 :(得分:1)
在你的array.Start方法应该这一行:
gameObj.Add(new GamePlay(gameObj));
是:
gameObj.Add(newGame);
答案 2 :(得分:0)
我认为你遇到0或者null的所有地方都是简单的int类型
发生这种情况是因为.Net中的值类型不能为空值,实际上0是int的空值
所以您应该将GamePlay
类的定义从使用int
更改为int?
或Nullable<int>