sql语句怎么添加一条记录?

这是一段sql代码

-- MySQL Administrator dump 1.4
--
-- ------------------------------------------------------
-- Server version4.1.20-community-nt

--
-- Create schema userdb
--

CREATE DATABASE userdb;
USE userdb;

--
-- Table structure for table `userdb`.`user`
--

DROP TABLE IF EXISTS `user`;
CREATE TABLE `user` (
`id` int(10) unsigned NOT NULL auto_increment,
`uid` varchar(20) NOT NULL default '',
`tel` varchar(15) default NULL,
PRIMARY KEY (`id`),
UNIQUE KEY `Index_uid` USING BTREE (`uid`)
)
INSERT INTO user(uid,tel) values('甲','3354986');(就是这句报错了)
ENGINE=InnoDB DEFAULT CHARSET=gbk;
我是用的mysql数据库,前台是mysql-front,前台执行如上代码时倒数第二句会报错,把这句删掉就可以正常建立一个数据库和一张有三个字段的表,那该怎样修改才能正确插入一条记录呢?望高手指点,谢谢!

sql语句中,添加记录的语法为:insert into 表名 (col1,col2....coln)values(value1,value2.....valuen);

其中,如果你插入的每一列都是顺序插入,无一缺漏的话,(col1,col2...coln)可以省略。

也就是上式也可以简化为:insert into 表名 values(value1,value2.....valuen);

看了你写的sql代码,问题出在insert into 的整体语句出现在了不该出现的地方,只需做一点小改动即可解决,如下图:

解析:insert into语句需要在user表已经存在的情况下才可以使用。而你原来的语句中,将上图2中的语句插入到了create table user的语句中,致使create table user 语句未能成功执行,所以才会报错。

而将“INSERT INTO user(uid,tel) values('甲','3354986');”整条语句直接拿出来放在“ENGINE=InnoDB DEFAULT CHARSET=gbk;”后面之后,整个sql就可以顺利执行了。

扩展资料:

当mysql大批量插入数据的时候就会变的非常慢, mysql提高insert into 插入速度的方法有三种:

1、第一种插入提速方法:

如果数据库中的数据已经很多(几百万条), 那么可以 加大mysql配置中的 bulk_insert_buffer_size,这个参数默认为8M

举例:bulk_insert_buffer_size=100M;

2、第二种mysql插入提速方法: 

改写所有 insert into 语句为 insert delayed into

这个insert delayed不同之处在于:立即返回结果,后台进行处理插入。

3、第三个方法: 一次插入多条数据:

insert中插入多条数据,举例:

insert into table values('11','11'),('22','22'),('33','33')...;

温馨提示:答案为网友推荐,仅供参考
第1个回答  推荐于2017-10-14
sql中增加记录用insert into 语句。
sql:insert into tablename( filname1,filename2...) valuse(values1,values2...);
解释:上面的语句就是在tablename表中插入一条记录,插入记录中filname1字段的值是values1,filname2字段的值是values2。
第2个回答  2021-03-24
sql语句怎么添加一条记录?有时候我们在写sql语句的时候,想插入一条空记录,怎么插入呢,下面来分享一下方法
工具原料sql语句插入一条空记录
方法/步骤分步阅读
1
/6
第一步我们在数据库中建立一张test表,可以看到test表中有id,name,second三个字段,id设置为自动递增,
2
/6
第二步输入“insert into test(name,second) values(null,null)”sql语句,点击运行,
3
/6
第三步运行之后,可以看到test表插入了一条空记录,
4
/6
第四步我们也可以插入一条记录某个字段为空值,输入“insert into test(name,second) values(null,88)”sql语句,点击运行,
5
/6
第五步运行之后,可以看到插入了一条记录,name值为空,
6
/6
第六步也可以通过“insert into test(name) values('张三')”语句,插入一条记录,除开name字段,其它字段值为空。
第3个回答  2013-05-02
将你的 INSERT INTO user(uid,tel) values('甲','3354986'); 这句话放到最后面,变成
ENGINE=InnoDB DEFAULT CHARSET=gbk;
INSERT INTO user(uid,tel) values('甲','3354986');
然后就能运行成功了本回答被提问者采纳
第4个回答  2013-05-02
你数据表建立的时候有问题,应该采用规范的命名方法比如说e_user,很多数据库中user作为系统表,你把错误也展示出来!!追问

You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near INSERT INTO user(uid,tel) values('甲','3354986');
ENGINE =InnoDB DEFAULT CHARSE' at line 8
应该不是表名的问题,因为没有这句就可以成功建表

追答

你把编码格式改成utf-8试试。