+ "''''" + txtWriter.Text + "''''," + "''''" + txtContent.Text + "'''')"; conn.Open(); //Response.Write (cmd.CommandText);
// 插入记录 try { cmd.ExecuteNonQuery(); } catch (Exception ex) { Response.Write("<script language=javascript>alert(''''输入错误,数据库不能更新。'''')</script>"); } finally { conn.Close(); } }
注意Command对象的ExecuteNonQuery()方法使用,该方法可以用于插入、更新、删除等操作,是Command对象的重要方法。今天介绍了Command语句的最基本用法,下次还将介绍占位符的用法。好了,各位先消化一下,明后天将做实用的东东了。
第七天
学习目的
接触验证控件
昨天介绍了SQL SERVER插入数据,但是我们省略了验证输入这一步。以前的做法是用语句逐个判断输入的正确性,如是否为空,长度是否超过等。现在.NET中有了验证控件,可以使我们在编程的语句中大在简化了。今天介绍验证控件中最基本的一个,RequeiredFieldValidator控件,是用来判别否输入控件是否为空值,如为空则引发错误。
RequeiredFieldValidator可以用来验证TextBox、ListBox、DropDownList、RadioButtonList及Html控件中的InputText、TextArea、Select、InputFile等。
属性介绍: ControlToValidate:指点验证某一控件的控件名,如为空,将引发异常; ErrorMessage:错误提示信息; IsValid:用于判断是否通过验证; Display:有三个值,None表示错误时不显示信息,但在ValidationSunmmary控件中显示;Static表示不论错误提示是否出现,都占页面空间;Dymatic:只有错误提示才占用空间。 Text:文本内容。和ErrorMessage一起使用时,将显示Text错误信息。该种情况可以通过ValidationSummay控件显示ErrorMessage属性的提示。
使用方法: 设置: txtTitle:MaxLength(50); txtSubTitle: MaxLength(50); txtWriter: MaxLength(10); 这样可以防止输入过长字符串 rfvTitle:ControlToValidate(txtTitle)、ErrorMessage(“标题必须输入。”) rfvContent:ControlToValidate(txtTitle)、ErrorMessage(“内容必须输入。”)
这样在没有验证通过时,会出现下图信息提示,并不执行插入语句。直到验证正确后,才执行数据更新。
图片如下:
第八天
学习目的
学会SQL中的占位符用法
在鲸鱼这几天忙死了,好几天没写了,真对不起各位。这几天让XHTML闹得不开心,虽然以前也知道这个,但没太在意。可现在我是如梦初醒,我发觉XHTML是个信号,所以这几天不得不仔细研究一下这个。很笨,我还没发觉XHTML的奥妙。确实如此,没上过台面,真不知这桌菜怎样好吃。少说了,回到正题。
先把以前的Command的CommandText重新写过: cmd.CommandText = "INSERT INTO NewsArticle (Title, SubTitle, Writer, Content)" + " valueS ( @Title, @SubTitle, @Writer, @Content )"; 这样代码是否很清晰了,我们可以避免一大串的难以看懂的的语句了。
接下来,我们就给这些定位符赋予属性和值了: cmd.Parameters.Add("@Title", SqlDbType.NVarChar, 50); cmd.Parameters.Add("@SubTitle", SqlDbType.NVarChar, 50); cmd.Parameters.Add("@Writer", SqlDbType.NVarChar, 10); cmd.Parameters.Add("@Content", SqlDbType.NText);
以上我们给每个占位符定义一个值类型,相信不难看懂吧。接者再给于值: cmd.Parameters["@Title"].value = txtTitle.Text.Trim(); if (txtSubTitle.Text == string.Empty || txtSubTitle.Text.Trim() == "") { cmd.Parameters["@SubTitle"].value = DBNull.value; } else { cmd.Parameters["@SubTitle"].value = txtSubTitle.Text.Trim(); } if (txtWriter.Text == string.Empty || txtWriter.Text.Trim() == "") { cmd.Parameters["@Writer"].value = DBNull.value; } else { cmd.Parameters["@Writer"].value = txtWriter.Text; } cmd.Parameters["@Content"].value = txtContent.Text;
其实,也可以这样写: cmd.Parameters.Add("@Title", SqlDbType.NVarChar, 50) .value = txtTitle.Text.Trim(); 这要看你喜欢了。
不错吧,程序是否很有条理。
程序代码: private void btnPublish_ServerClick(object sender, System.EventArgs e) { string strConnection = ConfigurationSettings.AppSettings["SqlDatabase1"];
// 连接SqlServer数据库 SqlConnection conn = new SqlConnection(strConnection); // 建立SqlCommand SqlCommand cmd = conn.CreateCommand(); 上一页 [1] [2] [3] [4] [5] [6] [7] 下一页 |