峰峦@叠嶂 2023-02-15 08:34 采纳率: 99.5%
浏览 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日

悬赏问题

  • ¥15 docker环境配置
  • ¥20 绿盟安全扫描--检测到目标站点存在javascript框架库漏洞
  • ¥30 Android STD快速启动
  • ¥15 如何使用simulink建立一个永磁同步直线电机模型?
  • ¥30 天体光谱图的的绘制并得到星表
  • ¥15 PointNet++的onnx模型只能使用一次
  • ¥20 西南科技大学数字信号处理
  • ¥15 有两个非常“自以为是”烦人的问题急期待大家解决!
  • ¥30 STM32 INMP441无法读取数据
  • ¥15 R语言绘制密度图,一个密度曲线内fill不同颜色如何实现