VS2019C#连接mysql,添加数据(Insert)
VS2019 C# 连接mysql,添加数据(Insert)
1.在项⽬⽬录下添加MySql.Data.dll
⾸先到MySql.Data.dll,我的路径为:C:\Program Files (x86)\MySQL\Connector NET 8.0\Assemblies\v4.5.2
复制到项⽬⽬录下:
在代码中引⽤命名空间:
using MySql.Data.MySqlClient;
做完之后,在编译时可能会报错:未能到类型或命名空间名称xxx。
明明添加引⽤了,为什么不⾏呢?因为版本号的问题!
2.版本号
注意MySql.Data.dll的版本号,和.NET framework的版本号(VS⾥⾯有很多,可调)要⼀致。
右击项⽬名称(exp6)->属性->应⽤程序:
3.代码
string connStr =string.Format("user=root;pwd=123456;server=127.0.0.1;database=db1;");
MySqlConnection conn =new MySqlConnection(connStr);
conn.Open();
string data_in ="insert into 表明(列表名1,列表名2) values('"+"1"+"','"+"2"+"','";
data_in +="')";
MySqlCommand cmd =new MySqlCommand(data_in, conn);
cmd.ExecuteNonQuery();
conn.Close();mysql下载的vs库放在那个文件里
如果⽤户名,密码,数据库名,表名都正确的话,就可以连接上。
如果句⼦的语法出错,就会报错: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 ‘XXXX’ at line X。
添加语句的语法:写给我⾃⼰看的,⼀度⼗分困惑
众所周知,在mysql中,字符串需要加单引号;⽽在C#中,字符串需要加双引号。
⽐如列表名1为user,varchar(10)类型,列表名2为pwd,varchar(10)类型。
向其中插⼊数据user=123,pwd=456,
正常的sql语句:
insert into table_name(user,pwd)values('123','456');
⽽在C#中,这句话本⾝是⼀个字符串,所以在这个语句的基础上,该加双引号的地⽅就要加双引号。
如果是常数数据,可以直接在整个sql语句上⾯加双引号,完事。
str ="insert into table_name(user,pwd) values('123','456');"
然⽽事情往往不会这么简单。
如果添加的数据是其他地⽅得来的,不是直接就能写进去的,⽐如 str1 = “123”,str2=“456”,添加语句为data_in;data_in ="insert into table_name(user,pwd) values('"+str1+"','"+str2+"',)";
分步详细说明(我真是个⼩垃圾 ):
⾸先是前⾯的语句,⼀直到第⼀个单引号, insert into table_name(user,pwd) values(’
句⼦最后的单引号是sql语句的单引号,双引号是字符串的双引号!
data_in ="insert into table_name(user,pwd) values('"
然后加第⼀个数据,str1
data_in += str1;
其次是字符串1后⾯那个引号,逗号,以及字符串2之前的单引号,
data_in +="','";
接着是第2个数据,str2
data_in += str2;
最后是字符串2后⾯那个引号,和最后的括号。
data_in +="')";
终于添加进去了,棒棒棒!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。