weixin_43747032 2022-07-08 16:23 采纳率: 100%
浏览 68
已结题

SQL语法错误,如何解决?

问题遇到的现象和发生背景

提示 string sql 后面语句有语法错误

问题相关代码,请勿粘贴截图
float a = 285;          
            string conStr = "server=DESKTOP-VAS78Q7\\SQLEXPRESS;database=db_test;uid=sa;pwd=123"; 
           SqlConnection conn = new SqlConnection(conStr);
            conn.Open();       
            string sql = "( select * from T4 where X11 <  '" + a + "' order by X11 desc limit 1 ) union( select * from T4 where X11 >  '" + a + "' order by X11 limit 1)";
            SqlCommand Cmd = new SqlCommand(sql, conn);
            SqlDataReader db = Cmd.ExecuteReader();n
            if (db.Read())
            {
                double x11 = Convert.ToDouble(db["X11"]);
                double y11 = Convert.ToDouble(db["Y11"]);
                conn.Close();
            }

运行结果及报错内容

SqlDataReader db = Cmd.ExecuteReader(); 其他信息: 关键字 'order' 附近有语法错误。

我的解答思路和尝试过的方法

我想要达到的结果

我需要实现想在C#中实现在数据库列X11中找到与数值a大小相邻的两个数。比如a=101,想查找出X11中100和105这两个数所在的行,X11为0 5 10 15等这样间隔的一串数据。并且把X11为100和105的行其他列数据读取出来。

  • 写回答

2条回答 默认 最新

  • foreverliuyin 2022-07-08 17:16
    关注
    "(select * from (select top 1 * from T4 where X11 <  '" + a + "' order by X11 desc) tt1) union (select * from (select top 1 * from T4 where X11 >  '" + a + "' order by X11) tt2)"
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 7月19日
  • 已采纳回答 7月11日
  • 创建了问题 7月8日

悬赏问题

  • ¥15 关于#java#的问题:找一份能快速看完mooc视频的代码
  • ¥15 这种微信登录授权 谁可以做啊
  • ¥15 请问我该如何添加自己的数据去运行蚁群算法代码
  • ¥20 用HslCommunication 连接欧姆龙 plc有时会连接失败。报异常为“未知错误”
  • ¥15 网络设备配置与管理这个该怎么弄
  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!