当前位置:首页 > 代码 > 正文

winform图书借阅代码的简单介绍

admin 发布:2022-12-19 18:54 156


今天给各位分享winform图书借阅代码的知识,其中也会对进行解释,如果能碰巧解决你现在面临的问题,别忘了关注本站,现在开始吧!

本文目录一览:

winForm怎么把连接数据库的方法写在类里面?

你可以写一个通过类,代码如下:

public Class DBHepler

{

public static DataSet GetDataSet(string strWhere)

{

public static string connString="Data Sourse=Localhost;Initial CataLog=数据库名;User Id=数据库登陆名; Pwd=数据库登陆密码";

SqlConnection sqlCon = new SqlConnection(connString);

SqlCommand sqlCom = new SqlCommand(sqlCom);

SqlCommand.CommandText = strWhere;

DataSet ds = new DataSet();

try

{

sqlCon.open();

SqlDataAdapter sqlDA = new SqlDataAdapter(sqlCom);

sqlDA.Fill(ds);

return ds;

}

catch(SqlException e)

{

throw new Exception(e.Message);

}

}

}

==================================================

然后就可以在你的方法中调用了:

private void getrf()

{

{

string str = "select 图书编号,图书名称,出版社,图书价格, 借阅次数,存放位置,库存数量 from bookMessage order by 图书编号 ASC";

DataSet ds = DBHepler.GetDataSet(str);

dataGridView1.DataSource = ds.Table[0].defaultView;

dataGridView1.DataBind();

}

}

请解析一下WinForm代码!

SqlConnection conn 定义一个SqlConnection对象,comm 定义一个SqlCommand ,它的SQL语句是select count (*)from Table1 where name = @loginame and password = @loginpassword,查询数据库中指定的数据(满足条件name = @loginame and password = @loginpassword 注同name最好使用中括号括上)的条数

comm.Parameters.Add(new SqlParameter("@loginame",SqlDbType.NVarchar,20);

定义参数loginame,并指定数型是NVarchar,长度为20

comm.Parameters.Add(new SqlParameter("@loginpassword",SqlDbType.NVarchar,20);

这一句同上

comm.Parameters["@loginpassword"].value=TextBox2.Text;

指定@loginpassword的值为TextBox2.Text,

comm.Connection.Open();

打开数据库连接

int mark,定义一个INT型的变量

(int)comm.ExecuteScalar()

指行查询,并返回第一行第一列的一个数据并转换成INT型,(int)是转换INT型的一种方法之一,你要不采用我的就太对不起咱打的这些字了,完毕

我写了一个WINFORM的图书管理系统,连接的本地数据库,我把EXE文件传给其他人,在另一台电脑上使用

有几种方案可供选择。

1、在另外一台电脑上面,

安装数据库。

然后把你本机的数据库导出,

然后导入到另外一台机器上面。

2、修改程序的

数据库连接的

配置信息,

由原有的

连接本机的

localhost

修改为你

电脑的

ip地址。

同时你需要保证

你的机器一直是开的,

并且和目标机器能联网。

你还需要设置你的数据库,

允许外部访问。

3、修改部分代码,

把数据库

换成

SQLite

或者

Access

这一类的数据库。

这样,

数据库本身就仅仅是一个文件,

到时候,随便复制到哪台机器上面运行,

都没有问题。

C# winform窗体,两个dataGridView的操作

数据库一个字段区分两个dataGridView所查询的数据,然后分别查询出来加载在两个DataGridView中就行了。

winform 图书在线借阅系统开发实例怎么在电脑上安装部署

en 楼下说很多 打包的时候直接把framewor打包进去。这样客户安装的时候就直接安装了。保证版本一样,也不用直接去下载省时间也。

c#小型图书管理系统

里面// // 里的全都是注释

#include iostream

#include iomanip

#include string

//输入/输出文件流类

#include fstream

using namespace std;

//最多的读者

const int Maxr=100;

//最多的图书

const int Maxb=100;

//每位读者最多借五本书

const int Maxbor=5;

//读者类,实现对读者的信息的描述

class Reader

{

private:

//删除标记 1:已删 0:未删

int tag;

//读者编号

int no;

//读者姓名

char name[10];

//所借图书

int borbook[Maxbor];

public:

Reader()

{

;

}

//获取姓名

char *getname()

{

return name;

}

//获取删除标记

int gettag()

{

return tag;

}

//获取读者编号

int getno()

{

return no;

}

//设置姓名

void setname(char na[])

{

strcpy(name,na);

}

//设置删除标记 1:已删 0:未删

void delbook()

{

tag=1;

}

//增加读者

void addreader(int n,char *na)

{

tag=0;

no=n;

strcpy(name,na);

for(int i=0;iMaxbor;i++)

borbook[i]=0;

}

//借书操作

void borrowbook(int bookid)

{

for(int i=0;iMaxbor;i++)

{

if (borbook[i]==0)

{

borbook[i]=bookid;

return;

}

}

}

//还书操作

int retbook(int bookid)

{

for(int i=0;iMaxbor;i++)

{

if(borbook[i]==bookid)

{

borbook[i]=0;

return 1;

}

}

return 0;

}

//读出读者信息

void disp()

{

cout setw(5) no setw(10) name"借书编号:[";

for(int i=0;iMaxbor;i++)

if(borbook[i]!=0)

cout borbook[i] "|";

cout "]"endl;

}

};

//读者类库,实现建立读者的个人资料

class RDatabase

{

private:

//读者记录指针

int top;

//读者记录

Reader read[Maxr];

public:

//构造函数,将reader.txt读到read[]中

RDatabase()

{

Reader s;

top=-1;

//打开一个输入文件

fstream file("reader.txt",ios::in);

while (1)

{

file.read((char *)s,sizeof(s));

if (!file)break;

top++;

read[top]=s;

}

//关闭 reader.txt

file.close();

}

//删除所有读者信息

void clear()

{

top=-1;

}

//添加读者时先查找是否存在

int addreader(int n,char *na)

{

Reader *p=query(n);

if (p==NULL)

{

top++;

read[top].addreader(n,na);

return 1;

}

return 0;

}

//按编号查找

Reader *query(int readerid)

{

for (int i=0;i=top;i++)

if (read[i].getno()==readerid

read[i].gettag()==0)

{

return read[i];

}

return NULL;

}

//输出所有读者信息

void disp()

{

for (int i=0;i=top;i++)

read[i].disp();

}

//读者库维护

void readerdata();

//析构函数,将read[]写到reader.txt文件中

~RDatabase()

{

fstream file("reader.txt",ios::out);

for (int i=0;i=top;i++)

if (read[i].gettag()==0)

file.write((char *)read[i],sizeof(read[i]));

file.close();

}

};

void RDatabase::readerdata()

{

char choice;

char rname[20];

int readerid;

Reader *r;

while (choice!='0')

{

cout "\n\n\t\t\t读 者 维 护\n\n\n\t\t 1 新 增\n\n\t\t 2 更 改\n\n\t\t 3 删 除\n\n\t\t 4 查 找\n\n\t\t 5 显 示\n\n\t\t 6 全 删\n\n\t\t 0 退 出"endl;

cin choice;

switch (choice)

{

case '1':

cout "输入读者编号:";

cin readerid;

cout "输入读者姓名:";

cin rname;

addreader (readerid,rname);

break;

case '2':

cout "输入读者编号:";

cin readerid;

r=query(readerid);

if (r==NULL)

{

cout " 该读者不存在 "endl;

break;

}

cout "输入新的姓名:";

cin rname;

r-setname(rname);

break;

case '3':

cout " 输入读者编号:";

cin readerid;

r=query(readerid);

if (r==NULL)

{

cout " 该读者不存在" endl;

break;

}

r-delbook();

break;

case '4':

cout "读入读者编号:";

cin readerid;

r=query(readerid);

if (r==NULL)

{

cout "该读者不存在" endl;

break;

}

r-disp();

break;

case '5':

disp();

break;

case '6':

clear();

break;

default:cout"输入错误,请从新输入:";break;

}

}

}

//图书类,实现对图书的描述,图书的编号,书名,借出,还入等

class Book

{

private:

//删除标记 1:已删 0:未删

int tag;

//图书编号

int no;

//书名

char name[20];

//是否再架 1:再架 2:已借

int onshelf;

public:

Book(){}

//获取姓名

char *getname() { return name; }

//获取图书编号

int getno(){ return no; }

//获取删除标记

int gettag(){ return tag; }

//设置书名

void setname(char na[])

{

strcpy(name,na);

}

//删除图书

void delbook(){ tag=1;}

//增加图书

void addbook(int n,char *na)

{

tag=0;

no=n;

strcpy(name,na);

onshelf=1;

}

//借书操作

int borrowbook()

{

if (onshelf==1)

{

onshelf=0;

return 1;

}

return 0;

}

//还书操作

void retbook()

{

onshelf=1;

}

//输出图书

void disp()

{

cout setw(6) no setw(18) name setw(10)

(onshelf==1? "在架":"已借") endl;

}

};

//图书库类,实现对图书的维护,查找,删除等

class BDatabase

{

private:

//图书记录指针

int top;

//图书记录

Book book[Maxb];

public:

//构造函数,将book.txt读到book[]中

BDatabase()

{

Book b;

top=-1;

fstream file("book.txt",ios::in);

while (1)

{

file.read((char *)b,sizeof(b));

if (!file) break;

top++;

book[top]=b;

}

file.close();

}

//全删

void clear()

{

top=-1;

}

//增加图书

int addbook(int n,char *na)

{

Book *p=query(n);

if (NULL==p)

{

top++;

book[top].addbook(n,na);

return 1;

}

return 0;

}

//查找图书

Book *query(int bookid)

{

for (int i=0;i=top;i++)

if (book[i].getno()==bookid book[i].gettag()==0)

{

return book[i];

}

return NULL;

}

//图书库维护

void bookdata();

void disp()

{

for (int i=0;i=top;i++)

if (book[i].gettag()==0)

book[i].disp();

}

//析构函数,将book[]写到book.txt文件中

~BDatabase()

{

fstream file("book.txt",ios::out);

for (int i=0;i=top;i++)

if (book[i].gettag()==0)

file.write((char *)book[i],sizeof(book[i]));

file.close();

}

};

void BDatabase::bookdata()

{

char choice;

char bname[40];

int bookid;

Book *b;

while (choice!='0')

{

cout "\n\n\n\t\t\t图 书 维 护 "endlendl;

cout"\t\t1 新 增\n \t\t2 更 改\n\t\t3 删 除\n\t\t4 查 找\n\t\t5 显 示\n\t\t6 全 删\n\t\t0 退 出"endl;

cin choice;

switch (choice)

{

case '1':

cout "输入图书编号:"endl;

cin bookid;

cout "输入图书书名:"endl;

cin bname;

addbook(bookid,bname);

break;

case '2':

cout "输入图书编号:"endl;

cin bookid;

b=query(bookid);

if (b==NULL)

{

cout " 该图书不存在 "endl;

break;

}

cout "输入新的书名:"endl;

cin bname;

b-setname(bname);

break;

case '3':

cout " 读入图书编号:"endl;

cin bookid;

b=query(bookid);

if (b==NULL)

{

cout " 该图书不存在" endl;

break;

}

b-delbook();

break;

case '4':

cout " 读入图书编号:"endl;

cin bookid;

b=query(bookid);

if (b==NULL)

{

cout " 该图书不存在" endl;

break;

}

b-disp();

break;

case '5':

disp();

break;

case '6':

clear();

break;

default:cout"输入错误,请从新输入:";

}

}

}

//main() 函数的实现,程序的主界面的引导

int main()

{

char choice;

int bookid,readerid;

RDatabase ReaderDB;

Reader *r;

BDatabase BookDB;

Book *b;

while(choice!='0')

{

cout endlendl"\t\t\t 图 书 管 理 系 统\n\n\n";

cout "\t\t\t1 借 书\n\n\t\t\t2 还 书 \n\n\t\t\t3 图 书 维 护\n\n\t\t\t4 读 者 维 护\n\n\t\t\t0 离 开"endl;

cin choice;

switch (choice)

{

case '1':

cout " 借书 读者编号:";

cin readerid;

cout " 图书编号: ";

cin bookid;

//按编号查找

r=ReaderDB.query(readerid);

if (NULL==r)

{

cout " 不存在该读者,不能借书" endl;

break;

}

b=BookDB.query(bookid);

if (b==NULL)

{

cout " 不存在该图书,不能借书" endl;

break;

}

if (b-borrowbook()==0)

{

cout " 该图书已借出,不能借书" endl;

break;

}

r-borrowbook(b-getno());

break;

case '2':

cout"还书\n 读者编号:";

cin readerid;

cout " 图书编号:";

cin bookid;

r=ReaderDB.query(readerid);

if (r==NULL)

{

cout " 不存在该读者,不能还书" endl;

break;

}

b=BookDB.query(bookid);

if (b==NULL)

{

cout " 不存在该图书,不能还书" endl;

break;

}

b-retbook();

r-retbook(b-getno());

break;

case '3':

BookDB.bookdata();

break;

case '4':

ReaderDB.readerdata();

break;

default:cout"输入错误,请从新输入:";

}

}

}

其中main函数是int型的,是因为在devcpp下编程造成的,其他程序报错请改为void型。

关于winform图书借阅代码和的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/18734.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载