开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 184|回复: 7
收起左侧

[已解决] 关于数据库插入数据 是小数 的问题

 关闭 [复制链接]
结帖率:100% (9/9)
发表于 2025-7-30 02:57:29 | 显示全部楼层 |阅读模式   河南省郑州市
50精币
数据库连接1.执行SQL (“insert into ceshi(NO,NAME,PRICE) values ('” + 编辑框1.内容 + “','” + 编辑框2.内容 + “',” + 编辑框3.内容 + “ )”, )
这是执行命令,我的问题是数据库表ceshi里的字段 NO  NAME  都是文本格式,可以插入成功,但是PRICE字段是小数类型,我用SQL执行 易语言只能执行文本命令,比如我输入的13.9,它插入数据库会当成文本格式,结果数据库里显示变成四舍五入14了,我就想问下怎么 执行SQL命令,把第三个参数PRICE,执行结果是小数

最佳答案

查看完整内容

当你用单引号包裹 PRICE 值(如 '13.9'),数据库会将其视为文本 如果 PRICE 字段是整数类型​(如 INT),数据库会强制将文本转为整数,导致 13.9 → 14 如果 PRICE 字段是小数类型​(如 DECIMAL 或 FLOAT),直接去掉单引号即可保留小数。

回答提醒:如果本帖被关闭无法回复,您有更好的答案帮助楼主解决,请发表至 源码区 可获得加分喔。
友情提醒:本版被采纳的主题可在 申请荣誉值 页面申请荣誉值,获得 1点 荣誉值,荣誉值可兑换荣誉会员、终身vip用户组。
快捷通道:申请荣誉值无答案申请取消悬赏投诉有答案未采纳为最佳
结帖率:100% (47/47)

签到天数: 3 天

发表于 2025-7-30 02:57:30 | 显示全部楼层   河北省秦皇岛市
csyloveyj 发表于 2025-7-30 19:19
我写的就你这一样  编辑框是12.9 字段传的参数没有单引号,数据库是古老的dbf,price 设计的是float 长度 ...

当你用单引号包裹 PRICE 值(如 '13.9'),数据库会将其视为文本
如果 PRICE 字段是整数类型​(如 INT),数据库会强制将文本转为整数,导致 13.9 → 14
如果 PRICE 字段是小数类型​(如 DECIMAL 或 FLOAT),直接去掉单引号即可保留小数。
回复

使用道具 举报

结帖率:100% (47/47)

签到天数: 3 天

发表于 2025-7-30 03:20:32 | 显示全部楼层   河北省秦皇岛市
数据库连接1.执行SQL (“insert into ceshi(NO,NAME,PRICE) values ('” + 编辑框1.内容 + “','” + 编辑框2.内容 + “', ” + 编辑框3.内容 + “)”, )

PRICE字段的值不要加单引号,确保编辑框3的内容是小数,确保 PRICE 在数据库中是 DECIMAL 或 FLOAT 类型,而非 INT。

  
子程序名返回值类型公开备 注
_按钮_插入_被单击  
.局部变量 SQL语句, 文本型

' 验证输入
如果真 (是否为小数 (编辑框3.内容))
信息框 ("价格必须为数字!", 0, "错误", )
返回 ()

' 构造SQL语句(PRICE字段无引号)
SQL语句 = “insert into ceshi(NO,NAME,PRICE) values ('” + 编辑框1.内容 + “','” + 编辑框2.内容 + “', ” + 编辑框3.内容 + “)”

' 执行SQL
如果真 (数据库连接1.执行SQL (SQL语句, ))
信息框 ("插入失败:" + 数据库连接1.取错误文本 (), 0, "错误", )
信息框 ("插入成功!", 0, "提示", )

子程序名返回值类型公开备 注
是否为小数逻辑型 
参数名类 型参考可空数组备 注
文本文本型
变量名类 型静态数组备 注
i整数型 
点计数整数型 
点计数 = 0
计次循环首 (取文本长度 (文本), i)
.局部变量 字符, 文本型
字符 = 取文本中间 (文本, i, 1)

如果真 (字符 ≠ “.” 是否数字 (字符))
返回 ()

如果真 (字符 = “.”)
点计数 = 点计数 + 1
如果真 (点计数 > 1)  ' 多个小数点无效
返回 ()


计次循环尾 ()
返回 ()


i支持库列表   支持库注释   
mysqlMySql支持库

回复

使用道具 举报

结帖率:100% (1/1)

签到天数: 8 天

发表于 2025-7-30 08:37:09 | 显示全部楼层   广西壮族自治区南宁市
sqlite用text存我这边像你这么存测试没问题,mysql的话表字段类型double或者float类型时设置下其小数点后多少位
回复

使用道具 举报

结帖率:100% (9/9)

签到天数: 7 天

 楼主| 发表于 2025-7-30 15:26:01 | 显示全部楼层   河南省郑州市
designer 发表于 2025-7-30 08:37
sqlite用text存我这边像你这么存测试没问题,mysql的话表字段类型double或者float类型时设置下其小数点后多 ...

mysql的话表字段类型 float 怎么设置呢 用SQL语句,谢谢
回复

使用道具 举报

结帖率:100% (9/9)

签到天数: 7 天

 楼主| 发表于 2025-7-30 19:19:09 | 显示全部楼层   河南省郑州市
2224848 发表于 2025-7-30 03:20
数据库连接1.执行SQL (“insert into ceshi(NO,NAME,PRICE) values ('” + 编辑框1.内容 + “','” + 编 ...

我写的就你这一样  编辑框是12.9 字段传的参数没有单引号,数据库是古老的dbf,price 设计的是float 长度是0 ,写进去12.9  他里面非显示成整数13,无语
回复

使用道具 举报

结帖率:100% (47/47)

签到天数: 3 天

发表于 2025-7-30 19:34:46 | 显示全部楼层   河北省秦皇岛市
csyloveyj 发表于 2025-7-30 19:19
我写的就你这一样  编辑框是12.9 字段传的参数没有单引号,数据库是古老的dbf,price 设计的是float 长度 ...
  
如果真 (是否为小数 (编辑框3.内容))
信息框 ("请输入有效数字!", 0, "错误", )
返回 ()

回复

使用道具 举报

结帖率:100% (9/9)

签到天数: 7 天

 楼主| 发表于 2025-8-1 00:03:51 | 显示全部楼层   河南省郑州市
2224848 发表于 2025-7-30 19:35
当你用单引号包裹 PRICE 值(如 '13.9'),数据库会将其视为文本
如果 PRICE 字段是整数类型​(如 INT) ...

我另辟蹊径  自己建个个一样的数据库 把字段设置成文本 解决了。。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报QQ: 793400750,邮箱:wp@125.la
网站简介:精易论坛成立于2009年,是一个程序设计学习交流技术论坛,隶属于揭阳市揭东区精易科技有限公司所有。
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备2025452707号) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表