c# 封装dbhelper中的存储过程执行,如何比较好的返回结果和out参数的值

我现在想到的是建3个类

//返回cmd.ExecuteNonQuery();的存储过程执行结果
class1{
    int returnnum;
    dic outputdic;
}

//返回cmd.ExecuteScalar();的存储过程执行结果
class2{
    object returnobject;
    dic outputdic;
}

//返回cmd.ExecuteQuery();的存储过程执行结果
class2{
    datatable returndatatable;
    dic outputdic;
}

有没有什么好的方法优雅的解决这个问题

1个回答

用泛型

class MyResult<T>
{
public T ReturnVal;
public dic outputdic;
}
第一个返回
MyResult<int>
第二个
MyResult<object>
第三个
MyResult<DataTable>
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
其他相关推荐
求助c#ktv后台管理系统
用c#编写ktv后台管理系统 用DBHelper Manager 调用方法 简写方法
c#向数据库添加大量数据为何我的这么慢
public void ShuaXin() { SqlCommand com = new SqlCommand("delete from priceavg", DBHelper.con); DBHelper.con.Open(); com.ExecuteNonQuery(); DBHelper.con.Close(); pros = new List<ProPrice>(); com.CommandText = "select proid from proprice where newprice=1"; DBHelper.con.Open(); SqlDataReader re = com.ExecuteReader(); ProPrice pp = null; while (re.Read()) { pp = new ProPrice() { ProID = Convert.ToInt32(re["ProID"]) }; pros.Add(pp); } re.Close(); DBHelper.con.Close(); //刷新上个月价格 for (int i = 0; i < pros.Count; i++) { com.CommandText = string.Format("select ptype from product where id={0} ", pros[i].ProID); com.Connection = DBHelper.con; DBHelper.con.Open(); if (com.ExecuteScalar() == null) { DBHelper.con.Close(); continue; } int id = (int)com.ExecuteScalar(); DBHelper.con.Close(); DateTime beginTime = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1); //获取本月的月份然后减去一个月 DateTime finishTime = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1); if (set.Tables["Avg1"] != null) { set.Tables.Remove("Avg1"); } string sql = string.Format("select " + getSqlWhere(id) + " from proprice where proid={0} and addtime between '{1}' and '{2}'", pros[i].ProID, beginTime, finishTime); adapter = new SqlDataAdapter(sql, DBHelper.con); adapter.Fill(set, "Avg1"); DataTable dt = set.Tables["Avg1"]; string[] strs = new string[dt.Columns.Count + 1]; int count1 = 0; if (dt.Columns.Count == 1) { strs = new string[dt.Columns.Count + 1]; } double avg = 0; for (int j = 0; j < dt.Columns.Count; j++) { double num = 0; int count = 0; for (int c = 0; c < dt.Rows.Count; c++) { if (dt.Rows[c][j] is DBNull || dt.Rows[c][j] == null) { count++; continue; } if ((dt.Rows[c][j]).ToString() == "非数字") { count++; continue; } if (Convert.ToDouble(dt.Rows[c][j]) == 0) { count++; continue; } num += Convert.ToDouble(dt.Rows[c][j]); } strs[j] = Math.Round(num / (dt.Rows.Count - count), 2).ToString(); if (strs[j] == "非数字") { count1++; } else { avg += Convert.ToDouble(strs[j]); } } strs[strs.Length - 1] = Math.Round((avg / (strs.Length - 1 - count1)), 2).ToString(); com.CommandText = string.Format("select count(*) from product where id={0} ", pros[i].ProID); DBHelper.con.Open(); if ((int)com.ExecuteScalar() == 0) { DBHelper.con.Close(); continue; } DBHelper.con.Close(); com.CommandText = string.Format("select IsSeason,ProDescription,ID,ProductImage,Spec,ProAddress,MaoZhong,JingZhong from product where id={0}", Convert.ToInt32(pros[i].ProID)); DBHelper.con.Open(); re = com.ExecuteReader(); Model.Product p1 = null; if (re.Read()) { p1 = new Model.Product() { IsSeason = Convert.ToInt32(re["IsSeason"]), ProDescription = re["ProDescription"].ToString(), ID = Convert.ToInt32(re["ID"]), ProductImage = re["ProductImage"].ToString(), Spec = re["Spec"].ToString(), ProAddress = re["ProAddress"].ToString(), MaoZhong = re["MaoZhong"].ToString(), JingZhong = re["JingZhong"].ToString() }; } re.Close(); DBHelper.con.Close(); string sqlstr = @"INSERT INTO priceAvg ([IsSeason],[ProDescription],[编号],[图片],[品名],[规格],[产地],[毛重],[净重],[isnoBiaoZhunJin],[isnoBiaoZhunJinls]," + insertSql(id) + ",timetype) values('" + p1.IsSeason + "','" + p1.ProDescription + "','" + p1.ID + "','" + p1.ProductImage + "','" + PinMing(Convert.ToInt32(pros[i].ProID)) + "','" + p1.Spec + "','" + p1.ProAddress + "','" + p1.MaoZhong + "','"; sqlstr = sqlstr + p1.JingZhong + "','" + 0 + "','" + 0 + "','"; if (insertSql(id).Trim() == "pavgprice") { strs = new string[] { strs[0] }; } int nb = 0; for (int m = 0; m < strs.Length; m++) { if (strs[m] == "非数字") { strs[m] = "0"; } if (strs[m] == null) { strs[m] = "0"; } if (strs[m] == "0") { nb++; } sqlstr = sqlstr + strs[m] + "','"; } if (nb == strs.Length) { continue; } sqlstr = sqlstr + 1 + "')"; com.CommandText = sqlstr; DBHelper.con.Open(); com.ExecuteNonQuery(); DBHelper.con.Close(); } }
关于C#制作的电影管理系统选座后的订票条件设置
座位表已经设计出来了,每个座位代表一个数字,一共1-30 然后每个座位有一个state值。当state为0是座位是空,state为1时,座位是已选,现在遇到的问题是当我选择已售出的座位时也能进行订票。我想的结果应该是当选择已售出座位时提示“座位已售出”而选择空座位时可以订票。。希望高手帮忙解答(最好是代码形式)座位表的数据库如下![图片说明](https://img-ask.csdn.net/upload/201504/30/1430366577_636106.jpg) 数据库连接我用的DBHelper
怎样优化下列C#代码??????
![图片说明](https://img-ask.csdn.net/upload/201611/30/1480468845_140348.png) 每个方法里面都要实例化一个DBHelper,有什么办法优化,直接将实例化放在外面?
c#中使用cmd.Parameters.AddWithValue存入数据库
``` DBHelper D = new DBHelper(); MySqlConnection M = D.getconn(); M.Open(); MySqlCommand cmd = new MySqlCommand("insert into test1(name,department,specification,amount,packing,declarationInspectionDate,assayDate,reportDate,commodityBatchNumber,inspectionbasis,conclusion,assessor,analyst,laboratoryTechnician) values(@name,@department,@specification,@amount,@packing,@declarationInspectionDate,@assayDate,@reportDate,@commodityBatchNumber,@inspectionbasis,@conclusion,@assessor,@analyst,@laboratoryTechnician)",M); cmd.CommandType = CommandType.Text; cmd.Parameters.AddWithValue("@name", this.textBox1.Text.Trim()); cmd.Parameters.AddWithValue("@department", this.textBox2.Text.Trim()); cmd.Parameters.AddWithValue("@specification", this.textBox3.Text.Trim()); cmd.Parameters.AddWithValue("@amount", float.Parse(this.textBox4.Text.Trim().ToString())); cmd.Parameters.AddWithValue("@packing", this.textBox5.Text.Trim()); cmd.Parameters.AddWithValue("@declarationInspectionDate", this.dateTimePicker1.Text.Trim()); cmd.Parameters.AddWithValue("@assayDate", this.dateTimePicker2.Text.Trim()); cmd.Parameters.AddWithValue("@reportDate", this.dateTimePicker3.Text.Trim()); cmd.Parameters.AddWithValue("@commodityBatchNumber", this.textBox8.Text.Trim()); cmd.Parameters.AddWithValue("@inspectionbasis", this.textBox10.Text.Trim()); cmd.Parameters.AddWithValue("@conclusion", this.textBox11.Text.Trim()); cmd.Parameters.AddWithValue("@assessor", this.textBox14.Text.Trim()); cmd.Parameters.AddWithValue("@analyst", this.textBox13.Text.Trim()); cmd.Parameters.AddWithValue("@laboratoryTechnician", this.textBox12.Text.Trim()); int j = cmd.ExecuteNonQuery(); ``` 用以上代码,我为什么不能实现对数据库的操作?显示插入成功,但是数据库中相应字段全都是空的,也就是说,cmd.Parameters.AddWithValue("@laboratoryTechnician", this.textBox12.Text.Trim());中没有给相应的参数赋值,一个也没有,很难受,我不知道怎么改才行。
C#初学者 代码看不懂,求大神,用了DBhelper之后两段代码是怎么实现的
//修改学院信息 private void btnupdate_Click(object sender, EventArgs e) { int index = dgvcollege.CurrentRow.Index; //取得选中行的索引 CollId = dgvcollege.Rows[index].Cells["CollegeId"].Value.ToString(); CollName = dgvcollege.Rows[index].Cells["CollegeName"].Value.ToString(); SaveCollege sc = new SaveCollege(this); sc.Show(); } //添加学院信息 private void btnaddcollege_Click(object sender, EventArgs e) { CollId = "0"; SaveCollege sc = new SaveCollege(this); sc.Show(); }
求助,C#的窗体程序如何进行数据更新。
![图片说明](https://img-ask.csdn.net/upload/201609/09/1473402361_40157.png) ![图片说明](https://img-ask.csdn.net/upload/201609/09/1473402384_189574.png) 在小窗口添加数据后在大窗口的视图同步刷新数据怎么实现啊。。。 这个是小窗口的代码 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; using System.Data.SqlClient; namespace SupperMarket { public partial class FrmEditStore : Form { DataSet ds; SqlDataAdapter sda; public FrmEditStore() { InitializeComponent(); } private void FrmEditStore_Load(object sender, EventArgs e) { GetStoreClass(); this.cboStoreClass.DataSource = ds.Tables["CommoditySort"]; this.cboStoreClass.ValueMember = "SortID"; this.cboStoreClass.DisplayMember = "SortName"; } public void GetStoreClass() { string sql = "select * from CommoditySort"; DBHelper db = new DBHelper(); try { ds = new DataSet(); sda = new SqlDataAdapter(sql, db.Connection); sda.Fill(ds, "CommoditySort"); } catch (Exception) { MessageBox.Show("系统错误!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); } } //是否为特价的控制 private void cbIs_CheckedChanged(object sender, EventArgs e) { if (this.cbIs.Checked == false) { this.nudPriceOf.Enabled = false;//是否禁用用控件 this.nudPriceOf.ReadOnly = true;//是否为只读状态 } else { this.nudPriceOf.Enabled = true; this.nudPriceOf.ReadOnly = false; } } private void btnSave_Click(object sender, EventArgs e) { if (this.txtStoreName.Text.Trim().Length != 0 || this.nudPrice.Value != 0) { int num = SaveStore(); if (num > 0) { MessageBox.Show("商品添加成功!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information); } else if (num == 0) { MessageBox.Show("商品添加失败!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information); } else { MessageBox.Show("系统错误!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); } } else { MessageBox.Show("请填写商品信息!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Information); } } public int SaveStore() { int num; int flag = 0; if (this.cbIs.Checked == false) { num = 0; } else { num = 1; } StringBuilder sb = new StringBuilder(); sb.AppendLine("insert commodity(CommodityName,SortID,CommodityPrice,IsDiscount,ReducedPrice)"); sb.AppendFormat(" values('{0}',{1},{2},'{3}',{4})", this.txtStoreName.Text, this.cboStoreClass.SelectedValue, this.nudPrice.Value, num, this.nudPriceOf.Value); DBHelper db = new DBHelper(); try { db.OpenConnection(); SqlCommand com = new SqlCommand(sb.ToString(), db.Connection); flag = com.ExecuteNonQuery(); } catch (Exception ex) { flag = -1; } finally { db.CloseConnection(); } return flag; } private void btnClean_Click(object sender, EventArgs e) { this.Close(); } } } 大窗口的代码 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Threading.Tasks; using System.Windows.Forms; using System.Data.SqlClient; namespace SupperMarket { public partial class FrmStore : Form { DataSet ds; SqlDataAdapter sda; public FrmStore() { InitializeComponent(); } public void GetStore() { StringBuilder sb = new StringBuilder(); sb.AppendLine("select c.CommodityID,c.CommodityName,cs.SortName,c.CommodityPrice,c.IsDiscount,c.ReducedPrice"); sb.AppendLine(" from commodity c"); sb.AppendLine(" join CommoditySort cs on cs.SortID = c.SortID"); DBHelper db = new DBHelper(); try { ds = new DataSet(); sda = new SqlDataAdapter(sb.ToString(), db.Connection); sda.Fill(ds, "commodity"); } catch (Exception ex) { MessageBox.Show("系统错误!", "提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); } } private void FrmStore_Load(object sender, EventArgs e) { GetStore(); this.dgvStoreDialog.AutoGenerateColumns = false; DataView dv = new DataView(ds.Tables["commodity"]); this.dgvStoreDialog.DataSource = dv; } private void tsbExit_Click(object sender, EventArgs e) { this.Close(); } private void tvStoreClass_AfterSelect(object sender, TreeViewEventArgs e) { int num = this.tvStoreClass.SelectedNode.Level; string choice = this.tvStoreClass.SelectedNode.Text; this.dgvStoreDialog.AutoGenerateColumns = false; DataView dv = new DataView(ds.Tables["commodity"]); int flag = choice.Equals("特价商品") ? 1 : 0; if (num == 1) { dv.RowFilter = string.Format("IsDiscount = {0}", flag); } this.dgvStoreDialog.DataSource = dv; } private void tsbAdd_Click(object sender, EventArgs e) { FrmEditStore fes = new FrmEditStore(); fes.ShowDialog(); } } }
C#渣新求助dataAdapter问题
写了下面这个方法调用了两次,第一次是在FormLoad事件里,成功运行 第二次在按钮事件中未成功,DataGridView没填充数据,也没报错 SQL语句在数据库中运行也没问题 public static void FillMainDgv(string str,DataGridView dgv) { try { dgv.Rows.Clear(); OleDbDataAdapter dataAdapter = new OleDbDataAdapter(str, DBHelper.connection); DataSet dataSet = new DataSet("ds"); dataAdapter.Fill(dataSet, "MainTable"); int i = 1; foreach (DataRow row in dataSet.Tables["MainTable"].Rows) { int index = dgv.Rows.Add(); dgv.Rows[index].Cells["Column1"].Value = Convert.ToString(i); dgv.Rows[index].Cells["id"].Value = row["id"]; dgv.Rows[index].Cells["date"].Value = row["dt"]; dgv.Rows[index].Cells["type"].Value = row["type"]; dgv.Rows[index].Cells["body"].Value = row["body"]; dgv.Rows[index].Cells["money"].Value = row["m"]; dgv.Rows[index].Cells["event1"].Value = row["event"]; dgv.Rows[index].Cells["remark"].Value = row["remark"]; dgv.Rows[index].Cells["time"].Value = row["t"]; i++; } dgv.ClearSelection(); } catch (Exception ex) { MessageBox.Show(ex.Message); } } FormLoad的SQL语句 SELECT id, Format([date], 'yyyy/mm/dd') AS dt, type, body, format([money],'0.00') as m, event, remark, Format([time],'yyyy/mm/dd hh:nn:ss') AS t FROM MainTable WHERE DateDiff('d', [date], #2016/06/01#) <=0 AND DateDiff('d', [date], #2016/06/30#) >=0 ORDER BY [date] DESC Button的SQL语句 SELECT id, Format([date], 'yyyy/mm/dd') AS dt, type, body, format([money],'0.00') as m, event, remark, Format([time],'yyyy/mm/dd hh:nn:ss') AS t FROM MainTable WHERE DateDiff('d', [date], #2016/06/01#) <=0 AND DateDiff('d', [date], #2016/06/30#) >=0 type='支出' AND [event] LIKE '**' OR [remark] LIKE '**' ORDER BY [date] DESC 以上语句在数据库中测试均有结果,请大家帮我看看问题出在什么地方了,谢谢了
c# dataAdapter 修改数据源
我想从数据源取东西放在datagridview上,通过datagridview的增删改再改变数据源。代码写出来,实现不了,请大家帮忙看下。最好是通过两个按钮来实现,一个查询,一个确定修改. 代码如下: string rateSql = string.Format(@"select r_time_int,r_time_unit,r_rate from rate where r_p_id = {0}", productId); OleDbCommand rateSqlCmd = new OleDbCommand(rateSql, DBHelper.conn); OleDbDataAdapter rateSqlAdp = new OleDbDataAdapter(rateSqlCmd); ds = new DataSet(); rateSqlAdp.Fill(ds); DataTable dt = ds.Tables[0]; OleDbCommandBuilder cmdb = new OleDbCommandBuilder(rateSqlAdp); rateSqlAdp.Update(ds); dataGridView1.DataSource = dt;
C#谁能帮我看看那里出问题了
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Data.SqlClient; namespace SuperMarket { class manager { public Array[] show(string sql) { DBHelper db = new DBHelper(); int i = 0; Array[] arr = new Array[100]; try { SqlCommand comm = new SqlCommand(sql,db.Conn); db.Open(); SqlDataReader read = comm.ExecuteReader(); while (read.Read()) { Page pa = new Page(); pa.Goodsld = Convert.ToInt32(read["Goodsld"]); pa.GoodName = read["GoodName"].ToString(); pa.Price = read["Price"].ToString(); pa.TypeName = read["TypeName"].ToString(); pa.ProdureCounts = Convert.ToInt32(read["ProdureCounts"]); arr[i] = pa(此处报错); i++; } } catch (Exception) { Console.WriteLine("异常"); } finally { db.Close(); } return arr; } public int show1(string sql) { DBHelper db = new DBHelper(); int k = 0 ; try { SqlCommand comm = new SqlCommand(sql, db.Conn); db.Open(); k = (int)comm.ExecuteNonQuery(); } catch (Exception) { Console.WriteLine("异常"); } finally { db.Close(); } return k; } } } using System; using System.Collections.Generic; using System.Linq; using System.Text; namespace SuperMarket { class sqlmanager { Page pa = new Page(); manager man = new manager(); public void showmanager() { Console.WriteLine("1.查询全部物品信息"); Console.WriteLine("2.查询指定商品价格"); Console.WriteLine("3.增加物品信息"); Console.WriteLine("输入其他字符串退出系统"); int num = Convert.ToInt32(Console.ReadLine()); if (num == 1) { sqla(); } else if (num==2) { sqlb(); } else if (num == 3) { sqlc(); } } public void sqla() { string sql = "select * from Goods"; Array[] arr = man.show(sql); foreach (Array item in arr) { if (item != null) { Console.WriteLine("{0},{1},{2},{3},{4}",pa.Goodsld,pa.GoodName,pa.Price,pa.TypeName,pa.ProdureCounts); } } }
C#窗体实现在线答题系统时代码无bug能运行,但不显示题目信息,求问怎么回事?
数据库那边没有问题,连接语句在别的窗体也能用,怀疑是questionIndex的问题,求大神帮忙看下怎么改 using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Text; using System.Data.SqlClient; using System.Windows.Forms; using System.Collections; namespace graduationproject { public partial class PsychologicalTest : Form { public int questionIndex = 1; public PsychologicalTest() { InitializeComponent(); } private void PsychologicalTest_Load(object sender, EventArgs e) { timer1.Start(); // 启动计时器 GetQuestionDetails(); // 显示题目信息 CheckOption();    // 如果题目已经答过,让相应的选项选中 CheckBtnNext();   // 确定是否到了最后一题 } private void CheckBtnNext() { // 如果达到20题,就让“下一题”按钮的文字显示为“提交” if (questionIndex >= QuizHelper.selectedQuestionIds.Length) { button2.Text = "提交"; } } private void button2_Click(object sender, EventArgs e) { // 如果没有到最后一题,就继续显示新题目信息 if (questionIndex < QuizHelper.selectedQuestionIds.Length) { questionIndex++; GetQuestionDetails(); // 显示试题信息 CheckOption(); // 如果题目已经答过,让相应的选项选中 CheckBtnNext();   // 确定是否到了最后一题 } else // 否则,打开答题卡窗体 { OpenResultCard(); } } private void OpenResultCard() { PsychologicalTestResult psychologicalTestResult = new PsychologicalTestResult(); psychologicalTestResult.MdiParent = this.MdiParent; psychologicalTestResult.Show(); this.Close(); } private void timer1_Tick(object sender, EventArgs e) { int minute; // 当前的分钟 int second; // 秒 // 如果还有剩余时间,就显示剩余的分钟和秒数 if (QuizHelper.remainSeconds > 0) { QuizHelper.remainSeconds--; minute = QuizHelper.remainSeconds / 60; second = QuizHelper.remainSeconds % 60; label4.Text = string.Format("{0:00}:{1:00}", minute, second); } // 否则,就提示交卷 else { timer1.Stop(); MessageBox.Show("时间到了!", "温馨提示", MessageBoxButtons.OK, MessageBoxIcon.Warning); this.Close(); } } private void radioButton_Click(object sender, EventArgs e) { QuizHelper.studentAnswers[questionIndex] = Convert.ToString(((RadioButton)sender).Tag); } public void GetQuestionDetails() { // 显示当前的题目信息 label1.Text = string.Format("第{0}题:", questionIndex); // 查询题目信息的sql语句 string sql = "SELECT Question FROM PsyQuestion WHERE QNumber=questionIndex "; SqlConnection conn = new SqlConnection("Data Source=.;Initial Catalog=graduationproject;Integrated Security=true"); try { conn.Open(); SqlCommand command = new SqlCommand(sql, conn); SqlDataReader reader = command.ExecuteReader(); if (reader.Read()) { label3.Text = reader["Question"].ToString(); } reader.Close(); } catch (Exception ex) { Console.WriteLine(ex.Message); } finally { DBHelper.connection.Close(); } } private void CheckOption() { switch (QuizHelper.studentAnswers[questionIndex]) { case "A": radioButton1.Checked = true; break; case "B": radioButton2.Checked = true; break; case "C": radioButton3.Checked = true; break; default: radioButton1.Checked = false; radioButton2.Checked = false; radioButton3.Checked = false; break; } } } }
C#新手提问 dataAdapter 如何通过datagridview修改数据源
点击查询按钮,通过dataAdapter 从数据库里取数据放在datagridview里 再在datagridview里添加、删除、修改,然后点击 更改 按钮修改数据库里的数据。 请问如何实现。我写了一点基础代码,但是不成功。 感激不尽,代码如下: string rateSql = string.Format(@"select r_time_int,r_time_unit,r_rate from rate where r_p_id = {0}", productId); OleDbCommand rateSqlCmd = new OleDbCommand(rateSql, DBHelper.conn); OleDbDataAdapter rateSqlAdp = new OleDbDataAdapter(rateSqlCmd); ds = new DataSet(); rateSqlAdp.Fill(ds); DataTable dt = ds.Tables[0]; OleDbCommandBuilder cmdb = new OleDbCommandBuilder(rateSqlAdp); rateSqlAdp.Update(ds); dataGridView1.DataSource = dt;
c#这段代码向数据库批量添加数据为何1000行就需要10分钟啊求大神帮忙优化啊
public void ShuaXin() { SqlCommand com = new SqlCommand("delete from priceavg", DBHelper.con); DBHelper.con.Open(); com.ExecuteNonQuery(); adapter = new SqlDataAdapter("select * from priceavg", DBHelper.con); adapter.Fill(set, "avgs"); DataTable t = set.Tables["avgs"]; pros = new List<ProPrice>(); com.CommandText = "select proid from proprice where newprice=1"; SqlDataReader re = com.ExecuteReader(); ProPrice pp = null; while (re.Read()) { pp = new ProPrice() { ProID = Convert.ToInt32(re["ProID"]) }; pros.Add(pp); } re.Close(); DBHelper.con.Close(); //刷新上个月价格 for (int i = 0; i < 1000; i++) { DBHelper.con.Open(); com.CommandText = string.Format("select ptype from product where id={0} ", pros[i].ProID); if (com.ExecuteScalar() == null) { DBHelper.con.Close(); continue; } int id = (int)com.ExecuteScalar(); DBHelper.con.Close(); DateTime beginTime = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddMonths(-1); //获取本月的月份然后减去一个月 DateTime finishTime = DateTime.Parse(DateTime.Now.ToString("yyyy-MM-01")).AddDays(-1); if (set.Tables["Avg1"] != null) { set.Tables.Remove("Avg1"); } string sql = string.Format("select " + getSqlWhere(id) + " from proprice where proid={0} and addtime between '{1}' and '{2}'", pros[i].ProID, beginTime, finishTime); adapter = new SqlDataAdapter(sql, DBHelper.con); adapter.Fill(set, "Avg1"); DataTable dt = set.Tables["Avg1"]; string[] strs = new string[dt.Columns.Count + 1]; int count1 = 0; if (dt.Columns.Count == 1) { strs = new string[dt.Columns.Count + 1]; } double avg = 0; for (int j = 0; j < dt.Columns.Count; j++) { double num = 0; int count = 0; for (int c = 0; c < dt.Rows.Count; c++) { if (dt.Rows[c][j] is DBNull || dt.Rows[c][j] == null) { count++; continue; } if ((dt.Rows[c][j]).ToString() == "非数字") { count++; continue; } if (Convert.ToDouble(dt.Rows[c][j]) == 0) { count++; continue; } num += Convert.ToDouble(dt.Rows[c][j]); } strs[j] = Math.Round(num / (dt.Rows.Count - count), 2).ToString(); if (strs[j] == "非数字") { count1++; } else { avg += Convert.ToDouble(strs[j]); } } strs[strs.Length - 1] = Math.Round((avg / (strs.Length - 1 - count1)), 2).ToString(); DBHelper.con.Open(); com.CommandText = string.Format("select count(*) from product where id={0} ", pros[i].ProID); if ((int)com.ExecuteScalar() == 0) { DBHelper.con.Close(); continue; } DBHelper.con.Close(); DBHelper.con.Open(); com.CommandText = string.Format("select IsSeason,ProDescription,ID,ProductImage,Spec,ProAddress,MaoZhong,JingZhong from product where id={0}", Convert.ToInt32(pros[i].ProID)); re = com.ExecuteReader(); Model.Product p1 = null; if (re.Read()) { p1 = new Model.Product() { IsSeason = Convert.ToInt32(re["IsSeason"]), ProDescription = re["ProDescription"].ToString(), ID = Convert.ToInt32(re["ID"]), ProductImage = re["ProductImage"].ToString(), Spec = re["Spec"].ToString(), ProAddress = re["ProAddress"].ToString(), MaoZhong = re["MaoZhong"].ToString(), JingZhong = re["JingZhong"].ToString() }; } re.Close(); DBHelper.con.Close(); string[] ss = insertSqls(id); DataRow row = t.NewRow(); row["IsSeason"] = p1.IsSeason; row["ProDescription"] = p1.ProDescription; row["编号"] = p1.ID; row["图片"] = p1.ProductImage; row["品名"] = PinMing(Convert.ToInt32(pros[i].ProID)); row["规格"] = p1.Spec; row["产地"] = p1.ProAddress; row["毛重"] = p1.MaoZhong; row["净重"] = p1.JingZhong; row["isnoBiaoZhunJin"] = 0; row["isnoBiaoZhunJinls"] = 0; int nb = 0; if (insertSql(id).Trim() == "pavgprice") { strs = new string[] { strs[0] }; } for (int m = 0; m < strs.Length; m++) { if (strs[m] == "非数字") { strs[m] = "0"; } if (strs[m] == null) { strs[m] = "0"; } if (strs[m] == "0") { nb++; } row[ss[m].Trim()] = strs[m]; } row["timetype"] = 1; t.Rows.Add(row); } SqlBulkCopy sqlbulkcopy = new SqlBulkCopy(DBHelper.con.ConnectionString, SqlBulkCopyOptions.UseInternalTransaction); sqlbulkcopy.DestinationTableName = "priceAvg"; for (int i = 0; i < t.Columns.Count; i++) { sqlbulkcopy.ColumnMappings.Add(t.Columns[i].ColumnName, t.Columns[i].ColumnName); } sqlbulkcopy.WriteToServer(t); } ``` ```
C#哪位大神帮我看下,我哪里错了
代码如下: //点击删除 private void delete_btn_Click(object sender, EventArgs e) { if (productId == -1) { MessageBox.Show("请先选择产品"); return; } MessageBox.Show(productId.toString()); DBHelper.conn.Open(); OleDbTransaction tran = DBHelper.conn.BeginTransaction(); string deleteProduct = string.Format(@"update product set p_delete_flag = 1 where p_id = {0}", productId); OleDbCommand deleteProductCmd = new OleDbCommand(deleteProduct, DBHelper.conn); deleteProductCmd.Transaction = tran; string deleteRate = string.Format(@"update rate set r_delete_flag = 1 where r_p_id = {0}", productId); OleDbCommand deleteRateCmd = new OleDbCommand(deleteRate, DBHelper.conn); deleteRateCmd.Transaction = tran; try { int a = deleteProductCmd.ExecuteNonQuery(); MessageBox.Show(a.ToString()); int b = deleteRateCmd.ExecuteNonQuery(); MessageBox.Show(b.ToString()); MessageBox.Show("删除成功"); } catch (Exception ex) { MessageBox.Show(ex.Message); tran.Rollback(); } finally { deleteProductCmd.Dispose(); deleteRateCmd.Dispose(); DBHelper.conn.Close(); } } productId = 21 a= 1 数据库确实是一行 b=2 数据库里确实存在两行 返回数据库一看。。。一点没变
公司有几个教育管理老项目,只用了aspx页面 + dbhelper,请问这处于什么水平?
关键是,现在有接到一个相同的项目,领导说拿旧的改改就可以了,但是只要一个地方报错,其他项目全部都要改,很难维护
EF 和 dbhelper 结合在一起使用
如查询一个订单,页面上有单号、日期等输入框,有输入的时候才过滤,用EF是怎么去玩的? 如果我用 helper 是封装起来的,db.query("select * from a").filter("billno").filter("billdate").tojson(); .filter 大概这样 if(request["billno"]).isnull())return "" else return "billno='"+request["billno"]+"'"; 如果EF,能实现类似的效果吗? 其实我是想问,怎么可以 dbhelper结合到 ef里面。。因为如果单独起来,两个一起用,就会有两个连接,这样感觉不是很爽。。
实例化DbHelper时报错,DbHelper的类型初始值设定项引发异常
![调用db工厂方法实例化继承了IDatabase, IDisposable两个接口的类Database](https://img-ask.csdn.net/upload/201605/14/1463202236_223971.png) ![进入方法体,调用DataFactory的Database方法](https://img-ask.csdn.net/upload/201605/14/1463202348_846602.png)![进入方法体](https://img-ask.csdn.net/upload/201605/14/1463202468_754107.png)![db为静态字符串](https://img-ask.csdn.net/upload/201605/14/1463202520_648942.png)![实例化DbHelper](https://img-ask.csdn.net/upload/201605/14/1463202562_969138.png)![异常信息](https://img-ask.csdn.net/upload/201605/14/1463202591_386282.png)![数据库连接字符串](https://img-ask.csdn.net/upload/201605/14/1463202610_793776.png) 麻烦各位能帮我看看什么原因吗?
怎么执行存储过程,求赐教
{ //SQL注入式攻击 try { SqlDataAdapter da = new SqlDataAdapter(sql, connString); if (para != null) { da.SelectCommand.CommandType=type; da.SelectCommand.Parameters.AddRange(para); } DataTable dt = new DataTable(); da.Fill(dt); return dt; } catch (Exception) ---------------------------------- SqlParameter[] para ={ new SqlParameter("@pageIndex",1), new SqlParameter("@pageSize",5) }; DataTable dt = DBHelper.ExecuteSelect(CommandType.StoredProcedure, "pro_User", para); 一直提示存储过程参数为赋值.
用数据集DataSet绑定的数据怎样传到Label控件上?
在数据访问层 public class TradeService { static StringBuilder sb = new StringBuilder(); //连接数据库获取用户订票数据 public static DataSet GetTrade() { DataSet ds = null; try { SqlConnection conn = new SqlConnection(DBHelper.connString); string sql = "………查询语句省略………"; SqlDataAdapter ad = new SqlDataAdapter(sql, conn); ds = new DataSet(); if (ds.Tables["tradeList.seatNO"] != null) { ds.Tables["tradeList"].Clear(); } ad.Fill(ds, "tradeList"); } catch (Exception ex) { throw ex; } return ds; } }
终于明白阿里百度这样的大公司,为什么面试经常拿ThreadLocal考验求职者了
点击上面↑「爱开发」关注我们每晚10点,捕获技术思考和创业资源洞察什么是ThreadLocalThreadLocal是一个本地线程副本变量工具类,各个线程都拥有一份线程私有的数
Java学习的正确打开方式
在博主认为,对于入门级学习java的最佳学习方法莫过于视频+博客+书籍+总结,前三者博主将淋漓尽致地挥毫于这篇博客文章中,至于总结在于个人,实际上越到后面你会发现学习的最好方式就是阅读参考官方文档其次就是国内的书籍,博客次之,这又是一个层次了,这里暂时不提后面再谈。博主将为各位入门java保驾护航,各位只管冲鸭!!!上天是公平的,只要不辜负时间,时间自然不会辜负你。 何谓学习?博主所理解的学习,它是一个过程,是一个不断累积、不断沉淀、不断总结、善于传达自己的个人见解以及乐于分享的过程。
程序员必须掌握的核心算法有哪些?
由于我之前一直强调数据结构以及算法学习的重要性,所以就有一些读者经常问我,数据结构与算法应该要学习到哪个程度呢?,说实话,这个问题我不知道要怎么回答你,主要取决于你想学习到哪些程度,不过针对这个问题,我稍微总结一下我学过的算法知识点,以及我觉得值得学习的算法。这些算法与数据结构的学习大多数是零散的,并没有一本把他们全部覆盖的书籍。下面是我觉得值得学习的一些算法以及数据结构,当然,我也会整理一些看过
大学四年自学走来,这些私藏的实用工具/学习网站我贡献出来了
大学四年,看课本是不可能一直看课本的了,对于学习,特别是自学,善于搜索网上的一些资源来辅助,还是非常有必要的,下面我就把这几年私藏的各种资源,网站贡献出来给你们。主要有:电子书搜索、实用工具、在线视频学习网站、非视频学习网站、软件下载、面试/求职必备网站。 注意:文中提到的所有资源,文末我都给你整理好了,你们只管拿去,如果觉得不错,转发、分享就是最大的支持了。 一、电子书搜索 对于大部分程序员...
《奇巧淫技》系列-python!!每天早上八点自动发送天气预报邮件到QQ邮箱
此博客仅为我业余记录文章所用,发布到此,仅供网友阅读参考,如有侵权,请通知我,我会删掉。 补充 有不少读者留言说本文章没有用,因为天气预报直接打开手机就可以收到了,为何要多此一举发送到邮箱呢!!!那我在这里只能说:因为你没用,所以你没用!!! 这里主要介绍的是思路,不是天气预报!不是天气预报!!不是天气预报!!!天气预报只是用于举例。请各位不要再刚了!!! 下面是我会用到的两个场景: 每日下
Python 植物大战僵尸代码实现(2):植物卡片选择和种植
这篇文章要介绍的是: - 上方植物卡片栏的实现。 - 点击植物卡片,鼠标切换为植物图片。 - 鼠标移动时,判断当前在哪个方格中,并显示半透明的植物作为提示。
死磕YOLO系列,YOLOv1 的大脑、躯干和手脚
YOLO 是我非常喜欢的目标检测算法,堪称工业级的目标检测,能够达到实时的要求,它帮我解决了许多实际问题。 这就是 YOLO 的目标检测效果。它定位了图像中物体的位置,当然,也能预测物体的类别。 之前我有写博文介绍过它,但是每次重新读它的论文,我都有新的收获,为此我准备写一个系列的文章来详尽分析它。这是第一篇,从它的起始 YOLOv1 讲起。 YOLOv1 的论文地址:https://www.c
知乎高赞:中国有什么拿得出手的开源软件产品?(整理自本人原创回答)
知乎高赞:中国有什么拿得出手的开源软件产品? 在知乎上,有个问题问“中国有什么拿得出手的开源软件产品(在 GitHub 等社区受欢迎度较好的)?” 事实上,还不少呢~ 本人于2019.7.6进行了较为全面的 回答 - Bravo Yeung,获得该问题下回答中得最高赞(236赞和1枚专业勋章),对这些受欢迎的 Github 开源项目分类整理如下: 分布式计算、云平台相关工具类 1.SkyWalk
记一次腾讯面试:进程之间究竟有哪些通信方式?如何通信? ---- 告别死记硬背
有一次面试的时候,被问到进程之间有哪些通信方式,不过由于之前没深入思考且整理过,说的并不好。想必大家也都知道进程有哪些通信方式,可是我猜很多人都是靠着”背“来记忆的,所以今天的这篇文章,讲给大家详细着讲解他们是如何通信的,让大家尽量能够理解他们之间的区别、优缺点等,这样的话,以后面试官让你举例子,你也能够顺手拈来。 1、管道 我们来看一条 Linux 的语句 netstat -tulnp | gr...
20行Python代码爬取王者荣耀全英雄皮肤
引言 王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤,而且仅仅使用20行Python代码即可完成。 准备工作 爬取皮肤本身并不难,难点在于分析,我们首先得得到皮肤图片的url地址,话不多说,我们马上来到王者荣耀的官网: 我们点击英雄资料,然后随意地选择一位英雄,接着F12打开调试台,找到英雄原皮肤的图片
网络(8)-HTTP、Socket、TCP、UDP的区别和联系
TCP/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据。 一、TCP与UDP的不同 1. 是否需要建立连接。 UDP在传送数据之前不需要先建立连接;TCP则提供面向连接的服务; 2. 是否需要给出确认 对方的传输层在收到UDP报文后,不需要给出任何确认,而 TCP需要给出确认报文,要提供可靠的、面向连接的传输服务。 3.虽然UDP不提供可靠交...
简明易理解的@SpringBootApplication注解源码解析(包含面试提问)
欢迎关注文章系列 ,关注我 《提升能力,涨薪可待》 《面试知识,工作可待》 《实战演练,拒绝996》 欢迎关注我博客,原创技术文章第一时间推出 也欢迎关注公 众 号【Ccww笔记】,同时推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《提升能力,涨薪可待篇》- @SpringBootApplication注解源码解析 一、@SpringBootApplication 的作用是什
防劝退!数据结构和算法难理解?可视化动画带你轻松透彻理解!
大家好,我是 Rocky0429,一个连数据结构和算法都不会的蒟蒻… 学过数据结构和算法的都知道这玩意儿不好学,没学过的经常听到这样的说法还没学就觉得难,其实难吗?真难! 难在哪呢?当年我还是个小蒟蒻,初学数据结构和算法的时候,在忍着枯燥看完定义原理,之后想实现的时候,觉得它们的过程真的是七拐八绕,及其难受。 在简单的链表、栈和队列这些我还能靠着在草稿上写写画画理解过程,但是到了数论、图...
西游记团队中如果需要裁掉一个人,会先裁掉谁?
2019年互联网寒冬,大批企业开始裁员,下图是网上流传的一张截图: 裁员不可避免,那如何才能做到不管大环境如何变化,自身不受影响呢? 我们先来看一个有意思的故事,如果西游记取经团队需要裁员一名,会裁掉谁呢,为什么? 西游记团队组成: 1.唐僧 作为团队teamleader,有很坚韧的品性和极高的原则性,不达目的不罢休,遇到任何问题,都没有退缩过,又很得上司支持和赏识(直接得到唐太宗的任命,既给
开挂的人生!那些当选院士,又是ACM/IEEE 双料Fellow的华人学者们
昨日,2019年两院院士正式官宣,一时间抢占了各大媒体头条。 朋友圈也是一片沸腾,奔走相告,赶脚比自己中了大奖还嗨皮! 谁叫咱家导师就是这么厉害呢!!! 而就在最近,新一年度的IEEE/ACM Fellow也将正式公布。 作为学术届的顶级荣誉,不自然地就会将院士与Fellow作比较,到底哪个含金量更高呢? 学术君认为,同样是专业机构对学者的认可,考量标准不一,自然不能一概而论。 但...
聊聊C语言和指针的本质
坐着绿皮车上海到杭州,24块钱,很宽敞,在火车上非正式地聊几句。 很多编程语言都以 “没有指针” 作为自己的优势来宣传,然而,对于C语言,指针却是与生俱来的。 那么,什么是指针,为什么大家都想避开指针。 很简单, 指针就是地址,当一个地址作为一个变量存在时,它就被叫做指针,该变量的类型,自然就是指针类型。 指针的作用就是,给出一个指针,取出该指针指向地址处的值。为了理解本质,我们从计算机模型说起...
Python语言高频重点汇总
Python语言高频重点汇总 GitHub面试宝典仓库——点这里跳转 文章目录Python语言高频重点汇总**GitHub面试宝典仓库——点这里跳转**1. 函数-传参2. 元类3. @staticmethod和@classmethod两个装饰器4. 类属性和实例属性5. Python的自省6. 列表、集合、字典推导式7. Python中单下划线和双下划线8. 格式化字符串中的%和format9.
究竟你适不适合买Mac?
我清晰的记得,刚买的macbook pro回到家,开机后第一件事情,就是上了淘宝网,花了500元钱,找了一个上门维修电脑的师傅,上门给我装了一个windows系统。。。。。。 表砍我。。。 当时买mac的初衷,只是想要个固态硬盘的笔记本,用来运行一些复杂的扑克软件。而看了当时所有的SSD笔记本后,最终决定,还是买个好(xiong)看(da)的。 已经有好几个朋友问我mba怎么样了,所以今天尽量客观
代码详解:如何用Python快速制作美观、炫酷且有深度的图表
全文共12231字,预计学习时长35分钟生活阶梯(幸福指数)与人均GDP(金钱)正相关的正则图本文将探讨三种用Python可视化数据的不同方法。以可视化《2019年世界幸福报告》的数据为例,本文用Gapminder和Wikipedia的信息丰富了《世界幸福报告》数据,以探索新的数据关系和可视化方法。《世界幸福报告》试图回答世界范围内影响幸福的因素。报告根据对“坎特里尔阶梯问题”的回答来确定幸...
程序员一般通过什么途径接私活?
二哥,你好,我想知道一般程序猿都如何接私活,我也想接,能告诉我一些方法吗? 上面是一个读者“烦不烦”问我的一个问题。其实不止是“烦不烦”,还有很多读者问过我类似这样的问题。 我接的私活不算多,挣到的钱也没有多少,加起来不到 20W。说实话,这个数目说出来我是有点心虚的,毕竟太少了,大家轻喷。但我想,恰好配得上“一般程序员”这个称号啊。毕竟苍蝇再小也是肉,我也算是有经验的人了。 唾弃接私活、做外
(经验分享)作为一名普通本科计算机专业学生,我大学四年到底走了多少弯路
今年正式步入了大四,离毕业也只剩半年多的时间,回想一下大学四年,感觉自己走了不少弯路,今天就来分享一下自己大学的学习经历,也希望其他人能不要走我走错的路。 (一)初进校园 刚进入大学的时候自己完全就相信了高中老师的话:“进入大学你们就轻松了”。因此在大一的时候自己学习的激情早就被抛地一干二净,每天不是在寝室里玩游戏就是出门游玩,不过好在自己大学时买的第一台笔记本性能并不是很好,也没让我彻底沉...
如何写一篇技术博客,谈谈我的看法
前言 只有光头才能变强。 文本已收录至我的GitHub精选文章,欢迎Star:https://github.com/ZhongFuCheng3y/3y 我一直推崇学技术可以写技术博客去沉淀自己的知识,因为知识点实在是太多太多了,通过自己的博客可以帮助自己快速回顾自己学过的东西。 我最开始的时候也是只记笔记,认为自己能看得懂就好。但如果想验证自己是不是懂了,可以写成技术博客。在写技术博客的...
字节跳动面试官这样问消息队列:分布式事务、重复消费、顺序消费,我整理了一下
你知道的越多,你不知道的越多 点赞再看,养成习惯 GitHub上已经开源 https://github.com/JavaFamily 有一线大厂面试点脑图、个人联系方式和人才交流群,欢迎Star和完善 前言 消息队列在互联网技术存储方面使用如此广泛,几乎所有的后端技术面试官都要在消息队列的使用和原理方面对小伙伴们进行360°的刁难。 作为一个在互联网公司面一次拿一次Offer的面霸...
面试还搞不懂redis,快看看这40道面试题(含答案和思维导图)
Redis 面试题 1、什么是 Redis?. 2、Redis 的数据类型? 3、使用 Redis 有哪些好处? 4、Redis 相比 Memcached 有哪些优势? 5、Memcache 与 Redis 的区别都有哪些? 6、Redis 是单进程单线程的? 7、一个字符串类型的值能存储最大容量是多少? 8、Redis 的持久化机制是什么?各自的优缺点? 9、Redis 常见性...
大学四年自学走来,这些珍藏的「实用工具/学习网站」我全贡献出来了
知乎高赞:文中列举了互联网一线大厂程序员都在用的工具集合,涉及面非常广,小白和老手都可以进来看看,或许有新收获。
互联网公司的裁员,能玩出多少种花样?
裁员,也是一门学问,可谓博大精深!以下,是互联网公司的裁员的多种方法:-正文开始-135岁+不予续签的理由:千禧一代网感更强。95后不予通过试用期的理由:已婚已育员工更有责任心。2通知接下来要过苦日子,让一部分不肯同甘共苦的员工自己走人,以“兄弟”和“非兄弟”来区别员工。3强制996。员工如果平衡不了工作和家庭,可在离婚或离职里二选一。4不布置任何工作,但下班前必须提交千字工作日报。5不给活干+...
【设计模式】单例模式的八种写法分析
网上泛滥流传单例模式的写法种类,有说7种的,也有说6种的,当然也不排除说5种的,他们说的有错吗?其实没有对与错,刨根问底,写法终究是写法,其本质精髓大体一致!因此完全没必要去追究写法的多少,有这个时间还不如跟着宜春去网吧偷耳机、去田里抓青蛙得了,一天天的....
《面试宝典》:检验是否为合格的初中级程序员的面试知识点,你都知道了吗?查漏补缺
欢迎关注文章系列,一起学习 《提升能力,涨薪可待篇》 《面试知识,工作可待篇》 《实战演练,拒绝996篇》 也欢迎关注公 众 号【Ccww笔记】,原创技术文章第一时间推出 如果此文对你有帮助、喜欢的话,那就点个赞呗,点个关注呗! 《面试知识,工作可待篇》-Java笔试面试基础知识大全 前言 是不是感觉找工作面试是那么难呢? 在找工作面试应在学习的基础进行总结面试知识点,工作也指日可待,欢...
关于研发效能提升的思考
研发效能提升是最近比较热门的一个话题,本人根据这几年的工作心得,做了一些思考总结,由于个人深度有限,暂且抛转引入。 三要素 任何生产力的提升都离不开这三个因素:人、流程和工具,少了其中任何一个因素都无法实现。 人,即思想,也就是古人说的“道”,道不同不相为谋,是制高点,也是高层建筑的基石。 流程,即方法,也是古人说的“法”。研发效能的提升,也就是要提高投入产出比,既要增加产出,也要减...
微博推荐算法简述
在介绍微博推荐算法之前,我们先聊一聊推荐系统和推荐算法。有这样一些问题:推荐系统适用哪些场景?用来解决什么问题、具有怎样的价值?效果如何衡量? 推荐系统诞生很早,但真正被大家所重视,缘起于以”facebook”为代表的社会化网络的兴起和以“淘宝“为代表的电商的繁荣,”选择“的时代已经来临,信息和物品的极大丰富,让用户如浩瀚宇宙中的小点,无所适从。推荐系统迎来爆发的机会,变得离用户更近: 快...
相关热词 c# 数组类型 泛型约束 c#的赛狗日程序 c# 传递数组 可变参数 c# 生成存储过程 c# list 补集 c#获得所有窗体 c# 当前秒数转成年月日 c#中的枚举 c# 计算校验和 连续随机数不重复c#
立即提问