峰峦@叠嶂 2023-02-15 08:34 采纳率: 97.6%
浏览 32
已结题

如何按时间段来取数据,及优化SQL语句;

请教一下,我从数据库的取值语句如下,是采用datagridview和文本框text结合使用,下面想采用按时间段来查询(如所附截图所框),所查结果并按时间,降序排序,请各位指导一下如何处理,

另外,这些相关语句是否需要分开,若是在同一条语句上写,是否太长了;

img


 private void button1_Click(object sender, EventArgs e)
        {
            //连接数据库
            conn = new SqlConnection("server=IP;database=DB;user=sa;password=passw0rd");

            conn.Open();

            //查询条件      
            SqlString = "select EquipmentName,CreateTime,ParamsName,Value from b_HistoricalData where Equipmentname = '" + comboBox1.Text + "'and ParamsName like '%" + textBox1.Text + "%'"; 
                
                //配置了与下拉列表绑定,按其查询分类显示
            //加载数据并显示

            try
            {
                //查询条件和SqlConnection连接
                SqlCommand cmd = new SqlCommand(SqlString, conn);
                //数据适配器
                SqlDataAdapter sda = new SqlDataAdapter();
                sda.SelectCommand = cmd;
                //DataTable存储数据
                DataTable dt = new DataTable();
                sda.Fill(dt);
                dataGridView1.DataSource = dt;
            }
            catch
            { }
            finally
            {
                conn.Close();
            }
  • 写回答

5条回答 默认 最新

  • GISer Liu 2023-02-15 09:29
    关注

    以下答案引用自GPT-3大模型,请合理使用:

    如果要按时间段来查询并降序排序,可以使用如下的SQL语句:
    select EquipmentName,CreateTime,ParamsName,Value from b_HistoricalData 
    where Equipmentname = 'xxx'and ParamsName like '%yyy%' 
    and CreateTime between '2018-01-01' and '2020-01-01'
    ORDER BY CreateTime DESC;
    
    在上述SQL语句中,'xxx''yyy'分别可以用comboBox1.Text和textBox1.Text来替换,而'2018-01-01''2020-01-01'可以替换为你的起始时间和结束时间。最后,根据你发布的截图,应该可以使用DateTimePicker来替换上面的时间,获得dateTimePicker的时间可以使用语句dateTimePicker1.Value.ToString("yyyy-MM-dd")。
    
    
    所以,最终的SQL语句可以改写为:
    select EquipmentName,CreateTime,ParamsName,Value from b_HistoricalData 
    where Equipmentname = '" + comboBox1.Text + "'and ParamsName like '%" + textBox1.Text + "%' 
    and CreateTime between '" + dateTimePicker1.Value.ToString("yyyy-MM-dd") + "' and '" + dateTimePicker2.Value.ToString("yyyy-MM-dd") + "' 
    ORDER BY CreateTime DESC;
    
    如果是在同一条语句上编写,不会太长,但是建议还是将这两个条件分开,也更加直观易懂。
    

    如果我的回答解决了您的问题,请采纳我的回答

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(4条)

报告相同问题?

问题事件

  • 系统已结题 2月25日
  • 已采纳回答 2月17日
  • 创建了问题 2月15日

悬赏问题

  • ¥20 wireshark抓不到vlan
  • ¥20 关于#stm32#的问题:需要指导自动酸碱滴定仪的原理图程序代码及仿真
  • ¥20 设计一款异域新娘的视频相亲软件需要哪些技术支持
  • ¥15 stata安慰剂检验作图但是真实值不出现在图上
  • ¥15 c程序不知道为什么得不到结果
  • ¥40 复杂的限制性的商函数处理
  • ¥15 程序不包含适用于入口点的静态Main方法
  • ¥15 素材场景中光线烘焙后灯光失效
  • ¥15 请教一下各位,为什么我这个没有实现模拟点击
  • ¥15 执行 virtuoso 命令后,界面没有,cadence 启动不起来