public string Insert_Empleado(Empleado nn) { string result=string.Empty; //using (TransactionScope scope = new TransactionScope()) //{ using (MamirmiEntities BDmodel = new MamirmiEntities()) { //var query = from x in BDmodel.Empleado // where x.carne == nn.carne // select x; Empleado query = BDmodel.Empleado.SingleOrDefault(x => x.carne == nn.carne && x.estado == true); if (query==null) { BDmodel.Empleado.Add(nn); if (BDmodel.ChangeTracker.HasChanges())//double check if there was any change detected by EF or not? { BDmodel.SaveChanges(); result = "Correcto: Empleado Agregado con Exito"; } else { result = "Error: Revisar datos de entrada"; } } else { result = "Error: El carnet ingresado se encuentra en uso."; } } return result; }
public string Update_Persona(Empleado newp) { using (MamirmiEntities BDmodel = new MamirmiEntities()) { Empleado oldp = BDmodel.Empleado.SingleOrDefault(x=> x.ID==newp.ID); oldp.nombre = newp.nombre; oldp.apellidos = newp.apellidos; if (BDmodel.ChangeTracker.HasChanges()) { BDmodel.SaveChanges(); return "Correcto: Empleado Actualizado con Exito"; } else { return "Error: Revisar datos de entrada"; } } }
/*private void button1_Click(object sender, EventArgs e) { if (button1.Text == "Agregar") { Persona nn = new Persona(); nn.ID = textBox1.Text; nn.nombre = textBox2.Text; nn.apellidos = textBox3.Text; nn.edad = Int32.Parse(numericUpDown1.Value.ToString()); nn.EstadoCivil = comboBox2.SelectedItem.ToString(); nn.nacionalidad = comboBox1.SelectedItem.ToString(); nn.direccion = textBox4.Text; nn.sexo = comboBox3.SelectedItem.ToString(); nn.Hijos = Int32.Parse(numericUpDown2.Value.ToString()); if (nn.ID.Length >= 9) { if (nn.nombre != "" && nn.apellidos != "" && nn.direccion != "") { nn.fecha_de_ingreso = dateTimePicker1.Value.Date; label11.Text = Controlador.Insert_Persona(nn); dataGridView1.DataSource = Controlador.view_Personas(textBox5.Text); rowautosize(); } else { label11.Text = "Revisar parametros de entrada."; label11.ForeColor = Color.Red; } } else { label11.Text = "La cédula debe contener al menos 9 números."; label11.ForeColor = Color.Red; } } else { Persona nn = new Persona(); nn.ID = textBox1.Text; nn.nombre = textBox2.Text; nn.apellidos = textBox3.Text; nn.edad = Int32.Parse(numericUpDown1.Value.ToString()); nn.EstadoCivil = comboBox2.SelectedItem.ToString(); nn.nacionalidad = comboBox1.SelectedItem.ToString(); nn.direccion = textBox4.Text; nn.sexo = comboBox3.SelectedItem.ToString(); nn.Hijos = Int32.Parse(numericUpDown2.Value.ToString()); nn.fecha_de_ingreso = dateTimePicker1.Value; label11.Text = Controlador.Update_Persona(nn); dataGridView1.DataSource = Controlador.view_Personas(textBox5.Text); rowautosize(); } } private void formPersona_Load(object sender, EventArgs e) { dataGridView1.DataSource = Controlador.view_Personas(textBox5.Text); dataGridView1.Columns[0].HeaderCell.Value = "Nombre"; dataGridView1.Columns[1].HeaderCell.Value = "Apellidos"; rowautosize(); } private void textBox5_TextChanged(object sender, EventArgs e) { dataGridView1.DataSource = Controlador.view_Personas(textBox5.Text); rowautosize(); } private void rowautosize() { dataGridView1.Columns[0].Width = (groupBox3.Width/3); dataGridView1.Columns[1].Width = (groupBox3.Width / 3) + (groupBox3.Width / 4); dataGridView1.BackgroundColor = this.BackColor; dataGridView1.BorderStyle = BorderStyle.None; } private void dataGridView1_CellContentClick(object sender, DataGridViewCellEventArgs e) { Int32 selectedCellCount = dataGridView1.GetCellCount(DataGridViewElementStates.Selected); int[] selecion = new Int32[2]; selecion = null; selecion = new Int32[2]; if (selectedCellCount > 0) { if (dataGridView1.AreAllCellsSelected(true)) { MessageBox.Show("Seleccione una celda.", "Alerta"); } else { for (int i = 0; i < selectedCellCount; i++) { selecion[0] = dataGridView1.SelectedCells[i].RowIndex; selecion[1] = dataGridView1.SelectedCells[i].ColumnIndex; } Persona nn = Controlador.Get_Persona(dataGridView1.Rows[selecion[0]].Cells[0].Value.ToString(), dataGridView1.Rows[selecion[0]].Cells[1].Value.ToString()); textBox1.Text= nn.ID.ToString(); textBox2.Text = nn.nombre; textBox3.Text = nn.apellidos; numericUpDown1.Value = nn.edad; comboBox2.SelectedItem = nn.EstadoCivil; comboBox1.SelectedItem = nn.nacionalidad; textBox4.Text = nn.direccion; comboBox3.SelectedItem = nn.sexo; numericUpDown2.Value = (decimal)nn.Hijos; dateTimePicker1.Value = nn.fecha_de_ingreso; button1.Text = "Actualizar"; tabControl1.SelectedIndex=1; } } } private void textBox1_KeyPress(object sender, KeyPressEventArgs e) { if (!(char.IsNumber(e.KeyChar)) && (e.KeyChar != (char)Keys.Back)) { label11.Text = "Sólo se permiten números en la identificación"; label11.ForeColor = Color.Red; //MessageBox.Show("Solo se permiten numeros", "Advertencia", MessageBoxButtons.OK, MessageBoxIcon.Exclamation); e.Handled = true; return; } } private void textBox1_TextChanged(object sender, EventArgs e) { if (textBox1.Text == "" && label11.Text != "Sólo se permiten números en la identificación" && label11.Text != "La cédula debe contener al menos 9 números.") { textBox2.Text = string.Empty; textBox3.Text = string.Empty; numericUpDown1.Value = 18; comboBox2.SelectedItem = "Soltero"; comboBox1.SelectedItem = "Costa Rica"; textBox4.Text = string.Empty; comboBox3.SelectedItem = "Masculino"; numericUpDown2.Value = 0; dateTimePicker1.Value = DateTime.Today; button1.Text = "Agregar"; } } private void empleadosToolStripMenuItem_Click(object sender, EventArgs e) { registro_Empleados nn = new registro_Empleados(); nn.Show(); this.Hide(); } private void personasToolStripMenuItem_Click(object sender, EventArgs e) { Mamirmi_Registro nn = new Mamirmi_Registro(); nn.Show(); this.Hide(); }*/ private void btnAceptar_Click(object sender, EventArgs e) { try { if ((txt_Cedula.Text != "") && (txt_Carne.Text != "") && (txt_Nombre.Text != "") && (txt_Apellidos.Text != "") ) { if (txt_Cedula.TextLength >= 9) { Empleado nn = new Empleado(); nn.ID = txt_Cedula.Text; nn.carne = txt_Carne.Text; nn.nombre = txt_Nombre.Text; nn.apellidos = txt_Apellidos.Text; nn.fecha_Ingreso = DateTime.Today; nn.estado = true; nn.cuenta_BN = txt_BancoNacional.Text; nn.cuenta_BP = txt_BancoPopular.Text; nn.departamento = cmb_Departamento.SelectedItem.ToString(); nn.numeroComprobante = Int32.Parse(txt_NumeroComprabante.Text); lbl_error.Text = Controlador.Insert_Empleado(nn); txt_Apellidos.Text = ""; txt_BancoNacional.Text = ""; txt_BancoPopular.Text = ""; txt_Carne.Text = ""; txt_Cedula.Text = ""; txt_Nombre.Text = ""; txt_NumeroComprabante.Text = ""; } else { lbl_error.Text = "La cédula debe contener al menos 9 números."; lbl_error.ForeColor = Color.Red; } } else { lbl_error.Text = "Error: Favor revisar datos de entrada."; lbl_error.ForeColor = Color.Red; } } catch(Exception ) { lbl_error.Text = "Error inesperado"; lbl_error.ForeColor = Color.Red; } }