开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

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

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


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

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

查看: 159|回复: 2
收起左侧

[完成] SQL语句添加字段的问题

 关闭 [复制链接]
结帖率:100% (4/4)
发表于 2025-4-27 18:52:00 | 显示全部楼层 |阅读模式   湖北省恩施土家族苗族自治州
20精币

.版本 2
.支持库 SqliteDB
.支持库 iconv

.子程序 数据表_添加字段, 逻辑型
.参数 数据库路径, 文本型
.参数 数据表名, 文本型
.参数 字段名, 文本型
.局部变量 表, Sqlite表
.局部变量 库, Sqlite数据库
.局部变量 转换编码, 字节集
.局部变量 sql, 文本型


转换编码 = 编码转换 (到字节集 (数据表名), #编码_GBK, #编码_UTF_8, )
数据表名 = 到文本 (转换编码)
转换编码 = 编码转换 (到字节集 (字段名), #编码_GBK, #编码_UTF_8, )
字段名 = 到文本 (转换编码)
' sql = “ALTER TABLE ” + “ID451153” + “ ADD ” + “age”
' sql = “alter table ID451153 ADD ” + “name” + “ char(40)”
sql = “ALTER TABLE ID451153 ADD COLUMN phone TEXT”
输出调试文本 (sql)
库.打开 (数据库路径, 假)
' 表.打开 (“ID451153”, 库)
.如果真 (库.执行SQL语句 (sql) = 假)
    输出调试文本 (库.取错误文本 ())
.如果真结束
库.关闭 ()
返回 (真)


SQLITE数据库SQL语句添加字段一直失败,返回错误文本如下:
* ALTER TABLE ID451153 ADD COLUMN phone TEXT
* malformed database schema - near ",": syntax error




最佳答案

查看完整内容

[e=1].版本 2 .支持库 sqlite3 .支持库 iconv .子程序 数据表_添加字段, 逻辑型 .参数 数据库路径, 文本型 .参数 数据表名, 文本型 .参数 字段名, 文本型 .局部变量 表, Sqlite表 .局部变量 库, Sqlite数据库 .局部变量 转换编码, 字节集 .局部变量 sql, 文本型 转换编码 = 编码转换 (到字节集 (数据表名), #编码_GBK, #编码_UTF_8, ) 数据表名 = 到文本 (转换编码) 转换编码 = 编码转换 (到字节集 (字段名), #编码_GBK, #编 ...

结帖率:100% (9/9)

签到天数: 9 天

发表于 2025-4-27 18:52:01 | 显示全部楼层   江苏省无锡市
  
子程序名返回值类型公开备 注
数据表_添加字段逻辑型 
参数名类 型参考可空数组备 注
数据库路径文本型
数据表名文本型
字段名文本型
变量名类 型静态数组备 注
Sqlite表 
Sqlite数据库 
转换编码字节集 
sql文本型 
转换编码 = 编码转换 (到字节集 (数据表名), #编码_GBK, #编码_UTF_8, )
数据表名 = 到文本 (转换编码)
转换编码 = 编码转换 (到字节集 (字段名), #编码_GBK, #编码_UTF_8, )
字段名 = 到文本 (转换编码)
sql = “ALTER TABLE ” + 数据表名 + “ ADD COLUMN ” + 字段名 + “ TEXT”
输出调试文本 (sql)
库.打开 (数据库路径, )
如果真 (库.执行SQL语句 (sql))
输出调试文本 (库.取错误文本 ())
库.关闭 ()
返回 ()

库.关闭 ()
返回 ()


i支持库列表   支持库注释   
sqlite3(未知支持库)
iconv编码转换支持库

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:100% (9/9)

签到天数: 7 天

发表于 2025-4-27 20:52:38 | 显示全部楼层   江苏省苏州市
这个 SQL 语法错误通常是由于 数据库类型不支持 ADD COLUMN 语法 或 表名、字段名包含特殊字符未正确转义 导致的

SQLite 的 ALTER TABLE 语法有严格限制:仅支持添加列到表末尾,且不支持指定列的默认值、约束等。
错误原因:
如果表中已有数据,直接执行 ADD COLUMN 时,SQLite 不允许在列名前添加 COLUMN 关键字(部分数据库支持,但 SQLite 不支持)。
修正语法:
sql
ALTER TABLE ID451153 ADD phone TEXT;

说明:
去掉 COLUMN 关键字,直接写 ADD 字段名 类型。
如果表中无数据,COLUMN 关键字可选(但建议去掉以兼容 SQLite)。
回复

使用道具 举报

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

本版积分规则 致发广告者

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

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

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