代码改变世界

关于MySql

  Evan.Pei  阅读(294)  评论(0编辑  收藏  举报

1.Mysql最开始是由瑞士的Mysql AB公司开发,后被Sun公司收购,再后面Sun被Oracle公司收购,所以Mysql属于Oracle公司。

2.Linx+Apache+Mysql+PHP 被誉为经典组合简称LAMP,或是Apache换成Nginx是LNMP。

3.MySql 开源,体积小,拥有成本低,目前有企业版与社区版。可以到mysql.com的 download中下载

4.Mysql适合中小型企业,中小型项目使用,处理千万级的数据轻松。

5.下载地址mysql.com。

6.Mysql使用 Mysql 5.6Command Line Client 编写命令。

7.或者使用Mysql workbench 可视化开发环境:下载地址:http://dev.mysql.com/downloads/workbench/

8.关于.net中链接MySql

 

     8.1在Mysql服务器运行Cmd到Mysql安装目录中的bin文件中去:cd..   cd file

   

   8.2然后运行mysql 登录mysql:

   

   root:用户

    8.3 登录成功后接着录入:设置外部访问权限

      mysql>GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'password' WITH GRANT OPTION;

          mysql>flush privileges;

 

      上面的意思是*.*代表所有数据库如果指定的话可以改成mydb.*

                            '%'这个的意思是所有其他电脑都可以访问mysql,如果想指定计算机可以改成‘192.168.*.*’你的ip.

           总的意思就是设置外部访问mysql数据库的权限可以指定被访问数据和访问者的电脑,也可完全放开。

    8.4 接下来是C#端:

     8.4.1将mysql.data.dll拷贝到.net项目bin中,并添加引用.

          8.4.2使用方法如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.UI;
using System.Web.UI.WebControls;
using MySql.Data.MySqlClient;
 
namespace WebApplication1
{
    public partial class ConnMysqlDB : System.Web.UI.Page
    {
        public string myConnectionString = "Database=evantestdb;Data Source=192.168.61.254;User Id=root;Password=123456";
 
        protected void Page_Load(object sender, EventArgs e)
        {
            string sql = "select * from employee";
            MySqlConnection con = new MySqlConnection(myConnectionString);
            MySqlCommand com = new MySqlCommand(sql,con);
            con.Open();
            MySqlDataReader dr=com.ExecuteReader();
 
            string a = "";
            while(dr.Read()){
                a += dr["Ename"].ToString()+"\n\n";
            }
 
            Response.Write(a);
 
        }
    }
}

  

 下面是MySQL的一些使用:

  

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
mysql -u root -p;//进入mysql
mysql>show variables like '%datadir%';//查询数据库存放路径
show databases://查询所有数据库
use testDB;//进入testDB数据库
show Tables;//查看所有表
show tables from dbname;//查看其它数据库中的所有表
describe tablename;//查看表结构
quit;//退出
create database dataName;//创建数据库
drop database dataName;//删除数据库包括表和数据 策底删除
alter table tableName rename to newName;//修改表名
rename table oldTableName to newName;//修改表名
alter table tableNme add email varchar(30) not null;//添加列
alter table tablename change id newid int(3);//将列名id修改成newid
alter table tablename drop cellName;//删除列
 
整数类型[从小到大]TinyInt,SmallInt,MediumInt,Int,Bigint
浮点类型 Float,Double,decimal
字符串Char,varcahr,text,blob
枚举类型Enum('Y','N')代表只能插入这两个字符
例如:Alter table tableName add newCell Enum('Y','N');
      INSERT INTO tableName values('Y')只能是Y和N
 
set类型Set('A','B','CD','EFG')可以同时插入多个用逗号隔开
 例如:Alter table tableName add newCell Set('A','B','CD','EFG');
      INSERT INTO tableName values('A,B,EFG')可以多个插入
 
日期时间 data(YYYY-MM-DD),time(HH:MM:SS),year(YYYY),
           datatime(YYYY-MM-DD HH:MM:SS),timestamp(YYYY-MM-DD HH:MM:SS)
 
关于自增长  MSsql中identity(1,1) MySql中 auto_increment
 例如:create table testTable(id int auto_increment,
       primary key(id)
       );
使用Unique保证唯一性 alter table tableName add unique(cellName);
 
delete from tableName;//删除表中的数据,但是自增长的列继续增长
truncate table tableName;//删除表中的数据,自增长的列从1开始
 
//least(1,2,3,0);//取最小值0
//greatest(1,2,3,0);//取最大值3
//rand();//随机
//round(1.12345,2);//四舍五入 保留2位小数
//truncate(1.1234,2);//保留2位,截断,不进行四舍五入
//avg();//平均
//sum()
//min()
//max()
//count()
 
//length();//长度
//lcase();//lower()//转小写
//upper();//大写
//strcmp();//比较大小
//position('a' in 'abc');//查找a的位置返回1
//replace('yes','y','hh');//将yes中的y替换成hh
//insert('yes',2,3,'hh');//在yes中从第2位开始插入hh
//concat('hello','world');//连接
//concat_ws(':','a','b');//结果是a:b
//left('hello',2);//取左边第几个字符right()
//lpad('abc',11,'z');//在左边用Z补齐到11位rpad();
//ltrim();//去左边空格Rtrim().trim()
//substring('abcdfsdfs',2,2);
//ascii('A');//去ascii值
 
//now();现在时间
//curtime();//只取当前时间不要日期
//curdata();//只取日期
//year('2012-02-12');取年moth()
//dayofyear('2012-02-23');一年中的第几天dayofweek()
//week('2015-1-12');//第几周
//hour('2015-09-15 17:27:09'),minute(),second();取时分秒
//date_add('2015-09-15 17:27:09',interval 3 month);添加3个月 day,
//date_sub();减去与上面相反
//SELECT TimesTampDiff(day, '2015-09-10 15:52:11',now());取相差天数
---关于加密
password('abc');//加密函数不可逆转
encrypt('abc','key');//加密函数不可逆转
encode('text','key1');//加密text
decode('cellName','key1');//解密encode()
insert into users(uname) values(aes_encrypt('text','key2'));//加密,这种比encode()加密的更复杂
select aes_decrypt(uname) from users;//解密
---逻辑
select if(10>2,'true','false');
select ifnull(1,'null');--如果不为空返回第一个参数,空返回第二个参数
select nullif(1,2);--如果两个参数相等返回null,不等返回第一个参数
 
select case when 1>0 then 'ok'
            when 2>2 then 'ok2'
            else 'abc' end;
select case 'green'
            when 'red' then 'ok'
            when 'green' then 'ok2'
            else 'abc' end;
             
---格式化
select date_format(now(),'yyyy-mm-dd');
select time_format('','')          
select inet_aton('192.168.10.58');--转换为长串数据例如是:434334233
select inet_ntoa(434334233);--转换成'192.168.10.58'
cast('99' as int);--转整数
convert('99',signed);
             
--------存储过程
delimiter $$  --界定符代表mysql碰到$$才结束 而不是;号
create procedure proc_1()
BEGIN
select * from employee;
END$$
             
             
             
             
             
             
             
             
             
             
             
             
             
            

 

  

 

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
点击右上角即可分享
微信分享提示