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();













發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章