实例介绍
【实例截图】







【核心代码】
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using CarButton;
using System.Data.SqlClient;
namespace Example
{
public partial class Main : Form
{
public Main()
{
InitializeComponent();
helper = new SQLHelper();
}
//用于测试使用
public const int userID = 10000000;
SQLHelper helper;
private void Main_Load(object sender, EventArgs e)
{
AddData();
//显示浏览记录数量
label1.Text = GetCount().ToString();
}
/// <summary>
/// 获得历史浏览记录数量
/// </summary>
int GetCount()
{
string s = "select count (*) from record where userid=@userid";
SqlParameter[] sqlParameter = new SqlParameter[]{
new SqlParameter("@userid",userID)
};
return (int)new SQLHelper().ExecuteScalar(s, sqlParameter);
}
/// <summary>
/// 获取数据库中所有汽车的信息
/// </summary>
/// <returns></returns>
List<Car> GetCars()
{
//string selectCar = "with total as select *, row_number() over(order by Id) as rowNum from car) select * from total where rowNum between 1 and 4";
string selectCar = "select * from car";
List<Car> cars = new List<Car>();
//Car car = new Car();//BUG***********************************************
DataTable dataTable = helper.GetDataTable(selectCar, CommandType.Text);
for (int i = 0; i < dataTable.Rows.Count; i )
{
Car car = new Car();
car.ID = Convert.ToInt32(dataTable.Rows[i]["ID"]);
car.CarName = dataTable.Rows[i]["CarName"] as string;
car.NewPrice = Convert.ToDouble(dataTable.Rows[i]["NewPrice"]);
car.OldPrice = Convert.ToDouble(dataTable.Rows[i]["OldPrice"]);
car.FristPayment = Convert.ToDouble(dataTable.Rows[i]["FristPayment"]);
car.Introduction = dataTable.Rows[i]["Introduction"].ToString();
car.Picture = new PictureOperate().GetImage((byte[])dataTable.Rows[i]["Picture"]);
cars.Add(car);
}
return cars;
}
/// <summary>
/// 通过代码创建控件
/// </summary>
/// <param name="x"></param>
/// <param name="y"></param>
/// <param name="number"></param>
/// <param name="car"></param>
void CreateUserControl(int x, int y, int number, Car car)
{
//配置UserControlCarList相应的属性
UserControlCarList user = new UserControlCarList();
user.Name = "userControlCarList" number;
user.Location = new System.Drawing.Point(x, y);
user.pictureBox_CarImage.Image = car.Picture;
user.label_CarIntroduction.Text = car.Introduction;
user.label_CarName.Text = car.CarName;
user.label_CarPrice.Text = car.NewPrice / 10000.0 "万 首付" car.FristPayment / 10000.0 "万";
user.label_CarID.Text = car.ID.ToString();
user.label_UserID.Text = userID.ToString();
//将动态创建的控件添加到Panel控件中
panel1.Controls.Add(user);
user.Click = new EventHandler(aBtn_Click);//使用事件函数句柄指向一个具体的函数
}
/// <summary>
/// 通过从数据库中读取到的汽车,创建相应的控件
/// </summary>
void AddData()
{
List<Car> cars = GetCars();
int i = 1;
//动态创建控件
foreach (var item in cars)
{
if (i % 2 != 0)
{
//220 270
CreateUserControl(12, 12 (i - 1) / 2 * 220, i, item);
}
else
{
CreateUserControl(12 220, 12 (i - 2) / 2 * 220, i, item);
}
i ;
}
}
/// <summary>
/// 点击"动态创建的控件"跳转到汽车详细信息的界面
/// </summary>
/// <param name="sender"></param>
/// <param name="e"></param>
private void aBtn_Click(object sender, EventArgs e)
{
//通过sender对象来获取是由哪个控件传来的Click事件
UserControlCarList user = (UserControlCarList)sender;
//跳转到汽车详细信息的界面,并将用户ID和汽车ID传过去
new CarInfo(Convert.ToInt32(user.label_CarID.Text), Convert.ToInt32(user.label_UserID.Text)).Show();
this.Close();
}
private void label1_Click(object sender, EventArgs e)
{
new Record(userID).Show();
this.Close();
}
private void label2_Click(object sender, EventArgs e)
{
new Record(userID).Show();
this.Close();
}
}
}
标签: C# 窗体 SQL Server 数据库 用户控件
相关软件
小贴士
感谢您为本站写下的评论,您的评论对其它用户来说具有重要的参考价值,所以请认真填写。
- 类似“顶”、“沙发”之类没有营养的文字,对勤劳贡献的楼主来说是令人沮丧的反馈信息。
- 相信您也不想看到一排文字/表情墙,所以请不要反馈意义不大的重复字符,也请尽量不要纯表情的回复。
- 提问之前请再仔细看一遍楼主的说明,或许是您遗漏了。
- 请勿到处挖坑绊人、招贴广告。既占空间让人厌烦,又没人会搭理,于人于己都无利。
关于好例子网
本站旨在为广大IT学习爱好者提供一个非营利性互相学习交流分享平台。本站所有资源都可以被免费获取学习研究。本站资源来自网友分享,对搜索内容的合法性不具有预见性、识别性、控制性,仅供学习研究,请务必在下载后24小时内给予删除,不得用于其他任何用途,否则后果自负。基于互联网的特殊性,平台无法对用户传输的作品、信息、内容的权属或合法性、安全性、合规性、真实性、科学性、完整权、有效性等进行实质审查;无论平台是否已进行审查,用户均应自行承担因其传输的作品、信息、内容而可能或已经产生的侵权或权属纠纷等法律责任。本站所有资源不代表本站的观点或立场,基于网友分享,根据中国法律《信息网络传播权保护条例》第二十二与二十三条之规定,若资源存在侵权或相关问题请联系本站客服人员,点此联系我们。关于更多版权及免责申明参见 版权及免责申明
网友评论
我要评论