小言_互联网的博客

快来学习 SQL !!!

465人阅读  评论(0)

SQL 安装教程

安装包下载

那必然去官网下载,下方是官网链接
微软下载官网

点击下载

选择这两个,再点击next~~~


先双击这个文件

一直下一步,这个功能要全选




一直下一步,完成后点开另一个文件

同样全选

安装完成

通过 sql sever 2008 建库

连接到服务器


新建数据库


输入数据库相关参数


右键数据库名称,新建表


输入列名,数据类型等参数


右键小箭头设置主键等属性

用 SQL 语句建库

新建数据库

单机新建查询,输入下方代码,点击执行,闭上眼睛默说五遍“我想要一个数据库”,然后睁开眼睛,你便拥有了一个数据库~~~~

CREATE DATABASE [2859902680] --数据库名字(名字含数字数字要用[],下同)
on primary
(
	name = [2859902680_data],
	filename = 'E:\goodgoodstudy\project\sql\1\2859902680_data.mdf', --数据文件路径
	size=10, --初始大小/MB
	maxsize=unlimited, --是否限制增长
	filegrowth=1 --增量
)
LOG ON (
	name = [2859902680_log],
	filename = 'E:\goodgoodstudy\project\sql\1\2859902680_log.ldf', --日志文件路径
	size = 5,
	maxsize=unlimited,
	filegrowth=1
)

建表

右键点击新建好的数据库,选择新建查询,在新的 sql 文件中输入下方代码,点击执行并呼出一口仙气

CREATE TABLE SC
(
--  列名 约束条件(数据类型,可否为空)
    S# CHAR(4),
    C# CHAR(4),
    SCORE SMALLINT,
    PRIMARY KEY(S#,C#),--设置主键
    --FOREIGN KEY(S#)REFERENCES S(S#),--设置外键
);

你就会发现一个现新建的数据表!!!


插入数据

还是右键数据库,新建查询,输入以下代码后点击执行

INSERT INTO SC
VALUES ('S1','C1',70),
('S1','C2',80),
('S1','C4',90),
('S2','C5',90),
('S4','C1',90),
('S5','C2',60),
('S5','C3',NULL),
('S5','C4',60),
('S5','C5',78),
('S6','C1',76)

记得 char 类型的数据需要加引号,int 类型不需要

然后右键这个数据表

点击 编辑前200行

即可看到刚刚输入的数据乖乖躺在表里~~~~

SQL 查询语句

还是右键数据库,新建查询,然后按照下方模板输入代码,体会查询数据带来的成就感

SELECT DISTINCT /*返回唯一不同的值*/ column, AGG_FUNC(column_or_expression),FROM mytable
    JOIN another_table
      ON mytable.column = another_table.column
    WHERE constraint_expression
    GROUP BY column /*结合函数对结果集进行分组*/
    HAVING constraint_expression
    ORDER BY column ASC/*升序排序*/ / DESC/*降序排序*/
    LIMIT count/*输出数据量*/ OFFSET COUNT/*从第几个数据开始输出*/;

数据操作

– ① 检索年龄小于17岁的女学生的学号和姓名。

SELECT DISTINCT S#, SNAME
FROM S
WHERE AGE<17 AND SEX='F'

– ② 检索男学生所学课程的课程名与课程号。

SELECT DISTINCT CNAME, SC.C#
FROM SC, S, C
WHERE  SC.C# = C.C#
    AND S.S#=SC.S#
    AND S.SEX='M'

– ③ 检索男学生所学课程的任课教师的工号和姓名。

SELECT DISTINCT T#, TNAME
FROM T WHERE T# IN( 
	SELECT T# FROM C WHERE C# IN(
        SELECT C# FROM SC WHERE S# IN(
            SELECT S# FROM S WHERE SEX = 'M'
        )
    )
)

– ④ 检索至少选修两门课程的学生学号。

SELECT DISTINCT S#, COUNT(C#) AS a
FROM SC
GROUP BY S#
HAVING COUNT(C#) > 2

– ⑤ 检索至少有学号S2和S4学生选修的课程的课程号。

SELECT C#
FROM C
WHERE C# IN (
    SELECT x.C# FROM SC as x, SC as y
		WHERE x.S# = 'S2' and y.S# ='S4' and x.C#=y.C#
)

– ⑥ 检索WANG同学不学的课程的课程号。

SELECT DISTINCT C#
	FROM SC
	WHERE C# NOT IN(
    	SELECT C# FROM SC WHERE S# IN(
    		SELECT S# FROM S WHERE SNAME = 'WANG'
	)
)
GROUP BY C#

– ⑦ 检索全部学生都选修的课程的课程号与课程名。

SELECT C#, CNAME
FROM C
WHERE C# IN(
    SELECT C# FROM SC
	GROUP BY C#
	HAVING COUNT (*) = (
    	SELECT COUNT(*) FROM S
		GROUP BY S#
	)
)

– ⑧ 检索选修课程包含LIU老师所授课程的学生学号。

SELECT DISTINCT SC.S#
FROM SC, C, T
WHERE SC.C# IN (
    SELECT C.C# WHERE C.T# IN(
        SELECT T# FROM T WHERE TNAME = 'LIU' 
    )
)

组合查询:

– ① 统计有学生选修的课程门数。

SELECT COUNT(DISTINCT C#) AS co
FROM SC

– ② 求选修C4课程的女学生的平均年龄。

SELECT AVG(S.AGE)AS RESULT
FROM S
WHERE S.S# IN(
    SELECT SC.S# FROM SC WHERE SC.C#='C4'
)
AND S.SEX='F'

– ③ 求LIU老师所授课程的每门课程的平均成绩。

SELECT C#,AVG(SC.SCORE) AS AVG_SCO
FROM SC
WHERE SC.C# IN(
    SELECT C# FROM C WHERE T# IN(
        SELECT T# FROM T WHERE TNAME='LIU'
    )
)
GROUP BY C#

– ④ 统计每门课程的学生选修人数(超过10人的课程才统计)。要求显示课程号和人数。

SELECT SC.C#, COUNT(*) AS NUM
FROM SC
GROUP BY SC.C#
HAVING COUNT(*)>10

– ⑤ 检索学号比WANG同学大,而年龄比他小的学生姓名。

SELECT SNAME FROM S
WHERE S#>(
	SELECT S# FROM S WHERE SNAME = 'WANG'
)
AND AGE<(
	SELECT AGE FROM S WHERE SNAME = 'WANG'
)

– ⑥ 在表SC中检索成绩为空值的学生学号和课程号。

SELECT S#, C#
FROM SC
WHERE SCORE IS NULL

– ⑦ 检索姓名以L打头的所有学生的姓名和年龄。

SELECT SNAME,AGE FROM S
WHERE SNAME LIKE 'L%'

– ⑧ 求年龄大于女同学平均年龄的男学生姓名和年龄。


```sql
SELECT SNAME, AGE
FROM S
WHERE SEX = 'M'
    AND AGE >(
    SELECT AVG(AGE) FROM S WHERE SEX='F'
)

– ① 用户定义完整性:学生年龄<30。

ALTER TABLE S
ADD CONSTRAINT NL CHECK(AGE<30)

– 用实验验证当操作违反了完整性约束时,系统如何处理?

INSERT INTO S
VALUES('S11', 'HAORAN', 19, 'F')

– ② 修改SC中的约束条件,成绩在0-100之间。
– 如果约束存在则先删除

if exists(
	select * from sysobjects where name= 'CJ'
	)
alter table SC drop constraint CJ; 

– 添加约束

ALTER TABLE SC
ADD CONSTRAINT CJ CHECK(SCORE<=100 AND SCORE >=0)

–用实验验证当操作违反了完整性约束时,系统如何处理?

INSERT INTO SC
VALUES('S1', 'C5', 150)

– ①求某门课的平均成绩,并把结果存入数据库;

CREATE TABLE L
(
    C# CHAR(4) NOT NULL,
    AVGGRADE SMALLINT,
    PRIMARY KEY (C#),
    FOREIGN KEY (C#) REFERENCES C(C#)
);

INSERT INTO L
SELECT C#, AVG(SCORE)
FROM SC
GROUP BY C#

– ②将选LIU老师所授课的全体学生的成绩置零。

UPDATE SC SET SCORE = 0
WHERE C# IN (
    SELECT C# FROM C WHERE T# IN(
        SELECT T# FROM T WHERE TNAME = 'LIU'
    )
)

数据库与C#窗体关联

在窗体设计界面插入控件后
添加代码
新建连接对象,并传入连接指令字符串

 public static string con = "server=BLACK;database=2019_3_2;uid=sa;pwd=123456";
        public static SqlConnection con_connection = new SqlConnection(con);

定义查询语句

string sql = "SELECT * FROM OP WHERE OP.H_Pos = 402";

含 textbox 输入的sql语句

sql = "SELECT OP.Name,OP.O_ID,OP.Sex,OP.Num,OP.H_Pos,Age,Health_condition,N_Name FROM OP, NW WHERE OP.O_ID = "
                        +textBox1.Text+" AND NW.O_ID = " + textBox1.Text;

执行查询语句

SqlDataAdapter sqlLaoRen = new SqlDataAdapter(sql, con);

建立数据表对象

 DataTable it = new DataTable();

将查询结果填充到数据表内

sqlLaoRen.Fill(it);

将数据表内容展示到控件中

 dataGridView1.DataSource = it.DefaultView;

内容居中显示

dataGridView1.RowsDefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;

粘贴我所做的其中一个窗体的代码

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Data.SqlClient;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Security.Cryptography.X509Certificates;

namespace 三级项目
{
   
    public partial class Form5 : Form
    {
   
        public Form5()
        {
   
            InitializeComponent();
        }
        public static string con = "server=BLACK;database=2019_3_2;uid=sa;pwd=123456";
        public static SqlConnection con_connection = new SqlConnection(con);
        //新建连接对象,并传入连接指令字符串

        private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
        {
   

        }

        private void button1_Click(object sender, EventArgs e)
        {
   
            string search_leixing = comboBox2.Text;
            string sql ="";
            if (textBox1.Text == "")//判断输入是否为空
            {
   
                MessageBox.Show("查询失败,请重新输入");
                return;
            }
            switch (search_leixing)//判断下拉栏内容
            {
    
                case "通过老人证件号码查询老人信息":
                    if (textBox1.Text.Length != 3)//判断输入是否为空
                    {
   
                        MessageBox.Show("查询失败,请重新输入");
                        return;
                    }
                    sql = "SELECT OP.Name,OP.O_ID,OP.Sex,OP.Num,OP.H_Pos,Age,Health_condition,N_Name FROM OP, NW WHERE OP.O_ID = "
                        +textBox1.Text+" AND NW.O_ID = " + textBox1.Text;
                    break;
                case "通过护工工号查询护工信息":
                    if (textBox1.Text.Length != 12)//判断输入是否为空
                    {
   
                        MessageBox.Show("查询失败,请重新输入");
                        return;
                    }
                    sql = "SELECT N_Name,N_ID,NW.Sex,Employment_term,NW.Num,NW.O_ID,NW.H_Pos,OP.Name FROM NW, OP WHERE NW.N_ID = "
                        + textBox1.Text + " AND OP.O_ID = NW.O_ID;";
                    break;
                case "通过管理人员编号查询管理人员信息":
                    if (textBox1.Text.Length != 6)//判断输入是否为空
                    {
   
                        MessageBox.Show("查询失败,请重新输入");
                        return;
                    }
                    sql = "SELECT M_Name, MA.H_Pos AS 所属养老院, NW.N_NAME AS 护工名字, NW.N_ID, NW.SEX AS 护工性别 FROM MA, Manage, NW WHERE MA.M_ID = "
                        +textBox1.Text+" AND MA.M_ID = Manage.M_ID AND Manage.N_ID = NW.N_ID";
                    break;
                default:
                    MessageBox.Show("查询失败,请重新输入");
                    return;
                    break;
            }
            SqlDataAdapter sqlLaoRen = new SqlDataAdapter(sql, con);
            //传入查询命令字符串
            DataTable it = new DataTable();
            //建立数据表对象
            sqlLaoRen.Fill(it);
            //将查询结果填充到数据表内
            dataGridView1.DataSource = it.DefaultView;
            //将数据表内容展示到控件中
            dataGridView1.RowsDefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
            //内容居中显示
        }

        private void button2_Click(object sender, EventArgs e)
        {
   
            new Form1().Show();
            this.Close();
        }
    }
}

配上好看的窗体界面设计


转载:https://blog.csdn.net/qq_46039856/article/details/109085672
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场