Asp.net VB.Net SQL结果转换为JSON for Ajax
新程序员,我正在用VB.Net代码构建一个aspx页面,我正在尝试用数据库中的数据创建一个D3图表,但我无法将返回值转换为正确的格式Asp.net VB.Net SQL结果转换为JSON for Ajax,asp.net,json,vb.net,Asp.net,Json,Vb.net,新程序员,我正在用VB.Net代码构建一个aspx页面,我正在尝试用数据库中的数据创建一个D3图表,但我无法将返回值转换为正确的格式 $(function () { GetData(); }); function GetData() { $.ajax({ type: "post", url: "D3PieChart.aspx/GetData", contentType
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
在我的VB代码中,我可以将字符串转换为我想要的精确格式:
[{ name: "PROAIR", value: 7}],{ name: "NASONEX", value: 4}]
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
但当我把它传回去的时候,结果是:
{"d":"[{name: \"PROAIR\", value: 7},{name: \"NASONEX\", value: 4}]"}
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
我现在知道它正在尝试序列化返回值,所以我尝试使用datatable并序列化它,然后使用ListOf对象并序列化它,但每次我都会在返回值中使用更多引号和转义退格得到不同的结果。我已经看过了MicrosoftPerson示例和一些StackContacts示例,但是我真的需要构建一个全新的类并向其中添加新项目吗?
我的字符串生成器代码如下:
Dim sData As String
Dim sqlCmd As New SqlCommand(strSql, cn)
Using sdr As SqlDataReader = sqlCmd.ExecuteReader()
Dim sb As New StringBuilder()
sb.Append("[")
While sdr.Read()
sb.Append("{")
System.Threading.Thread.Sleep(50)
sb.Append(String.Format("name: '{0}', value: {1}", sdr(0), sdr(1)))
sb.Append("},")
End While
sb = sb.Remove(sb.Length - 1, 1)
sb.Append("]")
sData = sb.ToString
sData = sData.Replace("'", ControlChars.Quote)
cn.Close()
Return sData
End Using
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
如果我尝试序列化该字符串:
Dim serializer As New JavaScriptSerializer()
Dim SerializedResult = serializer.Serialize(sData)
Return SerializedResult
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
我的结果是:{d:\[{name:\\\PROAIR\\\,value:7},{name:\\\NASONEX\\\,value:4}]\}
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
我试着用
Dim deserializedResult=serializer.DeserializeOf StringsData
但它会因数组类型失败而出错,因此显然您不能这样做:
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
在aspx页面中,我硬编码了:
success: function (r) {
var data = [{ name: "PROAIR", value: 7}],{ name: "NASONEX", value: 4}]
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
我的图表构建得非常完美,因此只需以正确的格式返回sql数据并将脚本代码更改为var data=r
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
编辑以下工作代码:
Dim sData As String
Dim sqlCmd As New SqlCommand(strSql, cn)
Using sdr As SqlDataReader = sqlCmd.ExecuteReader()
Dim sb As New StringBuilder()
sb.Append("[")
While sdr.Read()
sb.Append("{")
System.Threading.Thread.Sleep(50)
sb.Append(String.Format("name: '{0}', value: {1}", sdr(0), sdr(1)))
sb.Append("},")
End While
sb = sb.Remove(sb.Length - 1, 1)
sb.Append("]")
sData = sb.ToString
sData = sData.Replace("'", ControlChars.Quote)
cn.Close()
Return sData
End Using
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
aspx页面:
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
VB页面:
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
<WebMethod()> _
Public Shared Function GetData() As String
Dim sConnect As String = ConfigurationManager.ConnectionStrings("SQLConnectionString").ConnectionString
Dim cn As New SqlConnection(sConnect)
Dim strSql As String = "SELECT name and a count of stuff "
strSql += "FROM a bunch of tables WHERE stuff = stuff "
Dim dtb As New DataTable
cn.Open()
If (cn.State And ConnectionState.Open) <> 0 Then
Dim sqlCmd As New SqlCommand(strSql, cn)
Dim sqlDad As New SqlDataAdapter(sqlCmd)
sqlDad.Fill(dtb)
dtb.Columns(0).ColumnName = "Name"
dtb.Columns(1).ColumnName = "value"
Dim sjData As String = GetJson(dtb)
Return sjData
End If
Return -1
End Function
Public Shared Function GetJson(ByVal dt As DataTable) As String
Dim serializer As New System.Web.Script.Serialization.JavaScriptSerializer()
serializer.MaxJsonLength = Integer.MaxValue
Dim rows As New List(Of Dictionary(Of String, Object))()
Dim row As Dictionary(Of String, Object) = Nothing
Dim row2 As Dictionary(Of Integer, Object) = Nothing
For Each dr As DataRow In dt.Rows
row = New Dictionary(Of String, Object)()
row2 = New Dictionary(Of Integer, Object)()
For Each dc As DataColumn In dt.Columns
row.Add(dc.ColumnName.Trim(), dr(dc))
Next
rows.Add(row)
Next
Return serializer.Serialize(rows)
End Function
End Class
这是一个简单的图表,不带任何参数,它都是硬编码的,但它从SQL Server数据库中提取图表数据。我在我的项目中做了类似的事情,希望它能帮助您:
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
在我的aspx页面中,我正在使用-
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
$.ajax({
...
error: function () {
},
success: function (result) {
$("#MainContent_EmployeesGridView").find('span[id="MainContent_EmployeesGridView_minIncrease_' + rowNum + '"]').html(result.d[0]);
$("#MainContent_EmployeesGridView").find('span[id="MainContent_EmployeesGridView_maxIncrease_' + rowNum + '"]').html(result.d[1]);
}
});
需要注意的重要部分是,我正在使用result.d[0]在gridview中设置html文本值
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
所以对于你的问题,它看起来像:
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
success: function (r) {
var data = r.d[0];
var data2 = r.d[1]; }
在datatable中获取Sql结果,然后简单地将其传递给GetJson方法以获取json字符串
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
Dim da As New OleDb.OleDbDataAdapter(strSql, cn)
Dim dt As DataTable = New DataTable
da.Fill(dt)
Dim sData As string = GetJson(dt)
Public Shared Function GetJson(ByVal dt As DataTable) As String
Dim serializer As New System.Web.Script.Serialization.JavaScriptSerializer()
serializer.MaxJsonLength = Integer.MaxValue
Dim rows As New List(Of Dictionary(Of String, Object))()
Dim row As Dictionary(Of String, Object) = Nothing
For Each dr As DataRow In dt.Rows
row = New Dictionary(Of String, Object)()
For Each dc As DataColumn In dt.Columns
row.Add(dc.ColumnName.Trim(), dr(dc))
Next
rows.Add(row)
Next
Return serializer.Serialize(rows)
End Function
添加System.Collections.Generic的引用
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
在aspx页面上
$(function () {
GetData();
});
function GetData() {
$.ajax({
type: "post",
url: "D3PieChart.aspx/GetData",
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (r) {
data = r.d;
data = jQuery.parseJSON(data)
-- Build D3 chart commands in this section --
},
error: function (xhr, status, error) {
OnFailure(error);
alert('Error');
}
});
}
</script>
success: function (r) {
var data = r.d;
你为什么不使用json.net?@Daniel我是一名新员工,我还没有能力安装/引用新模块,所以我希望用我现有的功能来实现这一点。我填充了一个数据表,添加了列名,并调用了你的GetJson函数Dim sData作为String=GetJsondt Return sDataran out out of time on on comments我填充了一个数据表,添加了columnnames并调用了GetJson函数Dim sData作为String=GetJsondt Return sData,但是如果我将alertdata添加到aspx页面,我会得到[{Name:PROAIR,Value:7},{Name:NASONEX,Value:4}],并在列周围加上引号,而我不会得到任何图表。我需要删除columnnames.use jQuery.parseJSONr.dinaspx页面中的var data=r.d;var d2=jQuery.parseJSONdata alertJSON.stringifyd2;警报2;stringify在引号中显示对的名称,警报只显示[object][object]。为了让D3准备好数据集,我只需要删除返回集中单词Value周围的引号,我认为它应该可以工作。所以实际上,我可以从Value中删除引号,或者在整数中添加引号。我更改了SQL查询,将计数转换为varchar,数据表被序列化为D3应该可读的格式。不是,但那是另一个问题。当我可以投票或标记为答案时,我会的。谢谢你的帮助。