不允许从数据类型sql_variant到uniqueidentifier的隐式转换。使用CONVERT函数运行此查询

时间:2011-06-25 15:57:05

标签: asp.net sql-server

我正在使用Microsoft Visual Web Developer 2010 Express创建一个网站,我使用了"createUserWizard"的工具箱。然后我将userId表的"CustomerInfo"放到"data type=uniqueidentifier",因为我需要将它链接到aspnet_表中的用户名。

稍后,我需要将"Order"表格与"CustomerInfo"表格相关联,因此我将orderId data type=uniqueidentifier置于其中。然后,我计划将我的订单详细信息插入"Order"表,但我有以下问题:

  

“从数据类型隐式转换   sql_variant到uniqueidentifier不是   允许。使用CONVERT函数   运行此查询“。

我搜索并找到一些答案,例如参数设置为“空”的数据类型或删除它。但后来我有这个错误

  

“从字符串转换为uniqueidentifier时转换失败。”

这是我的SQL

<asp:SqlDataSource ID="SqlDataSource1" runat="server" ConnectionString="<%$ ConnectionStrings:ConnectionString %>" 
                                    DeleteCommand="DELETE FROM [Order] WHERE [orderId] = @orderId" 
                                    InsertCommand="INSERT INTO [Order] ([orderId], [userId], [Services], [PickUpDate], [PickUpTime], [SpecialDate], [SpecialTime]) VALUES (@orderId, @userId, @Services, @PickUpDate, @PickUpTime, @SpecialDate, @SpecialTime)" 
                                    SelectCommand="SELECT * FROM [Order]" 

                                    UpdateCommand="UPDATE [Order] SET [userId] = @userId, [Services] = @Services, [PickUpDate] = @PickUpDate, [PickUpTime] = @PickUpTime, [SpecialDate] = @SpecialDate, [SpecialTime] = @SpecialTime WHERE [orderId] = @orderId">
                                    <DeleteParameters>
                                        <asp:Parameter Name="orderId" Type="Object" />
                                    </DeleteParameters>
                                    <InsertParameters>
                                    <asp:Parameter Name="orderId" Type="Object" />
                                    <asp:Parameter Name="userId" Type="Object" />
                                        <asp:Parameter Name="Services" Type="String" />
                                        <asp:Parameter Name="PickUpDate" Type="String" />
                                        <asp:Parameter Name="PickUpTime" Type="String" />
                                        <asp:Parameter Name="SpecialDate" Type="String" />
                                        <asp:Parameter Name="SpecialTime" Type="String" />
                                    </InsertParameters>
                                    <UpdateParameters>
                                        <asp:Parameter Name="userId" Type="Object" />
                                        <asp:Parameter Name="Services" Type="String" />
                                        <asp:Parameter Name="PickUpDate" Type="String" />
                                        <asp:Parameter Name="PickUpTime" Type="String" />
                                        <asp:Parameter Name="SpecialDate" Type="String" />
                                        <asp:Parameter Name="SpecialTime" Type="String" />
                                        <asp:Parameter Name="orderId" Type="Object" />
                                    </UpdateParameters>
                                </asp:SqlDataSource>

现在我想起来了,也许我的代码在vb中存在问题。 我会把它放在这里,请告诉我如何正确地将数据插入数据库。

Protected Sub OrderButton_Click(ByVal sender As Object, ByVal e As System.EventArgs) Handles OrderButton.Click
    SqlDataSource1.InsertParameters(0).DefaultValue = Now
    SqlDataSource1.Insert()
    Response.Redirect("~/Customer/AfterOrder.aspx")
End Sub

1 个答案:

答案 0 :(得分:7)

如果要从代码中插入GUID,则应使参数类型为GUID

<asp:Parameter Name="ParamName" DbType="Guid" />

你应该将GUID值传递为(c#):

SqlDataSource1.InsertParameters["ParamName"].DefaultValue = System.Guid.NewGuid().ToString();

如果要传递字符串值,则必须在插入查询中使用CONVERT(UNIQUEIDENTIFIER,'YOUR VALUE'),如下所示:

InsertCommand="INSERT INTO [Order] ([UserId], [etc]) 
VALUES (CONVERT(UNIQUEIDENTIFIER,@UserId), @etc)"