我正在Windows应用商店应用上制作航班数据应用。该应用程序将只追踪从&到达巴基斯坦的航班。如何解决此sqlite异常约束
我通过JSON从
得到我的数据,并将其保存到SQLite数据库。
这是我的职责是获取数据
P.S:在连接字符串中使用的所有变量声明和分配,但因为它们是不相关的,我不向他们展示。
public async void getdata()
{
var dbpath = Path.Combine(Windows.Storage.ApplicationData.Current.LocalFolder.Path, "flight_record.sqlite");
for (int hour = 0; hour < 24; hour++)
{
HttpClient web = new HttpClient();
var response = await web.GetStringAsync("https://api.flightstats.com/flex/flightstatus/rest/v2/json/airport/status/KHI/arr/" + year + "/" + Month + "/" + today + "/" + hour + "?appId=" + appId + "&appKey=" + appKey + "&utc=false&numHours=1&maxFlights=10");
jsondata1 data1 = JsonConvert.DeserializeObject<jsondata1>(response);
for (int i = 0; i < data1.flightStatuses.Length; i++)
{
int f_ID = Convert.ToInt32(data1.flightStatuses[i].flightId);
string l_time = data1.flightStatuses[i].arrivalDate.dateLocal.TimeOfDay.ToString();
string year1 = data1.flightStatuses[i].arrivalDate.dateLocal.Year.ToString();
string month1 = data1.flightStatuses[i].arrivalDate.dateLocal.Month.ToString();
string day1 = data1.flightStatuses[i].arrivalDate.dateLocal.Day.ToString();
string departureAirport1 = data1.flightStatuses[i].departureAirportFsCode.ToString();
string arrivalAirport1 = data1.flightStatuses[i].arrivalAirportFsCode.ToString();
string stats = data1.flightStatuses[i].status.ToString();
string FsCode = data1.flightStatuses[i].carrierFsCode.ToString();
string flightNumber1 = data1.flightStatuses[i].flightNumber.ToString();
//here arival_data is my sqlite database table
using (var db = new SQLite.SQLiteConnection(dbpath))
{
db.Execute("Insert into arrival_data (flightID, time, year, month, day, departureAirport, arrivalAirport, status, airline, carrierFsCode, flightNumber) values ('" + f_ID + "', '" + l_time + "', '" + year1 + "', '" + month1 + "', '" + day1 +
"', '" + departureAirport1 + "', '" + arrivalAirport1 + "', '" + stats + "', '" + airline1 +
"', '" + FsCode + "', '" + flightNumber1 + "')");
}
}
}
}
我请求查询仅支持每小时1个查询, 所以我做了一个循环,将运行23次。
每小时的飞行次数不同,所以我在第二次循环中使用了data1.flightStatuses.Length。
之后,我将数据插入表中。
当我运行应用程序,我得到下面的异常
我做了调试,而不是插入数据分贝,我在列表框中显示出来,并且发现这是结果
如果你看结果,时间不是递增顺序。因此,我得到了例外!
那么,如何组织数据,使时间递增顺序,还是有另一种方式?
我怀疑你尝试插入行的顺序是否导致了约束异常 - 这可能是别的。你可以发布arrival_data表模式的SQL定义吗?另外,我强烈强烈建议您使用SqlParameters,而不是直接将数据串联到SQL字符串中 - 这是SQL注入攻击的一个巨大安全漏洞。 –