SQL语句错误:

Column count doesn't match value count at row 1

列计数与第1行的值计数不匹配

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 'DATABASE' at line 1

您的SQL语法中有错误; 请检查与MySQL服务器版本对应的手册,以获取在第1行“DATABASE”附近使用的正确语法

连接数据库时出现这样的错误:ERROR 2003 (HY000): Can't connect to MySQL server on 'localhost' (10061) 

原因:数据库未启动,要先启动数据库,操作:在有管理员权限的命令行窗口键入 "net start mysql" 命令来启动数据库即可。

 注意:sql语句中的变量都应该用英文单词表示。

1、 在MySQL下创建一个数据库student,字符集使用utf8

CREATE DATABASE student character set utf8;//创建表时设置字符集

2、 创建三个表

(1) 学生表,字段如下:学号,姓名,性别,出生日期,省份,班级,各字段使用合适的数据类型,设置学号为主键

create table 学生表(

学号 INT NOT NULL PRIMARY KEY,   //设置主键

姓名 VARCHAR(20) NOT NULL ,

性别 VARCHAR(2) ,

出生日期 DATE ,

省份 VARCHAR(20),

班级 VARCHAR(15)

);

(2) 课程表,字段如下:课程号,课程名称,任课教师,学时,学分,课程性质(选修,必修),备注,各字段使用合适的数据类型,设置课程号为主键

create table 课程表(

课程号 INT NOT NULL PRIMARY KEY,

课程名称 VARCHAR(30) NOT NULL ,

任课老师 VARCHAR(10) ,

学时 INT  ,

学分 INT ,

课程性质 VARCHAR(15)

);

(3) 成绩表:字段如下:学号,课程号,成绩,设置学号,课程号为外部主键

create table 成绩表(

学号 INT NOT NULL  ,

课程号 INT  NOT NULL  ,

成绩 INT ,

foreign key ( 学号 )  references  学生表( 学号 ),     //设置外键

foreign key (课程号 )  references 课程表(课程号 )   //设置外键

);

3、 使用SQL语句在三个表中分别增加若干数据

//插入数据,INT类型数据直接写,VARCHAR字符串类型数据要用单引号,DATE日期类型数据也要用单引号

insert into 学生表 ( 学号, 姓名, 性别, 出生日期, 省份, 班级) values (1404240520 ,'小浩', '男' , '2008-08-15' ,'湖北省','11405班');

4、 使用相应的SQL语句实现以下操作

(1) 查询所有学生的学号,姓名,出生日期信息

select 学号,姓名,出生日期  from 学生表;    //查询语句select与from之间可以有多个字段,用逗号隔开,代表要输出的字段

(3) 查询省份是“湖北”,姓“李”的女同学的学号,班级,出生日期

select 学号, 班级, 出生日期 from 学生表 where 省份='湖北省' and 姓名 like '李%' and 性别='女';

(4) 统计男,女同学的人数

select 性别,count(*) from 学生表 where 性别='女' group by 性别;   //count(*)表中本来是没有的,新创建的字段来记录个数

select 性别,count(*) from 学生表 where 性别='男' group by 性别;

(6) 删除性别为null或’’的学生
       delete  from student where sex=null or sex=' ';

(7) 将1990年出生的学生省份修改为“湖北”,年龄增加1岁
        update student set birthdate=adddate(birthdate,INTERVAL 1 YEAR),province='湖北' where year(birthdate)=1990;//使用SQL语句方法

//或者 这样

update  student  set provice=’湖北省’ , birthdate =birthdate+1 where year(birthdate)=1990;

(8) 分页显示年龄大于20岁的同学所有信息(每页显示10条,本题要求显示第二页)
        select * from student where YEAR(birthdate)<YEAR( current_date())-20  limit 10,10; //limit语句 limit 开始行,每页取出的数据个数

(9)查询所有同学的所有成绩信息,显示“学号,姓名,课程名称,成绩”
         select  score.studentid, student.name,course.coursename,score.score  from score  left join  student on score.studentid=student.studentid left join course on score.courseid=course.courseid;
//sql语句多表联合查询,left join左连接

(10) 查询所有男同学的成绩信息,显示“学号,姓名,课程名称,成绩”
        select score.studentid, student.name,course.coursename,score.score from score left join student on score.studentid=student.studentid left join course on score.courseid=course.courseid  where student.sex='男';

(11) 查询所有必修课程的平均分,显示“课程号,课程名称,课程性质,平均分”
       select course.courseid, course.coursename, course.type, AVG(score.score) from course ,score where course.courseid=score.courseid  and  course.type='必修' GROUP BY course.courseid;

(12) 查询某个班级所有课程的平均分,显示“班级,课程,平均分”(按平均分倒序显示),并将查询结果增加到一个新的表中
             create table classscore  as  select student.class,course.coursename,AVG(score.score) as avg from  student,course,score where student.class='计科1'and student.studentid=score.studentid and course.courseid=score.courseid group by course.coursename order by AVG(score.score) desc;  //创建新表并将查询到的数据作为新表的数据

查询命令语句http://bbs.csdn.net/topics/390407669

外键 http://blog.sina.com.cn/s/blog_53729e4601011wja.html

MySQL SQL的更多相关文章

  1. mysql sql优化实例

    mysql sql优化实例 优化前: pt-query-degist分析结果: # Query 3: 0.00 QPS, 0.00x concurrency, ID 0xDC6E62FA021C85B ...

  2. jbpm3.2中jbpm.jpdl.mysql.sql文件运行报错的问题

    这是一个很久之前遇到的问题,就是用从官网下下载的jbpm组件,它的jbpm.jpdl.mysql.sql不能正常运行.其原因是该sql文件中有一句语句有错误.现在附上正确的jbpm.jpdl.mysq ...

  3. 程序员实用的 MySQL sql 语句

    这儿只讲究实用,  程序员编程时常用到的 MySQL的 sql语句(不包括基本的 select, update, delete 等语句). 1. 添加一个用户build,并赋予所有权限的命令 gran ...

  4. Atitit.软件GUIbutton与仪表盘--db数据库区--导入mysql sql错误的解决之道

    Atitit.软件GUIbutton与仪表盘--db数据库区--导入mysql sql错误的解决之道 Keyword::截取文本文件后部分 查看提示max_allowed_packet限制 Targe ...

  5. mysql sql语句大全(转载)

      1.说明:创建数据库 CREATE DATABASE database-name 2.说明:删除数据库 drop database dbname 3.说明:备份sql server --- 创建 ...

  6. 从运维的角度分析使用阿里云数据库RDS的必要性--你不应该在阿里云上使用自建的MySQL/SQL Server/Oracle/PostgreSQL数据库

    开宗明义,你不应该在阿里云上使用自建的MySQL or SQL Server数据库,对了,还有Oracle or PostgreSQL数据库. 云数据库 RDS(Relational Database ...

  7. Mysql SQL Mode详解

    Mysql SQL Mode简介 MySQL服务器能够工作在不同的SQL模式下,并能针对不同的客户端以不同的方式应用这些模式.这样,应用程序就能对服务器操作进行量身定制以满足自己的需求.这类模式定义了 ...

  8. MYSQL SQL语句技巧初探(一)

    MYSQL SQL语句技巧初探(一) 本文是我最近了解到的sql某些方法()组合实现一些功能的总结以后还会更新: rand与rand(n)实现提取随机行及order by原理的探讨. Bit_and, ...

  9. (1.4)mysql sql mode 设置与使用

    关键词: mysql sql mode 1.查阅 mysql> mysql> show variables like 'sql_mode%';+---------------+------ ...

  10. 16.Mysql SQL Mode

    16.SQL Mode及相关问题SQL Mode定义了Mysql支持的SQL语法和数据校验级别,Mysql支持多种SQL Mode.用途: 设置不同的SQL Mode可以对数据进行不同严格程度的校验, ...

随机推荐

  1. Mybatis 与 spring mvc

    本文是用来小结一下自己mybatis 和spring mvc 学习过程. 在写的过程中发现 http://www.phperz.com/article/15/0127/48684.html 这篇文章里 ...

  2. CentOS6.5安装配置SVN

    安装SVN软件包[root@localhost ~]# yum install subversion#确认是否已安装svn模块[root@localhost ~]# cd /etc/httpd/mod ...

  3. WWDC 2013 Session笔记 - iOS7中的多任务

    这是我的WWDC2013系列笔记中的一篇,完整的笔记列表请参看这篇总览.本文仅作为个人记录使用,也欢迎在许可协议范围内转载或使用,但是还烦请保留原文链接,谢谢您的理解合作.如果您觉得本站对您能有帮助, ...

  4. CentOS编译安装PHP 7.0

    问题1: Cannot find ldap.h 解决办法: yum install openldapyum install openldap-devel 问题2: Cannot find ldap l ...

  5. Ubuntu(14.04)远程连接windwos(server2008 r2)

    只需安装rdeasktop即可, sudo apt-get install rdesktop rdesktop 192.168.1.100 -g 800x600 其他参数 -f 其实用Ubuntu自带 ...

  6. 简明python教程 --C++程序员的视角(四):容器类型(字符串、元组、列表、字典)和参考

    数据结构简介 Python定义的类型(或对象)层次结构在概念上可以划分为四种类别:简单类型.容器类型.代码类型 和内部类型. 可以将 PyObject 类之下的所有 Python 类划分为 Pytho ...

  7. paper 99:CV界的明星人物经典介绍

            CV人物1:Jianbo Shi史建波毕业于UC Berkeley,导师是Jitendra Malik.其最有影响力的研究成果:图像分割.其于2000年在PAMI上多人合作发表”Nor ...

  8. 智能家居常用WiFi模块

    WiFi模块 WiFi模块就是整个系统的控制中心,控制很简单,就是输出一个开关信号控制继电器,而这个模块的核心是WiFi的连接,手机连接WiFi时需要扫描,输入密码,而这类本身没有屏幕和键盘的硬件设备 ...

  9. Orchard part8

    http://skywalkersoftwaredevelopment.net/blog/writing-an-orchard-webshop-module-from-scratch-part-8 定 ...

  10. Python正则处理多行日志一例

    正则表达式基础知识请参阅<正则表达式基础知识>,本文使用正则表达式来匹配多行日志并从中解析出相应的信息. 假设现在有这样的SQL日志: SELECT * FROM open_app WHE ...