会计考友 发表于 2012-7-31 22:26:35

2012年计算机二级ACCESS的参数化查询(1)

 最近因项目需要用Access做数据库开发Web项目   ACCESS被注入的安全问题
  许多人解决的方法仍然是用Replace替换特殊字符,然而这样做也并没有起到太大做用
  今天就把用ACCESS参数化查询的一些方法和经验和大家分享,希望对大家有所启发
  ASP.net 用OleDbCommand的new OleDbParameter创建参数货查询
  ASP用Command的CreateParameter 方法创建参数化查询
  (SQL储存过程查询也是用这个方法建立的)
  ASP.NET C#语法
  OleDbParameter parm = new OleDbParameter(Name, Type, Direction, Size, Value);
  (实际上它有七重载大家具体大家可以在VS.net里面就可以看到)
  参数
  Name 可选,字符串,代表 Parameter 对象名称。
  Type 可选,长整型值,指定 Parameter 对象数据类型。
  Direction 可选,长整型值,指定 Parameter 对象类型。。
  Size 可选,长整型值,指定参数值最大长度(以字符或字节数为单位)。
  Value 可选,变体型,指定 Parameter 对象的值。
  以下是实例,查询news表中所有tsing发表的新闻
  -------------------------------------------------------
  sql="select * from newss where username=? order by id"
  //注意查询的条件均用?号表示
  OleDbConnection conn = new OleDbConnection(connString);
  OleDbCommand cmd = new OleDbCommand(sql,conn);
  OleDbParameter parm = new OleDbParameter("temp",OleDbType.VarChar, 50);
  //temp为Parameter对象可随便定义,OleDbType.VarChar指定为字符串,长度50
  parm.Direction = ParameterDirection.Input;
  //指定其类型输入参数
  cmd.Parameters.Add(parm);
  cmd.Parameters["temp"].Value = "tsing";
  //查询tsing,也可以写成cmd.Parameters
  conn.Open();
  cmd.ExecuteReader();
  ASP VBSCRIPT语法
  Set parameter = command.CreateParameter (Name, Type, Direction, Size, Value)
  参数同上
页: [1]
查看完整版本: 2012年计算机二级ACCESS的参数化查询(1)