2014-04-16學習筆記
// 更新用的sql語句,分成段拼湊
string sql = string.Format("UPDATE Users SET NickName='{0}', FaceId={1},Sex='{2}',Age={3}",
txtNickName.Text.Trim(), Convert.ToInt32(picFace.Tag), cboSex.Text.Trim(), Convert.ToInt32(txtAge.Text.Trim()));
if (txtNewPwd.Text.Trim() != "") // 如果修改了密碼就更新密碼字段
{
//承接了上一個語句sql,因爲有時候用戶未修改密碼
sql = string.Format("{0} ,LoginPwd='{1}' ", sql, txtNewPwd.Text.Trim());
}
把整個窗體mainForm傳給了窗體personalInfoForm
personalInfoForm.mainForm=this;
在personalInfoForm中
public MainForm mainForm; // 主窗體
修改了用戶的資料信息之後
mainForm.ShowSelfInfo(); // 更新主窗體中的個人信息
//記錄登錄的用戶Id
class UserHelper
{
public static int loginId; //登錄的用戶Id
}
UserHelper.loginId
類中編寫的全局變量,相當於session記錄當前用戶的qq號,可以再多個窗口使用
// 循環添加好友列表
while (dataReader.Read())
{
// 創建一個SideBar項
//SbItem(顯示的文字 圖像的索引)
SbItem item = new SbItem((string)dataReader["NickName"], (int)dataReader["FaceId"]);
item.Tag = (int)dataReader["FriendId"]; // 將號碼放在Tag屬性中
// SideBar中的組可以通過數組的方式訪問,按照添加的順序索引從0開始
sbFriends.Groups[0].Items.Add(item); // 向SideBar的“我的好友”組中添加項
}
// 窗體加載時顯示頭像圖片
private void FacesForm_Load(object sender, EventArgs e)
{
for (int i = 0; i < ilFaces.Images.Count; i++)
{
lvFaces.Items.Add(i.ToString());//從0-99的數字
lvFaces.Items[i].ImageIndex = i;//找到了對應於i的imagelist的圖片
}
}
class DBHelper
{
private static string connString = "Data Source=.;Initial Catalog=MyQQ;User ID=sa;Pwd=123";
public static SqlConnection connection = new SqlConnection(connString);
}
// 窗體加載時,填充數據集
private void SearchFriendForm_Load(object sender, EventArgs e)
{
// 實例化數據集和數據適配器並填充
string sql = "SELECT Id, NickName, Age, Sex FROM Users";
dataAdapter = new SqlDataAdapter(sql, DBHelper.connection);
dataSet = new DataSet("MyQQ");//從數據庫myqq裏面找數據
dataAdapter.Fill(dataSet, "Users");//自定義虛擬表名users,用fili()填充dataset
// 指定DataGridView的數據源
dgvBasicResult.DataSource = dataSet.Tables[0];
dgvAdvancedResult.DataSource = dataSet.Tables[0];
}
重新填充dataset的數據
dataAdapter.SelectCommand.CommandText = sql;
dataSet.Tables[0].Clear();
dataAdapter.Fill(dataSet, "Users");
// DataGridView沒有選中任何一行
if (dgvBasicResult.SelectedRows.Count == 0)
{
MessageBox.Show("請選擇一個好友!", "操作", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
// 確保第一個單元格有值
else if (dgvBasicResult.SelectedRows[0].Cells[0] != null)
{
// 獲得DataGridView中選中的行的第一個單元格的值
friendId = int.Parse(dgvBasicResult.SelectedRows[0].Cells[0].Value.ToString());
}
獲取下拉菜單選擇的菜單
string sexCondition = cboSex.Text; // 性別條件
sql = "SELECT @@Identity FROM Users"; // 查詢新增加的記錄的標識號id
command.CommandText = sql;
myQQNum = Convert.ToInt32(command.ExecuteScalar()); // 強制類型轉換會出錯
SELECT TOP 1 * FROM users 這個是SQLSERVER選擇表中符合條件的前N行記錄的語句
SELECT TOP 1 nickname FROM users 查詢user表中第一行對應的 nickname列
SELECT TOP 5 nickname FROM users 查詢user表中前5行對應的nickname 列
關於第三方控件的使用
sbFriends.SeletedItem.Parent.Items.Remove(sbFriends.SeletedItem);
SbItem item = new SbItem((string)dataReader["NickName"], (int)dataReader["FaceId"]);
item.Tag = (int)dataReader["FriendId"]; // 將好友號碼放在Tag屬性中
// SideBar中的組可以通過數組的方式訪問,按照添加的順序索引從0開始
sbFriends.Groups[0].Items.Add(item); // 向SideBar的“我的好友”組中添加項
添加陌生人爲好友時
sbFriends.SeletedItem.Parent.Items.Remove(sbFriends.SeletedItem);
ShowFriendList(); // 更新好友列表
if (sbFriends.VisibleGroup == sbFriends.Groups[0])//判斷展開的刪除好友的parednt是不是我的好友
判斷時間空間有沒有在運行
tmrChatRequest.Enabled == true
// 控制喇叭閃爍
int messageImageIndex=0;
private void tmrAddFriend_Tick(object sender, EventArgs e)
{
// 反覆修改它的圖像
messageImageIndex = messageImageIndex == 0 ? 1:0;
tsbtnMessageReading.Image = ilMessage.Images[messageImageIndex];
}
ChatForm chatForm = new ChatForm();
//friendId nickName faceId是chatForm窗體的公共的全局變量 這是向窗體傳多個參數
chatForm.friendId = Convert.ToInt32(e.Item.Tag); // 號碼
chatForm.nickName = e.Item.Text; // 暱稱
chatForm.faceId = e.Item.ImageIndex; // 頭像
chatForm.Show();
string sql = string.Format("UPDATE Users SET NickName='{0}', FaceId={1},Sex='{2}',Age={3}",
txtNickName.Text.Trim(), Convert.ToInt32(picFace.Tag), cboSex.Text.Trim(), Convert.ToInt32(txtAge.Text.Trim()));
if (txtNewPwd.Text.Trim() != "") // 如果修改了密碼就更新密碼字段
{
//承接了上一個語句sql,因爲有時候用戶未修改密碼
sql = string.Format("{0} ,LoginPwd='{1}' ", sql, txtNewPwd.Text.Trim());
}
把整個窗體mainForm傳給了窗體personalInfoForm
personalInfoForm.mainForm=this;
在personalInfoForm中
public MainForm mainForm; // 主窗體
修改了用戶的資料信息之後
mainForm.ShowSelfInfo(); // 更新主窗體中的個人信息
//記錄登錄的用戶Id
class UserHelper
{
public static int loginId; //登錄的用戶Id
}
UserHelper.loginId
類中編寫的全局變量,相當於session記錄當前用戶的qq號,可以再多個窗口使用
// 循環添加好友列表
while (dataReader.Read())
{
// 創建一個SideBar項
//SbItem(顯示的文字 圖像的索引)
SbItem item = new SbItem((string)dataReader["NickName"], (int)dataReader["FaceId"]);
item.Tag = (int)dataReader["FriendId"]; // 將號碼放在Tag屬性中
// SideBar中的組可以通過數組的方式訪問,按照添加的順序索引從0開始
sbFriends.Groups[0].Items.Add(item); // 向SideBar的“我的好友”組中添加項
}
// 窗體加載時顯示頭像圖片
private void FacesForm_Load(object sender, EventArgs e)
{
for (int i = 0; i < ilFaces.Images.Count; i++)
{
lvFaces.Items.Add(i.ToString());//從0-99的數字
lvFaces.Items[i].ImageIndex = i;//找到了對應於i的imagelist的圖片
}
}
class DBHelper
{
private static string connString = "Data Source=.;Initial Catalog=MyQQ;User ID=sa;Pwd=123";
public static SqlConnection connection = new SqlConnection(connString);
}
// 窗體加載時,填充數據集
private void SearchFriendForm_Load(object sender, EventArgs e)
{
// 實例化數據集和數據適配器並填充
string sql = "SELECT Id, NickName, Age, Sex FROM Users";
dataAdapter = new SqlDataAdapter(sql, DBHelper.connection);
dataSet = new DataSet("MyQQ");//從數據庫myqq裏面找數據
dataAdapter.Fill(dataSet, "Users");//自定義虛擬表名users,用fili()填充dataset
// 指定DataGridView的數據源
dgvBasicResult.DataSource = dataSet.Tables[0];
dgvAdvancedResult.DataSource = dataSet.Tables[0];
}
重新填充dataset的數據
dataAdapter.SelectCommand.CommandText = sql;
dataSet.Tables[0].Clear();
dataAdapter.Fill(dataSet, "Users");
// DataGridView沒有選中任何一行
if (dgvBasicResult.SelectedRows.Count == 0)
{
MessageBox.Show("請選擇一個好友!", "操作", MessageBoxButtons.OK, MessageBoxIcon.Information);
}
// 確保第一個單元格有值
else if (dgvBasicResult.SelectedRows[0].Cells[0] != null)
{
// 獲得DataGridView中選中的行的第一個單元格的值
friendId = int.Parse(dgvBasicResult.SelectedRows[0].Cells[0].Value.ToString());
}
獲取下拉菜單選擇的菜單
string sexCondition = cboSex.Text; // 性別條件
sql = "SELECT @@Identity FROM Users"; // 查詢新增加的記錄的標識號id
command.CommandText = sql;
myQQNum = Convert.ToInt32(command.ExecuteScalar()); // 強制類型轉換會出錯
SELECT TOP 1 * FROM users 這個是SQLSERVER選擇表中符合條件的前N行記錄的語句
SELECT TOP 1 nickname FROM users 查詢user表中第一行對應的 nickname列
SELECT TOP 5 nickname FROM users 查詢user表中前5行對應的nickname 列
關於第三方控件的使用
sbFriends.SeletedItem.Parent.Items.Remove(sbFriends.SeletedItem);
SbItem item = new SbItem((string)dataReader["NickName"], (int)dataReader["FaceId"]);
item.Tag = (int)dataReader["FriendId"]; // 將好友號碼放在Tag屬性中
// SideBar中的組可以通過數組的方式訪問,按照添加的順序索引從0開始
sbFriends.Groups[0].Items.Add(item); // 向SideBar的“我的好友”組中添加項
添加陌生人爲好友時
sbFriends.SeletedItem.Parent.Items.Remove(sbFriends.SeletedItem);
ShowFriendList(); // 更新好友列表
if (sbFriends.VisibleGroup == sbFriends.Groups[0])//判斷展開的刪除好友的parednt是不是我的好友
判斷時間空間有沒有在運行
tmrChatRequest.Enabled == true
// 控制喇叭閃爍
int messageImageIndex=0;
private void tmrAddFriend_Tick(object sender, EventArgs e)
{
// 反覆修改它的圖像
messageImageIndex = messageImageIndex == 0 ? 1:0;
tsbtnMessageReading.Image = ilMessage.Images[messageImageIndex];
}
ChatForm chatForm = new ChatForm();
//friendId nickName faceId是chatForm窗體的公共的全局變量 這是向窗體傳多個參數
chatForm.friendId = Convert.ToInt32(e.Item.Tag); // 號碼
chatForm.nickName = e.Item.Text; // 暱稱
chatForm.faceId = e.Item.ImageIndex; // 頭像
chatForm.Show();
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.