Я использую Xamarin.Forms в visual studio и у меня есть список продуктов, которые я вставляю в таблицу. Когда я пытаюсь обновить Cantidad, Precio или другую функцию, Articulo не обновляется, и список появляется, как и прежде. Я пытаюсь использовать PK в качестве строки, поэтому, когда я пытаюсь обновить элемент, мне нужен Producto of the Articulo, он проверяет, что Id Producto существует в базе данных, а затем обновляет.
Это моя модель Articulo.cs
using SQLite;
using System;
using System.Collections.Generic;
using System.Text;
namespace Saansa.Modelos
{
public class Articulo
{
[PrimaryKey,AutoIncrement]
public string Id { get; set; }
public string Producto { get; set; }
public int Precio { get; set; }
public int Cantidad { get; set; }
public string MasterCategory { get; set; }
public string Category1 { get; set; }
public string Category2 { get; set; }
public string Category3 { get; set; }
}
}
Это мой файл xalm:
<?xml version="1.0" encoding="utf-8" ?>
<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
xmlns:local="clr-namespace:Saansa"
x:Class="Saansa.Inventario"
Title="Inventario">
<StackLayout BackgroundColor="#f5cda2">
<Image Margin="0,0,0,0" HeightRequest="10" Source="inventario.png" ></Image>
<Label Margin="0,0,0,0" Text="Mi Cafe Delicias" FontAttributes="Bold"
FontSize="Large" TextColor="#b27b4b" HorizontalTextAlignment="Center" ></Label>
<Entry x:Name="txtProducto" Placeholder="Código Producto"></Entry>
<Entry x:Name="txtNombre" Placeholder="Nombre del producto"></Entry>
<Entry x:Name="txtPrecio" Placeholder="Precio del producto"></Entry>
<Entry x:Name="txtCantidad" Placeholder="Cantidad del Producto"></Entry>
<Entry x:Name="txtMainCategory" Placeholder="Categoria general"></Entry>
<Entry x:Name="txtSub1" Placeholder="Subcategoria 1"></Entry>
<Entry x:Name="txtSub2" Placeholder="Subcategoria 2"></Entry>
<Entry x:Name="txtSub3" Placeholder="Subcategoria 3"></Entry>
<StackLayout HorizontalOptions="CenterAndExpand" Orientation="Horizontal">
<Button x:Name="btnAdd" WidthRequest="200" Text="Añadir" Clicked="BtnAdd_Clicked"
BackgroundColor="White" BorderColor="#b27b4b" BorderWidth="3" CornerRadius="15"/>
<Button x:Name="btnRead" WidthRequest="200" Text="Buscar" Clicked="BtnRead_Clicked"
BackgroundColor="White" BorderColor="#b27b4b" BorderWidth="3" CornerRadius="15"/>
</StackLayout>
<StackLayout HorizontalOptions="CenterAndExpand" Orientation="Horizontal">
<Button x:Name="btnUpdate" WidthRequest="200" Text="Actualizar" Clicked="BtnUpdate_Clicked"
BackgroundColor="White" BorderColor="#b27b4b" BorderWidth="3" CornerRadius="15"/>
<Button x:Name="btnDelete" WidthRequest="200" Text="Borrar" Clicked="BtnDelete_Clicked"
BackgroundColor="White" BorderColor="#b27b4b" BorderWidth="3" CornerRadius="15"/>
</StackLayout>
<ListView x:Name="lstArticulo" BackgroundColor="#f5cda2">
<ListView.ItemTemplate>
<DataTemplate>
<ViewCell>
<StackLayout>
<Label Text="{Binding Producto}"/>
<Label Text="{Binding Id}" HorizontalOptions="EndAndExpand"
TextColor="Black"/>
</StackLayout>
</ViewCell>
</DataTemplate>
</ListView.ItemTemplate>
</ListView>
</StackLayout>
</ContentPage>
В моем Inventario.xalm.cs мой вариант обновления такой:
private async void BtnUpdate_Clicked(object sender, EventArgs e)
{
if (!string.IsNullOrEmpty(txtProducto.Text))
{
Modelos.Articulo articulo = new Modelos.Articulo()
{
Id = txtProducto.Text,
Producto = txtNombre.Text,
Precio = Convert.ToInt32(txtPrecio.Text),
Cantidad = Convert.ToInt32(txtCantidad.Text),
MasterCategory = txtMainCategory.Text,
Category1 = txtSub1.Text,
Category2 = txtSub2.Text,
Category3 = txtSub3.Text
};
//Update Person
await App.SQLiteDb.SaveItemAsync(articulo);
txtNombre.Text = string.Empty;
txtCantidad.Text = string.Empty;
txtProducto.Text = string.Empty;
txtPrecio.Text = string.Empty;
txtMainCategory.Text = string.Empty;
txtSub1.Text = string.Empty;
txtSub2.Text = string.Empty;
txtSub3.Text = string.Empty;
await DisplayAlert("Success", "Person Updated Successfully", "OK");
//Get All Persons
var articuloLista = await App.SQLiteDb.GetItemsAsync();
if (articuloLista != null)
{
lstArticulo.ItemsSource = articuloLista;
}
}
else
{
await DisplayAlert("Required", "Please Enter Nombre articulo", "OK");
}
}
и мой SQLiteHekper.cs:
public Task<int> SaveItemAsync(Modelos.Articulo articulo)
{ //articulo.Cantidad. !string.IsNullOrEmpty(articulo.Cantidad)
if (!string.IsNullOrEmpty(articulo.Id))
{
//probando esto
//var nuevoArticulo = GetItemAsync(articulo.Producto);
return db.UpdateAsync(articulo);
}
else
{
return db.InsertAsync(articulo);
}
}